Content of file DefaultResource.java.html
<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"><html xmlns="http://www.w3.org/1999/xhtml" lang="en"><head><meta http-equiv="Content-Type" content="text/html;charset=UTF-8"/><link rel="stylesheet" href="../../jacoco-resources/report.css" type="text/css"/><link rel="shortcut icon" href="../../jacoco-resources/report.gif" type="image/gif"/><title>DefaultResource.java</title><link rel="stylesheet" href="../../jacoco-resources/prettify.css" type="text/css"/><script type="text/javascript" src="../../jacoco-resources/prettify.js"></script></head><body onload="window['PR_TAB_WIDTH']=4;prettyPrint()"><div class="breadcrumb" id="breadcrumb"><span class="info"><a href="../../jacoco-sessions.html" class="el_session">Sessions</a></span><a href="../../index.html" class="el_report">NorthernWind :: Filesystems :: SCM :: Git</a> > <a href="../index.html" class="el_bundle">it-tidalwave-northernwind-core-default</a> > <a href="index.source.html" class="el_package">it.tidalwave.northernwind.core.impl.model</a> > <span class="el_source">DefaultResource.java</span></div><h1>DefaultResource.java</h1><pre class="source lang-java linenums">/*
* #%L
* *********************************************************************************************************************
*
* NorthernWind - lightweight CMS
* http://northernwind.tidalwave.it - git clone https://bitbucket.org/tidalwave/northernwind-src.git
* %%
* Copyright (C) 2011 - 2023 Tidalwave s.a.s. (http://tidalwave.it)
* %%
* *********************************************************************************************************************
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on
* an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the
* specific language governing permissions and limitations under the License.
*
* *********************************************************************************************************************
*
*
* *********************************************************************************************************************
* #L%
*/
package it.tidalwave.northernwind.core.impl.model;
import javax.annotation.Nonnull;
import javax.annotation.PostConstruct;
import javax.inject.Inject;
import java.util.HashMap;
import java.util.Locale;
import java.util.Map;
import java.io.IOException;
import org.springframework.beans.factory.annotation.Configurable;
import it.tidalwave.northernwind.core.model.RequestLocaleManager;
import it.tidalwave.northernwind.core.model.Resource;
import it.tidalwave.northernwind.core.model.ResourceProperties;
import it.tidalwave.northernwind.core.model.spi.ResourceSupport;
import lombok.Cleanup;
import lombok.Getter;
import lombok.ToString;
import lombok.extern.slf4j.Slf4j;
import static it.tidalwave.role.io.Unmarshallable._Unmarshallable_;
/***********************************************************************************************************************
*
* The default implementation for {@link Resource}.
*
* @author Fabrizio Giudici
*
**********************************************************************************************************************/
<span class="nc" id="L54">@Configurable @Slf4j @ToString(callSuper = true, of = "placeHolder")</span>
/* package */ class DefaultResource extends ResourceSupport
{
@Inject
private InheritanceHelper inheritanceHelper;
@Inject
private RequestLocaleManager localeRequestManager;
<span class="nc" id="L63"> private final Map<Locale, ResourceProperties> propertyMapByLocale = new HashMap<>();</span>
<span class="nc" id="L65"> @Getter</span>
private boolean placeHolder;
private final ResourceProperties.PropertyResolver propertyResolver;
/*******************************************************************************************************************
*
*
******************************************************************************************************************/
public DefaultResource (@Nonnull final Resource.Builder builder)
{
<span class="nc bnc" id="L76" title="All 18 branches missed."> super(builder);</span>
<span class="nc" id="L77"> propertyResolver = new TextResourcePropertyResolver(getFile());</span>
<span class="nc bnc" id="L78" title="All 4 branches missed."> }</span>
/*******************************************************************************************************************
*
* {@inheritDoc}
*
******************************************************************************************************************/
@Override @Nonnull
public ResourceProperties getProperties()
{
<span class="nc" id="L88"> return propertyMapByLocale.get(localeRequestManager.getLocales().get(0));</span>
}
/*******************************************************************************************************************
*
*
******************************************************************************************************************/
@PostConstruct
/* package */ void loadProperties()
throws IOException
{
<span class="nc" id="L99"> final var file = getFile();</span>
<span class="nc" id="L100"> log.debug("loadProperties() for {}", file.getPath().asString());</span>
<span class="nc" id="L102"> var tmpPlaceHolder = true;</span>
<span class="nc bnc" id="L104" title="All 2 branches missed."> for (final var locale : localeRequestManager.getLocales())</span>
{
<span class="nc" id="L106"> var properties = modelFactory.createProperties().withPropertyResolver(propertyResolver).build();</span>
<span class="nc bnc" id="L108" title="All 2 branches missed."> if (file.isData())</span>
{
<span class="nc" id="L110"> tmpPlaceHolder = false;</span>
}
else
{
<span class="nc bnc" id="L114" title="All 2 branches missed."> for (final var propertyFile : inheritanceHelper.getInheritedPropertyFiles(file, locale, "Properties"))</span>
{
<span class="nc" id="L116"> log.trace(">>>> reading properties from {} ({})...", propertyFile.getPath().asString(), locale);</span>
<span class="nc bnc" id="L117" title="All 2 branches missed."> @Cleanup final var is = propertyFile.getInputStream();</span>
<span class="nc" id="L118"> final ResourceProperties tempProperties =</span>
<span class="nc" id="L119"> modelFactory.createProperties().build().as(_Unmarshallable_).unmarshal(is);</span>
// modelFactory.createProperties().withPropertyResolver(propertyResolver).build().as(_Unmarshallable_).unmarshal(is);
<span class="nc" id="L121"> log.trace(">>>>>>>> read properties: {} ({})", tempProperties, locale);</span>
<span class="nc" id="L122"> properties = properties.merged(tempProperties);</span>
<span class="nc bnc" id="L123" title="All 2 branches missed."> tmpPlaceHolder &= !propertyFile.getParent().equals(file);</span>
<span class="nc" id="L124"> }</span>
}
<span class="nc" id="L127"> placeHolder = properties.getProperty(P_PLACE_HOLDER).orElse(tmpPlaceHolder);</span>
<span class="nc bnc" id="L129" title="All 2 branches missed."> if (log.isDebugEnabled())</span>
{
<span class="nc" id="L131"> log.debug(">>>> properties for {} ({}):", file.getPath().asString(), locale);</span>
<span class="nc" id="L132"> logProperties(">>>>>>>>", properties);</span>
}
<span class="nc" id="L135"> propertyMapByLocale.put(locale, properties);</span>
<span class="nc" id="L136"> }</span>
<span class="nc" id="L137"> }</span>
/*******************************************************************************************************************
*
* FIXME: move to ResourceProperties!
| move to ResourceProperties! | |
*
******************************************************************************************************************/
private static void logProperties (@Nonnull final String indent,
@Nonnull final ResourceProperties properties)
{
<span class="nc" id="L147"> log.debug("{} property items:", indent);</span>
<span class="nc bnc" id="L149" title="All 2 branches missed."> for (final var key : properties.getKeys())</span>
{
<span class="nc" id="L151"> log.debug("{}>>>> {} = {}", indent, key, properties.getProperty(key));</span>
<span class="nc" id="L152"> }</span>
<span class="nc" id="L154"> log.debug("{} property groups: {}", indent, properties.getGroupIds());</span>
<span class="nc bnc" id="L156" title="All 2 branches missed."> for (final var groupId : properties.getGroupIds())</span>
{
<span class="nc" id="L158"> log.debug("{}>>>> group: {}", indent, groupId);</span>
<span class="nc" id="L159"> logProperties(indent + ">>>>", properties.getGroup(groupId));</span>
<span class="nc" id="L160"> }</span>
<span class="nc" id="L161"> }</span>
}
</pre><div class="footer"><span class="right">Created with <a href="http://www.jacoco.org/jacoco">JaCoCo</a> 0.8.9.202303310957</span></div></body></html>