http://git-wip-us.apache.org/repos/asf/incubator-tamaya-site/blob/4176b5bc/documentation/extensions/mod_spring.html ---------------------------------------------------------------------- diff --git a/documentation/extensions/mod_spring.html b/documentation/extensions/mod_spring.html new file mode 100644 index 0000000..974f903 --- /dev/null +++ b/documentation/extensions/mod_spring.html @@ -0,0 +1,331 @@ +<!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"> + <head> + <meta charset="utf-8"/> + <title>Apache Tamaya&#8201;&#8212;&#8201;Extension: Spring Integration</title> + <meta name="viewport" content="width=device-width, initial-scale=1.0"/> + <meta name="description" content=""/> + <meta name="author" content=""/> + <meta name="keywords" content=""/> + <meta name="generator" content="'JBake '+'${version}"/> + + <!-- Le styles --> + <link href="../../css/bootstrap.min.css" rel="stylesheet"/> + <link href="../../css/asciidoctor.css" rel="stylesheet"/> + <link href="../../css/base.css" rel="stylesheet"/> + <link href="../../css/prettify.css" rel="stylesheet"/> + + <!-- HTML5 shim, for IE6-8 support of HTML5 elements --> + <!--[if lt IE 9]> + <script src="../../js/html5shiv.min.js"></script> + <![endif]--> + + <!-- Fav and touch icons from ASF --> + <link rel="shortcut icon" href="../../favicon.ico"/> + <link rel="apple-touch-icon" sizes="57x57" href="../../favicons/apple-touch-icon-57x57.png"/> + <link rel="apple-touch-icon" sizes="60x60" href="../../favicons/apple-touch-icon-60x60.png"/> + <link rel="apple-touch-icon" sizes="72x72" href="../../favicons/apple-touch-icon-72x72.png"/> + <link rel="apple-touch-icon" sizes="76x76" href="../../favicons/apple-touch-icon-76x76.png"/> + <link rel="apple-touch-icon" sizes="114x114" href="../../favicons/apple-touch-icon-114x114.png"/> + <link rel="apple-touch-icon" sizes="120x120" href="../../favicons/apple-touch-icon-120x120.png"/> + <link rel="apple-touch-icon" sizes="144x144" href="../../favicons/apple-touch-icon-144x144.png"/> + <link rel="apple-touch-icon" sizes="152x152" href="../../favicons/apple-touch-icon-152x152.png"/> + <link rel="apple-touch-icon" sizes="180x180" href="../../favicons/apple-touch-icon-180x180.png"/> + <link rel="icon" type="image/png" href="../../favicons/favicon-32x32.png" sizes="32x32"/> + <link rel="icon" type="image/png" href="../../favicons/favicon-194x194.png" sizes="194x194"/> + <link rel="icon" type="image/png" href="../../favicons/favicon-96x96.png" sizes="96x96"/> + <link rel="icon" type="image/png" href="../../favicons/android-chrome-192x192.png" sizes="192x192"/> + <link rel="icon" type="image/png" href="../../favicons/favicon-16x16.png" sizes="16x16"/> + <link rel="manifest" href="../../favicons/manifest.json"/> + <link rel="shortcut icon" href="../../favicons/favicon.ico"/> + <meta name="msapplication-TileColor" content="#603cba"/> + <meta name="msapplication-TileImage" content="../../favicons/mstile-144x144.png"/> + <meta name="msapplication-config" content="../../favicons/browserconfig.xml"/> + <meta name="theme-color" content="#303284"/> + </head> + <body onload="prettyPrint()"> + <div id="wrap"> + <div> + + <!-- Fixed navbar --> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-collapse"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <a class="navbar-brand" href="../../">Apache Tamaya (incubating)</a> + </div> + <div class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li><a href="../../index.html">Home</a></li> + <li><a href="../../about.html">About</a></li> + <li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown">Documentation <b class="caret"></b></a> + <ul class="dropdown-menu"> + <li><a href="../../documentation/usecases.html">Use Cases and Requirements</a></li> + <li><a href="../../documentation/quickstart.html">Quickstart</a></li> + <li><a href="../../documentation/api.html">API</a></li> + <li><a href="../../documentation/core.html">Core</a></li> + <li><a href="../../documentation/extensions.html">Extension Guide</a></li> + <li class="divider"></li> + <li><a href="../../apidocs/index.html">Javadoc ${tamaya_version} (external)</a></li> + </ul> + </li> + <li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown">Development <b class="caret"></b></a> + <ul class="dropdown-menu"> + <li><a href="../../development/source.html">Sources</a></li> + <li><a href="../../development/community.html">Community</a></li> + <li><a href="../../devguide.html">Development Guide</a></li> + <li><a href="../../release-guide.html">Release Guide</a></li> + </ul> + </li> + <li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown">Releases <b class="caret"></b></a> + <ul class="dropdown-menu"> + <li><a href="../../download.html">Download</a></li> + <li><a href="../../history.html">Release History</a></li> + </ul> + </li> +<!-- Example: + <li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown">Dropdown <b class="caret"></b></a> + <ul class="dropdown-menu"> + <li><a href="#">Action</a></li> + <li><a href="#">Another action</a></li> + <li><a href="#">Something else here</a></li> + <li class="divider"></li> + <li class="dropdown-header">Nav header</li> + <li><a href="#">Separated link</a></li> + <li><a href="#">One more separated link</a></li> + </ul> + </li> +--> + <li><a href="../../sitemap.xml">Sitemap</a></li> + <li><a href="../../feed.xml">Subscribe</a></li> + </ul> + </div><!--/.nav-collapse --> + </div> + </div> + + </div> + <div class="container"> + + <div class="page-header"> + <h1>Apache Tamaya&#8201;&#8212;&#8201;Extension: Spring Integration</h1> + </div> + + <p><em>2016-12-18</em></p> + + <p><div id="preamble"> +<div class="sectionbody"> +<!-- toc disabled --> +</div> +</div> +<div class="sect1"> +<h2 id="Remote">Tamaya Spring Integration (Extension Module)</h2> +<div class="sectionbody"> +<div class="sect2"> +<h3 id="_overview">Overview</h3> +<div class="paragraph"> +<p>Apache Tamaya currently provides two implementations also full integration for Spring:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>A Spring @Configuration implementation that also provides a Tamaya based version of +org.springframework.context.support.PropertySourcesPlaceholderConfigurer.</p> +</li> +<li> +<p>org.apache.tamaya.integration.spring.TamayaEnvironment is the Tamaya based implementation of the Spring +Environment interface.</p> +</li> +<li> +<p>TamayaSpringPropertySource implements an additional Spring PropertySource.</p> +</li> +<li> +<p>Finally org.apache.tamaya.integration.spring.SpringConfigInjectionPostProcessor implements a Bean PostProcessor, +which adds all the full fledged Tamaya configuration capabilities to Spring.</p> +</li> +</ul> +</div> +</div> +<div class="sect2"> +<h3 id="_compatibility">Compatibility</h3> +<div class="paragraph"> +<p>Both modules are based on Java 7, so they will run on Java 7 and beyond. The extension shown here works similarly +with Spring Framework as well as Spring Boot.</p> +</div> +</div> +<div class="sect2"> +<h3 id="_installation">Installation</h3> +<div class="paragraph"> +<p>To benefit from Tamaya Spring integration you only must one of the following dependencies to your module:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="prettyprint highlight"><code class="language-xml" data-lang="xml"><dependency> + <groupId>org.apache.tamaya.ext</groupId> + <artifactId>tamaya-spring</artifactId> + <version>{tamaya_version}</version> +</dependency></code></pre> +</div> +</div> +</div> +<div class="sect2"> +<h3 id="_registering_tamaya_spring_configuration">Registering Tamaya Spring Configuration</h3> +<div class="paragraph"> +<p>Basically to activate the Tamaya Spring support the most simple thing is to a enable the Tamaya package for being +scanned for Spring components, e.g.</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="prettyprint highlight"><code class="language-xml" data-lang="xml"><beans xmlns="http://www.springframework.org/schema/beans" + xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" + xmlns:context="http://www.springframework.org/schema/context" + xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd"> + + <context:annotation-config /> + <context:component-scan base-package="org.apache.tamaya.integration.spring"/> + + ... + +</beans></code></pre> +</div> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<div class="title">Note</div> +</td> +<td class="content"> +Of course you can also use the newer @ComponentScan annotation as described by the Spring documentation. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>Similarly if you dont want to use component scanning you can configure things using plain old XML. Simply add the +following lines somewhere into one of your application context configuration files.</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="prettyprint highlight"><code class="language-xml" data-lang="xml"><bean id="tamayaInjectionProcessor" name="tamayaInjectionProcessor" class="org.apache.tamaya.integration.spring.SpringConfigInjectionPostProcessor"/> +<bean id="tamayaConfigProvider" name="tamayaConfigProvider" class="org.apache.tamaya.integration.spring.TamayaSpringConfig"/></code></pre> +</div> +</div> +</div> +<div class="sect2"> +<h3 id="_configuring_your_context">Configuring your Context</h3> +<div class="paragraph"> +<p>Done so enables you to use Tamaya as a backend for property resolution, e.g. propertyValue as illustrated below +is resolved from the current Tamaya configuration.</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="prettyprint highlight"><code class="language-xml" data-lang="xml"><bean id="configuredBean" name="configuredBean" class="org.apache.tamaya.integration.spring.ConfiguredSpringBean"> + <property name="message" value="${propertyValue}"/> +</bean></code></pre> +</div> +</div> +</div> +<div class="sect2"> +<h3 id="_configuring_your_beans">Configuring your Beans</h3> +<div class="paragraph"> +<p>Similarly you can inject any kind of configuration as supported by Tamaya into your Spring managed beans:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="prettyprint highlight"><code class="language-java" data-lang="java">** + * Created by Anatole on 25.09.2015. + */ +@ConfigDefaultSections +public class ConfiguredSpringBean { + + private String message; + + @Autowired + private Environment env; + + @Config("java.version") + private String javaVersion; + + @Config + @ConfigDefault("23") + private int testNumber; + + public String getJavaVersion(){ + return javaVersion; + } + + public int getTestNumber(){ + return testNumber; + } + + public Environment getEnv(){ + return env; + } + + public void setMessage(String message){ + this.message = message; + } + + public String getMessage() { + return message; + } +}</code></pre> +</div> +</div> +<div class="paragraph"> +<p>Summarizing you get all the nice features of Tamaya out of the box running with your Spring code.</p> +</div> +</div> +</div> +</div></p> + + <hr /> + </div> + </div> + <div> + <div id="push"></div> + + <div id="footer"> + <div class="container"> + <p class="muted credit">© 2014-2016 Apache Software Foundation | Mixed with <a href="http://getbootstrap.com/">Bootstrap v3.1.1</a> + | Baked with <a href="http://jbake.org">JBake <span>v2.5.0</span></a> + at <span>2016-12-18</span> + </p> + <p> + <b>Disclaimer</b> + Apache Tamaya (incubating) is an effort undergoing + incubation at + The Apache Software Foundation (ASF), sponsored by + the name of Apache Incubator. Incubation is required of + all newly accepted projects until a further review indicates + that the infrastructure, communications, and decision making + process have stabilized in a manner consistent with other + successful ASF projects. While incubation status is not + necessarily a reflection of the completeness or stability of + the code, it does indicate that the project has yet to + be fully endorsed by the ASF.<br /> + <a href="http://incubator.apache.org/guides/website.html" style="border:0px;" target="_target"><img class="incubator-logo" src="../../logos/egg-logo2.png"/></a> + </p> + </div> + </div> + + <!-- Le javascript + ================================================== --> + <!-- Placed at the end of the document so the pages load faster --> + <script src="../../js/jquery-1.11.1.min.js"></script> + <script src="../../js/bootstrap.min.js"></script> + <script src="../../js/prettify.js"></script> + + </div> + </body> +</html>
http://git-wip-us.apache.org/repos/asf/incubator-tamaya-site/blob/4176b5bc/documentation/extensions/mod_yaml.html ---------------------------------------------------------------------- diff --git a/documentation/extensions/mod_yaml.html b/documentation/extensions/mod_yaml.html new file mode 100644 index 0000000..5142ac2 --- /dev/null +++ b/documentation/extensions/mod_yaml.html @@ -0,0 +1,288 @@ +<!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"> + <head> + <meta charset="utf-8"/> + <title>Apache Tamaya&#8201;&#8212;&#8201;Extension: Builder</title> + <meta name="viewport" content="width=device-width, initial-scale=1.0"/> + <meta name="description" content=""/> + <meta name="author" content=""/> + <meta name="keywords" content=""/> + <meta name="generator" content="'JBake '+'${version}"/> + + <!-- Le styles --> + <link href="../../css/bootstrap.min.css" rel="stylesheet"/> + <link href="../../css/asciidoctor.css" rel="stylesheet"/> + <link href="../../css/base.css" rel="stylesheet"/> + <link href="../../css/prettify.css" rel="stylesheet"/> + + <!-- HTML5 shim, for IE6-8 support of HTML5 elements --> + <!--[if lt IE 9]> + <script src="../../js/html5shiv.min.js"></script> + <![endif]--> + + <!-- Fav and touch icons from ASF --> + <link rel="shortcut icon" href="../../favicon.ico"/> + <link rel="apple-touch-icon" sizes="57x57" href="../../favicons/apple-touch-icon-57x57.png"/> + <link rel="apple-touch-icon" sizes="60x60" href="../../favicons/apple-touch-icon-60x60.png"/> + <link rel="apple-touch-icon" sizes="72x72" href="../../favicons/apple-touch-icon-72x72.png"/> + <link rel="apple-touch-icon" sizes="76x76" href="../../favicons/apple-touch-icon-76x76.png"/> + <link rel="apple-touch-icon" sizes="114x114" href="../../favicons/apple-touch-icon-114x114.png"/> + <link rel="apple-touch-icon" sizes="120x120" href="../../favicons/apple-touch-icon-120x120.png"/> + <link rel="apple-touch-icon" sizes="144x144" href="../../favicons/apple-touch-icon-144x144.png"/> + <link rel="apple-touch-icon" sizes="152x152" href="../../favicons/apple-touch-icon-152x152.png"/> + <link rel="apple-touch-icon" sizes="180x180" href="../../favicons/apple-touch-icon-180x180.png"/> + <link rel="icon" type="image/png" href="../../favicons/favicon-32x32.png" sizes="32x32"/> + <link rel="icon" type="image/png" href="../../favicons/favicon-194x194.png" sizes="194x194"/> + <link rel="icon" type="image/png" href="../../favicons/favicon-96x96.png" sizes="96x96"/> + <link rel="icon" type="image/png" href="../../favicons/android-chrome-192x192.png" sizes="192x192"/> + <link rel="icon" type="image/png" href="../../favicons/favicon-16x16.png" sizes="16x16"/> + <link rel="manifest" href="../../favicons/manifest.json"/> + <link rel="shortcut icon" href="../../favicons/favicon.ico"/> + <meta name="msapplication-TileColor" content="#603cba"/> + <meta name="msapplication-TileImage" content="../../favicons/mstile-144x144.png"/> + <meta name="msapplication-config" content="../../favicons/browserconfig.xml"/> + <meta name="theme-color" content="#303284"/> + </head> + <body onload="prettyPrint()"> + <div id="wrap"> + <div> + + <!-- Fixed navbar --> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-collapse"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <a class="navbar-brand" href="../../">Apache Tamaya (incubating)</a> + </div> + <div class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li><a href="../../index.html">Home</a></li> + <li><a href="../../about.html">About</a></li> + <li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown">Documentation <b class="caret"></b></a> + <ul class="dropdown-menu"> + <li><a href="../../documentation/usecases.html">Use Cases and Requirements</a></li> + <li><a href="../../documentation/quickstart.html">Quickstart</a></li> + <li><a href="../../documentation/api.html">API</a></li> + <li><a href="../../documentation/core.html">Core</a></li> + <li><a href="../../documentation/extensions.html">Extension Guide</a></li> + <li class="divider"></li> + <li><a href="../../apidocs/index.html">Javadoc ${tamaya_version} (external)</a></li> + </ul> + </li> + <li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown">Development <b class="caret"></b></a> + <ul class="dropdown-menu"> + <li><a href="../../development/source.html">Sources</a></li> + <li><a href="../../development/community.html">Community</a></li> + <li><a href="../../devguide.html">Development Guide</a></li> + <li><a href="../../release-guide.html">Release Guide</a></li> + </ul> + </li> + <li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown">Releases <b class="caret"></b></a> + <ul class="dropdown-menu"> + <li><a href="../../download.html">Download</a></li> + <li><a href="../../history.html">Release History</a></li> + </ul> + </li> +<!-- Example: + <li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown">Dropdown <b class="caret"></b></a> + <ul class="dropdown-menu"> + <li><a href="#">Action</a></li> + <li><a href="#">Another action</a></li> + <li><a href="#">Something else here</a></li> + <li class="divider"></li> + <li class="dropdown-header">Nav header</li> + <li><a href="#">Separated link</a></li> + <li><a href="#">One more separated link</a></li> + </ul> + </li> +--> + <li><a href="../../sitemap.xml">Sitemap</a></li> + <li><a href="../../feed.xml">Subscribe</a></li> + </ul> + </div><!--/.nav-collapse --> + </div> + </div> + + </div> + <div class="container"> + + <div class="page-header"> + <h1>Apache Tamaya&#8201;&#8212;&#8201;Extension: Builder</h1> + </div> + + <p><em>2016-12-18</em></p> + + <p><div id="preamble"> +<div class="sectionbody"> +<!-- toc disabled --> +</div> +</div> +<div class="sect1"> +<h2 id="BuilderCore">Tamaya YAML (Extension Module)</h2> +<div class="sectionbody"> +<div class="sect2"> +<h3 id="_overview">Overview</h3> +<div class="paragraph"> +<p>The Tamaya YAML module provides support for reading configuration using the YAML format (yaml.org). YAML hereby +use intendation for expressing hierarchy, which makes yaml configuration files very easily readable and compact.</p> +</div> +</div> +<div class="sect2"> +<h3 id="_compatibility">Compatibility</h3> +<div class="paragraph"> +<p>The YAML module is based on Java 7, so it will run on Java 7 and beyond.</p> +</div> +</div> +<div class="sect2"> +<h3 id="_installation">Installation</h3> +<div class="paragraph"> +<p>To benefit from configuration builder support you only must add the corresponding dependency to your module:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="prettyprint highlight"><code class="language-xml" data-lang="xml"><dependency> + <groupId>org.apache.tamaya.ext</groupId> + <artifactId>tamaya-yaml</artifactId> + <version>{tamaya_version}</version> +</dependency></code></pre> +</div> +</div> +<div class="paragraph"> +<p>This extension also transitively requires the tamaya.formats module.</p> +</div> +</div> +<div class="sect2"> +<h3 id="_reading_configuration_in_yaml">Reading configuration in YAML</h3> +<div class="paragraph"> +<p>For reading YAML based onfiguration most easily a YAMLFormat can be provided:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="prettyprint highlight"><code class="language-java" data-lang="java">ConfigurationData dataRead = ConfigurationFormats.readConfig( + getClassLoader().getResource("myFileConfig.yaml"), new YAMLFormat()));</code></pre> +</div> +</div> +</div> +<div class="sect2"> +<h3 id="_examples">Examples</h3> +<div class="paragraph"> +<p>The YAML module adds instances of ConfigurationFormat so YAML configuration can be read and mapped to the +according property values. E.g. the following file is a simple and correct YAML configuration:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="prettyprint highlight"><code class="language-yaml" data-lang="yaml">invoice: 34843 +date : 2001-01-23 +bill-to: &id001 + given : Chris + family : Dumars + address: + lines: | + 458 Walkman Dr. + Suite #292 + city : Royal Oak + state : MI + postal : 48046 +ship-to: *id001 +product: + - sku : BL394D + quantity : 4 + description : Basketball + price : 450.00 + - sku : BL4438H + quantity : 1 + description : Super Hoop + price : 2392.00 +tax : 251.42 +total: 4443.52 +comments: + Late afternoon is best. + Backup contact is Nancy + Billsmer @ 338-4338.</code></pre> +</div> +</div> +<div class="paragraph"> +<p>Hereby the above file, by default is mapped as follows into Map<String,String> typed properties:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="prettyprint highlight"><code class="language-listing" data-lang="listing">invoice -> 34843 +date -> Tue Jan 23 01:00:00 CET 2001 +bill-to.family -> Dumars +bill-to.given -> Chris +bill-to.address.state -> MI +bill-to.address.postal -> 48046 +bill-to.address.city -> Royal Oak +bill-to.address.lines -> 458 Walkman Dr. +Suite #292 + +ship-to.given -> Chris +ship-to.address.state -> MI +ship-to.family -> Dumars +ship-to.address.postal -> 48046 +ship-to.address.city -> Royal Oak +ship-to.address.lines -> 458 Walkman Dr. +Suite #292 + +product -> {sku=BL394D, quantity=4, description=Basketball, price=450.0},{sku=BL4438H, quantity=1, description=Super Hoop, price=2392.0} +_product.collection-type -> List + +tax -> 251.42 +total -> 4443.52 +comments -> Late afternoon is best. Backup contact is Nancy Billsmer @ 338-4338.</code></pre> +</div> +</div> +</div> +</div> +</div></p> + + <hr /> + </div> + </div> + <div> + <div id="push"></div> + + <div id="footer"> + <div class="container"> + <p class="muted credit">© 2014-2016 Apache Software Foundation | Mixed with <a href="http://getbootstrap.com/">Bootstrap v3.1.1</a> + | Baked with <a href="http://jbake.org">JBake <span>v2.5.0</span></a> + at <span>2016-12-18</span> + </p> + <p> + <b>Disclaimer</b> + Apache Tamaya (incubating) is an effort undergoing + incubation at + The Apache Software Foundation (ASF), sponsored by + the name of Apache Incubator. Incubation is required of + all newly accepted projects until a further review indicates + that the infrastructure, communications, and decision making + process have stabilized in a manner consistent with other + successful ASF projects. While incubation status is not + necessarily a reflection of the completeness or stability of + the code, it does indicate that the project has yet to + be fully endorsed by the ASF.<br /> + <a href="http://incubator.apache.org/guides/website.html" style="border:0px;" target="_target"><img class="incubator-logo" src="../../logos/egg-logo2.png"/></a> + </p> + </div> + </div> + + <!-- Le javascript + ================================================== --> + <!-- Placed at the end of the document so the pages load faster --> + <script src="../../js/jquery-1.11.1.min.js"></script> + <script src="../../js/bootstrap.min.js"></script> + <script src="../../js/prettify.js"></script> + + </div> + </body> +</html> http://git-wip-us.apache.org/repos/asf/incubator-tamaya-site/blob/4176b5bc/documentation/quickstart.html ---------------------------------------------------------------------- diff --git a/documentation/quickstart.html b/documentation/quickstart.html new file mode 100644 index 0000000..2d8893d --- /dev/null +++ b/documentation/quickstart.html @@ -0,0 +1,398 @@ +<!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"> + <head> + <meta charset="utf-8"/> + <title>Tamaya Incubator</title> + <meta name="viewport" content="width=device-width, initial-scale=1.0"/> + <meta name="description" content=""/> + <meta name="author" content=""/> + <meta name="keywords" content=""/> + <meta name="generator" content="'JBake '+'${version}"/> + + <!-- Le styles --> + <link href="../css/bootstrap.min.css" rel="stylesheet"/> + <link href="../css/asciidoctor.css" rel="stylesheet"/> + <link href="../css/base.css" rel="stylesheet"/> + <link href="../css/prettify.css" rel="stylesheet"/> + + <!-- HTML5 shim, for IE6-8 support of HTML5 elements --> + <!--[if lt IE 9]> + <script src="../js/html5shiv.min.js"></script> + <![endif]--> + + <!-- Fav and touch icons from ASF --> + <link rel="shortcut icon" href="../favicon.ico"/> + <link rel="apple-touch-icon" sizes="57x57" href="../favicons/apple-touch-icon-57x57.png"/> + <link rel="apple-touch-icon" sizes="60x60" href="../favicons/apple-touch-icon-60x60.png"/> + <link rel="apple-touch-icon" sizes="72x72" href="../favicons/apple-touch-icon-72x72.png"/> + <link rel="apple-touch-icon" sizes="76x76" href="../favicons/apple-touch-icon-76x76.png"/> + <link rel="apple-touch-icon" sizes="114x114" href="../favicons/apple-touch-icon-114x114.png"/> + <link rel="apple-touch-icon" sizes="120x120" href="../favicons/apple-touch-icon-120x120.png"/> + <link rel="apple-touch-icon" sizes="144x144" href="../favicons/apple-touch-icon-144x144.png"/> + <link rel="apple-touch-icon" sizes="152x152" href="../favicons/apple-touch-icon-152x152.png"/> + <link rel="apple-touch-icon" sizes="180x180" href="../favicons/apple-touch-icon-180x180.png"/> + <link rel="icon" type="image/png" href="../favicons/favicon-32x32.png" sizes="32x32"/> + <link rel="icon" type="image/png" href="../favicons/favicon-194x194.png" sizes="194x194"/> + <link rel="icon" type="image/png" href="../favicons/favicon-96x96.png" sizes="96x96"/> + <link rel="icon" type="image/png" href="../favicons/android-chrome-192x192.png" sizes="192x192"/> + <link rel="icon" type="image/png" href="../favicons/favicon-16x16.png" sizes="16x16"/> + <link rel="manifest" href="../favicons/manifest.json"/> + <link rel="shortcut icon" href="../favicons/favicon.ico"/> + <meta name="msapplication-TileColor" content="#603cba"/> + <meta name="msapplication-TileImage" content="../favicons/mstile-144x144.png"/> + <meta name="msapplication-config" content="../favicons/browserconfig.xml"/> + <meta name="theme-color" content="#303284"/> + </head> + <body onload="prettyPrint()"> + <div id="wrap"> + <div> + + <!-- Fixed navbar --> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-collapse"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <a class="navbar-brand" href="../">Apache Tamaya (incubating)</a> + </div> + <div class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li><a href="../index.html">Home</a></li> + <li><a href="../about.html">About</a></li> + <li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown">Documentation <b class="caret"></b></a> + <ul class="dropdown-menu"> + <li><a href="../documentation/usecases.html">Use Cases and Requirements</a></li> + <li><a href="../documentation/quickstart.html">Quickstart</a></li> + <li><a href="../documentation/api.html">API</a></li> + <li><a href="../documentation/core.html">Core</a></li> + <li><a href="../documentation/extensions.html">Extension Guide</a></li> + <li class="divider"></li> + <li><a href="../apidocs/index.html">Javadoc ${tamaya_version} (external)</a></li> + </ul> + </li> + <li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown">Development <b class="caret"></b></a> + <ul class="dropdown-menu"> + <li><a href="../development/source.html">Sources</a></li> + <li><a href="../development/community.html">Community</a></li> + <li><a href="../devguide.html">Development Guide</a></li> + <li><a href="../release-guide.html">Release Guide</a></li> + </ul> + </li> + <li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown">Releases <b class="caret"></b></a> + <ul class="dropdown-menu"> + <li><a href="../download.html">Download</a></li> + <li><a href="../history.html">Release History</a></li> + </ul> + </li> +<!-- Example: + <li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown">Dropdown <b class="caret"></b></a> + <ul class="dropdown-menu"> + <li><a href="#">Action</a></li> + <li><a href="#">Another action</a></li> + <li><a href="#">Something else here</a></li> + <li class="divider"></li> + <li class="dropdown-header">Nav header</li> + <li><a href="#">Separated link</a></li> + <li><a href="#">One more separated link</a></li> + </ul> + </li> +--> + <li><a href="../sitemap.xml">Sitemap</a></li> + <li><a href="../feed.xml">Subscribe</a></li> + </ul> + </div><!--/.nav-collapse --> + </div> + </div> + + </div> + <div class="container"> + + <div class="page-header"> + <h1></h1> + </div> + + <p><em>2016-12-18</em></p> + + <p><div class="sect1"> +<h2 id="_apache_tamaya_quickstart">Apache Tamaya: Quickstart</h2> +<div class="sectionbody"> +<div class="paragraph"> +<p>The fastest way to start with Tamaya is just using the <em>Core</em> implementation, +implementing the <strong>API</strong> in small, minimalistic way. For that add the following +Maven dependency to your project:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="prettyprint highlight"><code class="language-xml" data-lang="xml"><dependency> + <groupId>org.apache.tamaya</groupId> + <artifactId>tamaya-core</artifactId> + <version>0.3-SNAPSHOT</version> +</dependency></code></pre> +</div> +</div> +<div class="paragraph"> +<p>Given that you can add your configuration properties to the following locations in your classpath:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="prettyprint highlight"><code>META-INF/javaconfiguration.properties</code></pre> +</div> +</div> +<div class="paragraph"> +<p>Additionally also system properties are taken into account, hereby overriding the default properties. Overall +Tamaya by default defines the following configuration model per default (most significant first):</p> +</div> +<div class="olist arabic"> +<ol class="arabic"> +<li> +<p>System Properties</p> +</li> +<li> +<p><code>META-INF/javaconfiguration.properties</code></p> +</li> +</ol> +</div> +<div class="paragraph"> +<p>There many modules that extend the capabilities of Tamaya. +These modules doe not depend on core, so alternative +implementations of the Tamaya API should work similarly.</p> +</div> +<div class="sect2"> +<h3 id="_multiple_configuration_files">Multiple configuration files</h3> +<div class="paragraph"> +<p>By default you can provide multiple <code>javaconfig.properties</code> files, e.g. as part +of multiple jars loaded into your system. The system internally creates one +<code>PropertySource</code> for each file found on the classpath. All <code>PropertySource</code> +instances created are ordered by their ordinal value (an int).</p> +</div> +<div class="paragraph"> +<p>Tamaya Core defines the following default ordinals (used, if no custom ordinal is defined):</p> +</div> +<table class="tableblock frame-all grid-all" style="width: 70%;"> +<colgroup> +<col style="width: 75%;"> +<col style="width: 25%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Source</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Ordinal</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">System Properties</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">400</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Environment Variables</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">300</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Java Configuration Properties</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">100</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p>That means that the value of a configuration variable <code>x</code> overhanded via <code>-Dx=yes</code> has +a higher precedence then the entry for configuration variable <code>x</code> specified in a <code>javaconfig.properties</code> +as <code>x=no</code>.</p> +</div> +<div class="paragraph"> +<p>These ordinal values can be either hardcoded, or be dynamically +configurable as key within each configuration resource. The ladder can be done by defining a special +Tamaya ordinal value as follows:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="prettyprint highlight"><code># override default Tamaya ordinal for property files +tamaya.ordinal=123</code></pre> +</div> +</div> +<div class="paragraph"> +<p>This assigns an ordinal of 123 to each entry in that configuration resource.</p> +</div> +</div> +<div class="sect2"> +<h3 id="_using_additional_features_of_tamaya">Using additional features of Tamaya</h3> +<div class="paragraph"> +<p>There many modules that extend the capabilities of +Tamaya. These modules doe not depend on core, so alternative +implementations of the Tamaya API should work similarly. Following a +small extract of most important modules available (or available soon):</p> +</div> +<div class="sect3"> +<h4 id="_dynamic_resolution_and_value_placeholders">Dynamic Resolution and Value Placeholders</h4> +<div class="listingblock"> +<div class="content"> +<pre class="prettyprint highlight"><code class="language-xml" data-lang="xml"><dependency> + <artifactId>org.apache.tamaya.ext</id> + <artifactId>tamaya-resolver</artifactId> + <version>0.3-SNAPSHOT</version> +</dependency></code></pre> +</div> +</div> +<div class="paragraph"> +<p>With that it is possible to define values with Unix styled placeholders that are +resolved on configuration access, e.g. +<code>mykey=my${dynamicValue}´. For further details refer to the module documentation. +This module also provides a `Resolver</code> singleton:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="prettyprint highlight"><code class="language-java" data-lang="java">String myExpression = ...; +String resolved = Resolver.evaluateExpression(myExpression);</code></pre> +</div> +</div> +</div> +<div class="sect3"> +<h4 id="_ant_styled_path_resolution_of_resources">Ant-styled Path Resolution of Resources</h4> +<div class="listingblock"> +<div class="content"> +<pre class="prettyprint highlight"><code class="language-xml" data-lang="xml"><dependency> + <artifactId>org.apache.tamaya.ext</id> + <artifactId>tamaya-resolution</artifactId> + <version>0.3-SNAPSHOT</version> +</dependency></code></pre> +</div> +</div> +<div class="paragraph"> +<p>This module provides a <code>Resolver</code> singleton that allows to +resolve configuration resources using a ant-styled resource +description, e.g.</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="prettyprint highlight"><code class="language-xml" data-lang="xml">Collection<URL> urls = ResourceResolver.getResources("META-INF/cfg/**/*.properties");</code></pre> +</div> +</div> +<div class="paragraph"> +<p>For further details refer to the module documentation.</p> +</div> +</div> +<div class="sect3"> +<h4 id="_configuration_injection">Configuration Injection</h4> +<div class="listingblock"> +<div class="content"> +<pre class="prettyprint highlight"><code class="language-xml" data-lang="xml"><dependency> + <artifactId>org.apache.tamaya.ext</id> + <artifactId>tamaya-inject</artifactId> + <version>{tamaya_version_development}</version> +</dependency></code></pre> +</div> +</div> +<div class="paragraph"> +<p>With this extension you can let Tamaya inject configuration into instances of +annotated classes or let Tamaya implement a configuration template.</p> +</div> +<div class="paragraph"> +<p>Corresponding configuration:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="prettyprint highlight"><code class="language-xml" data-lang="xml">public class MyType { + @ConfiguredProperty("name") + private String typeName; + + public String getName() { + return name; + } +} + +MyType type = new MyType(); +ConfigurationInjector.configure(type);</code></pre> +</div> +</div> +<div class="paragraph"> +<p>Or the same as template:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="prettyprint highlight"><code class="language-xml" data-lang="xml">public interface MyTypeTemplate { + @ConfiguredProperty("name") + public String getName(); +} + +MyTypeTemplate type = ConfigurationInjector.createTemplate(MyTypeTemplate.class);</code></pre> +</div> +</div> +<div class="paragraph"> +<p>Currently the following resolvers are available:</p> +</div> +<table class="tableblock frame-all grid-all" style="width: 60%;"> +<colgroup> +<col style="width: 20%;"> +<col style="width: 80%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Conf</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Cross-reference to another configuration entry</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">URL</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Referencing a resource addressable by an URL.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">File</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reference to a file, replacing the expression with the file’s text value.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Resource</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reference to classpath resource, replacing the expression with the resource’s text value.</p></td> +</tr> +</tbody> +</table> +</div> +</div> +</div> +</div></p> + + <hr /> + </div> + </div> + <div> + <div id="push"></div> + + <div id="footer"> + <div class="container"> + <p class="muted credit">© 2014-2016 Apache Software Foundation | Mixed with <a href="http://getbootstrap.com/">Bootstrap v3.1.1</a> + | Baked with <a href="http://jbake.org">JBake <span>v2.5.0</span></a> + at <span>2016-12-18</span> + </p> + <p> + <b>Disclaimer</b> + Apache Tamaya (incubating) is an effort undergoing + incubation at + The Apache Software Foundation (ASF), sponsored by + the name of Apache Incubator. Incubation is required of + all newly accepted projects until a further review indicates + that the infrastructure, communications, and decision making + process have stabilized in a manner consistent with other + successful ASF projects. While incubation status is not + necessarily a reflection of the completeness or stability of + the code, it does indicate that the project has yet to + be fully endorsed by the ASF.<br /> + <a href="http://incubator.apache.org/guides/website.html" style="border:0px;" target="_target"><img class="incubator-logo" src="../logos/egg-logo2.png"/></a> + </p> + </div> + </div> + + <!-- Le javascript + ================================================== --> + <!-- Placed at the end of the document so the pages load faster --> + <script src="../js/jquery-1.11.1.min.js"></script> + <script src="../js/bootstrap.min.js"></script> + <script src="../js/prettify.js"></script> + + </div> + </body> +</html> http://git-wip-us.apache.org/repos/asf/incubator-tamaya-site/blob/4176b5bc/documentation/usecases.html ---------------------------------------------------------------------- diff --git a/documentation/usecases.html b/documentation/usecases.html new file mode 100644 index 0000000..42e85fa --- /dev/null +++ b/documentation/usecases.html @@ -0,0 +1,1073 @@ +<!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"> + <head> + <meta charset="utf-8"/> + <title>Tamaya Incubator</title> + <meta name="viewport" content="width=device-width, initial-scale=1.0"/> + <meta name="description" content=""/> + <meta name="author" content=""/> + <meta name="keywords" content=""/> + <meta name="generator" content="'JBake '+'${version}"/> + + <!-- Le styles --> + <link href="../css/bootstrap.min.css" rel="stylesheet"/> + <link href="../css/asciidoctor.css" rel="stylesheet"/> + <link href="../css/base.css" rel="stylesheet"/> + <link href="../css/prettify.css" rel="stylesheet"/> + + <!-- HTML5 shim, for IE6-8 support of HTML5 elements --> + <!--[if lt IE 9]> + <script src="../js/html5shiv.min.js"></script> + <![endif]--> + + <!-- Fav and touch icons from ASF --> + <link rel="shortcut icon" href="../favicon.ico"/> + <link rel="apple-touch-icon" sizes="57x57" href="../favicons/apple-touch-icon-57x57.png"/> + <link rel="apple-touch-icon" sizes="60x60" href="../favicons/apple-touch-icon-60x60.png"/> + <link rel="apple-touch-icon" sizes="72x72" href="../favicons/apple-touch-icon-72x72.png"/> + <link rel="apple-touch-icon" sizes="76x76" href="../favicons/apple-touch-icon-76x76.png"/> + <link rel="apple-touch-icon" sizes="114x114" href="../favicons/apple-touch-icon-114x114.png"/> + <link rel="apple-touch-icon" sizes="120x120" href="../favicons/apple-touch-icon-120x120.png"/> + <link rel="apple-touch-icon" sizes="144x144" href="../favicons/apple-touch-icon-144x144.png"/> + <link rel="apple-touch-icon" sizes="152x152" href="../favicons/apple-touch-icon-152x152.png"/> + <link rel="apple-touch-icon" sizes="180x180" href="../favicons/apple-touch-icon-180x180.png"/> + <link rel="icon" type="image/png" href="../favicons/favicon-32x32.png" sizes="32x32"/> + <link rel="icon" type="image/png" href="../favicons/favicon-194x194.png" sizes="194x194"/> + <link rel="icon" type="image/png" href="../favicons/favicon-96x96.png" sizes="96x96"/> + <link rel="icon" type="image/png" href="../favicons/android-chrome-192x192.png" sizes="192x192"/> + <link rel="icon" type="image/png" href="../favicons/favicon-16x16.png" sizes="16x16"/> + <link rel="manifest" href="../favicons/manifest.json"/> + <link rel="shortcut icon" href="../favicons/favicon.ico"/> + <meta name="msapplication-TileColor" content="#603cba"/> + <meta name="msapplication-TileImage" content="../favicons/mstile-144x144.png"/> + <meta name="msapplication-config" content="../favicons/browserconfig.xml"/> + <meta name="theme-color" content="#303284"/> + </head> + <body onload="prettyPrint()"> + <div id="wrap"> + <div> + + <!-- Fixed navbar --> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-collapse"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <a class="navbar-brand" href="../">Apache Tamaya (incubating)</a> + </div> + <div class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li><a href="../index.html">Home</a></li> + <li><a href="../about.html">About</a></li> + <li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown">Documentation <b class="caret"></b></a> + <ul class="dropdown-menu"> + <li><a href="../documentation/usecases.html">Use Cases and Requirements</a></li> + <li><a href="../documentation/quickstart.html">Quickstart</a></li> + <li><a href="../documentation/api.html">API</a></li> + <li><a href="../documentation/core.html">Core</a></li> + <li><a href="../documentation/extensions.html">Extension Guide</a></li> + <li class="divider"></li> + <li><a href="../apidocs/index.html">Javadoc ${tamaya_version} (external)</a></li> + </ul> + </li> + <li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown">Development <b class="caret"></b></a> + <ul class="dropdown-menu"> + <li><a href="../development/source.html">Sources</a></li> + <li><a href="../development/community.html">Community</a></li> + <li><a href="../devguide.html">Development Guide</a></li> + <li><a href="../release-guide.html">Release Guide</a></li> + </ul> + </li> + <li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown">Releases <b class="caret"></b></a> + <ul class="dropdown-menu"> + <li><a href="../download.html">Download</a></li> + <li><a href="../history.html">Release History</a></li> + </ul> + </li> +<!-- Example: + <li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown">Dropdown <b class="caret"></b></a> + <ul class="dropdown-menu"> + <li><a href="#">Action</a></li> + <li><a href="#">Another action</a></li> + <li><a href="#">Something else here</a></li> + <li class="divider"></li> + <li class="dropdown-header">Nav header</li> + <li><a href="#">Separated link</a></li> + <li><a href="#">One more separated link</a></li> + </ul> + </li> +--> + <li><a href="../sitemap.xml">Sitemap</a></li> + <li><a href="../feed.xml">Subscribe</a></li> + </ul> + </div><!--/.nav-collapse --> + </div> + </div> + + </div> + <div class="container"> + + <div class="page-header"> + <h1></h1> + </div> + + <p><em>2016-12-18</em></p> + + <p><div class="sect1"> +<h2 id="_apache_tamaya_use_cases_and_requirements">Apache Tamaya: Use Cases and Requirements</h2> +<div class="sectionbody"> +<!-- toc disabled --> +</div> +</div> +<div class="sect1"> +<h2 id="_use_cases">Use Cases</h2> +<div class="sectionbody"> +<div class="sect2"> +<h3 id="_simple_access">Simple Access</h3> +<div class="paragraph"> +<p>Users want to be able to access configuration in a unified way both in SE and EE. EE may provide additional +mechanism, such as injection, but the SE mechanisms should work as well, so any code written in SE is fully +portable to EE as well. +This can only be achieved by providing a static accessor, e.g.</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="prettyprint highlight"><code class="language-java" data-lang="java">Configuration config = Configuration.current();</code></pre> +</div> +</div> +<div class="paragraph"> +<p>The call above should work exactly the same in EE. To enable this the static call must be delegated in the +internals of the singleton, depending on the runtime. In EE the executing component can behave contextually, +or even be loaded within the CDI environment (at least for post loading, application runtime aspects, but not earlier).</p> +</div> +<div class="paragraph"> +<p>Additionally in EE it should also be possible to inject Configuration, which gives you the same results as the call +above:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="prettyprint highlight"><code class="language-java" data-lang="java">@Inject +private Configuration cfg;</code></pre> +</div> +</div> +</div> +<div class="sect2"> +<h3 id="_simple_lookup_of_properties">Simple Lookup of Properties</h3> +<div class="paragraph"> +<p>Users just want to create a configuration ad hoc, from given property files. The +files could be locally in the file system, on the classpath.</p> +</div> +<div class="paragraph"> +<p>Tamaya should provide a simple Java API for accessing key/value based configuration. Hereby users want to access +properties as simple String values.</p> +</div> +<div class="paragraph"> +<p>Hereby returning Java 8 Optional values must be considered as well, instead of returning null.</p> +</div> +</div> +<div class="sect2"> +<h3 id="_value_placeholders">Value Placeholders</h3> +<div class="paragraph"> +<p>Users just want to to be able to add placeholders to the values of configuration (not the keys). The mechanisms for +resolving the placeholders hereby should be not constraint to one single lanmguage like EL. Instead of different +replacement strategies should be selectable, e.g. by prefixing an expression with the name of the resolver that +should do the work (eg "blabla ${env:HOME} using Java version ${sys:java.version}.". +This allows resolution mechanism to be isolated easily and also allows to use simpler mechanisms, if no more complex +ones like EL are required. This is especially useful to deal with low resource environment like ME.</p> +</div> +</div> +<div class="sect2"> +<h3 id="_type_safe_properties">Type Safe Properties</h3> +<div class="paragraph"> +<p>Users just want to access properties not only as Strings, but let Tamaya do the conversion to the required +or the configred target type. By defauklt all java.ui.lang wrapper and primitive types should be supported, but also +other common types like date/time types, math numeric types and more.</p> +</div> +<div class="paragraph"> +<p>It must be possible that users can register their own custom types.</p> +</div> +<div class="paragraph"> +<p>Finally users also want to be able to dynamically provide or override type adaption (conversion), when reading a value, +for a certain key/value pair.</p> +</div> +</div> +<div class="sect2"> +<h3 id="_configuration_templates">Configuration Templates</h3> +<div class="paragraph"> +<p>Users want to be able to let Tamaya implement an interface template based on configuration. +This use case is pretty similar to the injection use case. Basically the values are not injected, +but cached within the template proxy returned, e.g. as DynamicValue. +Similarly it could even be possible to define callback methods (default methods) +or register listeners to DynamicValue instances returned.</p> +</div> +<div class="paragraph"> +<p>Templates hereby can easily be managed, but provide a excellent mechanism to provide type-safe configuration +to clients in a very transparent way. Details can be controlled by using the same annotations as for +normal configuration injection.</p> +</div> +</div> +<div class="sect2"> +<h3 id="_java_8_functional_support">Java 8 Functional Support</h3> +<div class="paragraph"> +<p>Users want to be able to benefit from the new programming styles introduced with Java 8. Configuration +should provide extension points for different aspects, where additional code can be hooked in easily. +In short: were possible functional interfaces should be modelled.</p> +</div> +<div class="paragraph"> +<p>Examples:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>code that converts a configuration to another kind of configuration: UnaryOperator<Configuration></p> +</li> +<li> +<p>code that creates any kind of result based on a configuration: Function<Configuration,T></p> +</li> +<li> +<p>Adapters for type conversion are defined as Function<String,T></p> +</li> +<li> +<p>Key, value filters ccan be modelled as BiFunction<String,String,String></p> +</li> +<li> +<p>etc.</p> +</li> +</ul> +</div> +</div> +<div class="sect2"> +<h3 id="_configuration_locations">Configuration Locations</h3> +<div class="paragraph"> +<p>Users want to be able to</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>read configuration from different locations.</p> +</li> +<li> +<p>By default classpath and file resources are +supported. But similarly remote access using a JSON ReST call should be possible.</p> +</li> +<li> +<p>Tamaya should define a JSON and XML format for configuration.</p> +</li> +<li> +<p>Configuration locations should be scannable using ant-styled resource patterns, if possible.</p> +</li> +<li> +<p>Scanning and reading logic can be modularized by using a ConfigReader interface.</p> +</li> +</ul> +</div> +</div> +<div class="sect2"> +<h3 id="_configuration_formats">Configuration Formats</h3> +<div class="paragraph"> +<p>Users want to be able to use the format they prefer.</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>properties, xml-properties and ini-format should be supported by default</p> +</li> +<li> +<p>Other/custom formats should be easily addable by registering or providing the format on configuration evaluation (read).</p> +</li> +<li> +<p>When possible Tamaya should figure out which format to be used and how the InputStream should be correctly +interpreted.</p> +</li> +</ul> +</div> +</div> +<div class="sect2"> +<h3 id="_multiple_configurations">Multiple Configurations</h3> +<div class="paragraph"> +<p>When systems grow they must be modularized to keep control. Whereas that sounds not really fancy, it leads to additional +aspects to be considered by a configuration system.</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>Different code modules, libraries, plugins or products want to have their "own" separated configuration.</p> +</li> +<li> +<p>Similar it should be possible to add fully specific additional configurations.</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p>The default configuration hereby should always be present, whereas additional configurations are optional. +Users want to be able to check the availability of such an additional configuration.</p> +</div> +<div class="paragraph"> +<p>Of course, additional configuration must be identifiable. The best way to do is to be discussed, nevertheless the +mechanism must not depend on Java EE and the identifying keys must be serializable easily. +Basically simple names are sufficient and woukld provide exact this required functionality.</p> +</div> +</div> +<div class="sect2"> +<h3 id="_external_configuration">External Configuration</h3> +<div class="paragraph"> +<p>Users want to be able to replace, override, extend or adapt any parts or all of an existing configuration from +external sources. +This also must be the case for multi-context environments, where the context identifiers are +the only way to link to the correct remote configuration.</p> +</div> +</div> +<div class="sect2"> +<h3 id="_context_dependent_configuration">Context Dependent Configuration</h3> +<div class="paragraph"> +<p>In multi tenancy setups or complex systems a hierarchical/graph model of contexts for configurations is required, or different runtime contexts are executed in parallel +within the same VN. What sounds normal for EE also may be the case for pure SE environments:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>Users want to be able to model different layers of runtime context</p> +</li> +<li> +<p>Users want to identify the current layer, so configuration used may be adapted.</p> +</li> +</ul> +</div> +</div> +<div class="sect2"> +<h3 id="_dynamic_provisioning_uc8">Dynamic Provisioning (UC8)</h3> +<div class="paragraph"> +<p>In Cloud Computing, especially the PaaS and SaaS areas a typical use case would be that an application (or server) +is deployed, configured and started dynamically. Typically things are controlled by some "active controller components", +which are capable of</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>creating new nodes (using IaaS services)</p> +</li> +<li> +<p>deploying and starting the required runtime platform , e.g. as part of a PaaS solution.</p> +</li> +<li> +<p>deploying and starting the application modules.</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p>All these steps require some kind of configuration. As of today required files are often created on the target node +before the systems are started, using proprietary formats and mechanism. Similarly accessing the configuration in place +may require examining the file system or using again proprietary management functions. Of course, a configuration +solution should not try to solve that, but it can provide a significant bunch of functionality useful in such scenarios:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>provide remote capabilities for configuration</p> +</li> +<li> +<p>allow configuration to be updated remotely.</p> +</li> +<li> +<p>allow client code to listen for configuration changes and react as needed.</p> +</li> +</ul> +</div> +</div> +<div class="sect2"> +<h3 id="_minimal_property_source_spi">Minimal Property Source SPI</h3> +<div class="paragraph"> +<p>Users expect that implementing an additional configuration property source is as easy as possible. +So there should be an SPI defined that allows any kind of data source to be used for providing configuration data. +The interface to be implemented is expected to be minimal to reduce the implementation burden. Default +methods should be used where possible, so only a few methods are expected to be required to implement.</p> +</div> +</div> +<div class="sect2"> +<h3 id="_scannable_properties">Scannable Properties</h3> +<div class="paragraph"> +<p>If possible configuration should be scannable, meaning it should be possible to evaluate the keys available. +The corresponding capabilities should be accessible by a isScannable() method.</p> +</div> +</div> +<div class="sect2"> +<h3 id="_combine_configurations">Combine Configurations</h3> +<div class="paragraph"> +<p>Users want to be able to combine different configurations to a new configuration instance. +Hereby the resulting configuration can be</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>a union of both, ignoring duplicates (and optionally log them)</p> +</li> +<li> +<p>a union of both, duplicates are ignored</p> +</li> +<li> +<p>a union of both, conflicts are thrown as ConfigException</p> +</li> +<li> +<p>an intersection of both, containing only keys present and equal in both configurations</p> +</li> +<li> +<p>an arbitrary mapping or filter, modelled by an CombinationPolicy, which basically can be modelled +as BiFunction<String, String, String>, hereby</p> +<div class="ulist"> +<ul> +<li> +<p>a result of null will remove the key</p> +</li> +<li> +<p>any other result will use the value returned as final value of the combination.</p> +</li> +</ul> +</div> +</li> +</ul> +</div> +</div> +<div class="sect2"> +<h3 id="_mx_rest_management">MX/ReST Management</h3> +<div class="paragraph"> +<p>Users want to be have comprehensive management support, which should allow</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>to change configuration</p> +</li> +<li> +<p>to remove configuration</p> +</li> +<li> +<p>to view configuration and its provider details</p> +</li> +</ul> +</div> +</div> +<div class="sect2"> +<h3 id="_adaptable_service_context">Adaptable Service Context</h3> +<div class="paragraph"> +<p>Tamaya should support an adaptable ServiceContext to resolve any kind of implememntation services, both API services as core +framework services. The ServiceContext should be dynamically replecable by configuring an alternate instance of +using the Java *ServiceContet+.</p> +</div> +<div class="paragraph"> +<p>This decouples component usage from its load and management part and als greatly simplifies integration with +new/alternate runtime environments. +The service context is exptected to provide</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>single singleton instances: these service can be cached.</p> +</li> +<li> +<p>access to multiple instances which implement some commons SPI interface.</p> +</li> +<li> +<p>as useful priorization of components is done by the model itself.</p> +</li> +</ul> +</div> +</div> +<div class="sect2"> +<h3 id="_configuration_injection">Configuration Injection</h3> +<div class="paragraph"> +<p>Users want to be able to polulate configured items by injecting configured values. Hereby</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>the lifecycle of the instances is not managed by Tamaya</p> +</li> +<li> +<p>all references to items configured are managed as weak references, to prevent memoryleaks.</p> +</li> +<li> +<p>Injection should if possible evaluate the properties by defaults. Even properties without +any annotations are possible.</p> +</li> +<li> +<p>Users expect to exclude certain properties from calculation</p> +</li> +<li> +<p>Beside injection of properties it is also possible to call setter methods with one parameter similarly.</p> +</li> +<li> +<p>Basically injection is performed, when the instance is passed to the Tamaya configuration system. It should also +be possible to inject/provide final values, especially Strings. Changes on configured values should be +reflected in the current value. Setters methods similarly can be called again, with the new values, on changes.</p> +</li> +<li> +<p>Users expect to control dynamic values and recall of setter methods, basically the following strategies should be +supported:</p> +<div class="ulist"> +<ul> +<li> +<p>inject only once and ignore further changes.</p> +</li> +<li> +<p>reinject/reinitialize on each change</p> +</li> +</ul> +</div> +</li> +<li> +<p>Dynamic Values can easily be modeled as ConfiguredValue instances, which should have the following functionality:</p> +<div class="ulist"> +<ul> +<li> +<p>access the current value</p> +</li> +<li> +<p>access the new value</p> +</li> +<li> +<p>access the latest value access time in ms</p> +</li> +<li> +<p>access the latest value update time in ms</p> +</li> +<li> +<p>evaluate easily if the value has changed since the last access</p> +</li> +<li> +<p>accept the change</p> +<div class="ulist"> +<ul> +<li> +<p>as a shortcut it should be possible to accept the change on access of the value implicitly, hereby always accessing +the latest valid value.</p> +</li> +</ul> +</div> +</li> +<li> +<p>ignore the change</p> +</li> +<li> +<p>register Consumer<DynamicValue> liasteners to listen on the changes (ans also removing them later again).</p> +</li> +</ul> +</div> +</li> +</ul> +</div> +<div class="paragraph"> +<p>All observing functionality can be done completely asynchronously and in parallel.</p> +</div> +</div> +</div> +</div> +<div class="sect1"> +<h2 id="Requirements">Requirements</h2> +<div class="sectionbody"> +<div class="sect2"> +<h3 id="_core_configuration_requirements">Core Configuration Requirements</h3> +<div class="sect3"> +<h4 id="_general">General</h4> +<div class="paragraph"> +<p>Tamaya must provide a Java SE API for accessing key/value based configuration. Hereby</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>Configuration is modelled by an interface</p> +</li> +<li> +<p>Configuration is organized as key/value pairs, using a subset of functionality present on Map<String,String> as +follows:</p> +<div class="ulist"> +<ul> +<li> +<p>access a value by key (get)</p> +</li> +<li> +<p>check if a value is present (containsKey)</p> +</li> +<li> +<p>get a set of all defined keys (keySet)</p> +</li> +<li> +<p>a configuration must be convertible to a Map, by calling toMap()</p> +</li> +<li> +<p>a configuration must provide access to its meta information.</p> +</li> +</ul> +</div> +</li> +<li> +<p>Configuration value access methods must never return null.</p> +</li> +<li> +<p>The API must support undefined values.</p> +</li> +<li> +<p>The API must support passing default values, to be returned if a value is undefined.</p> +</li> +<li> +<p>The API must allow to throw exceptions, when a value is undefined. Customized exceptions hereby should be supported.</p> +</li> +<li> +<p>Properties can be stored in the classpath, on a file or accessible by URL.</p> +</li> +<li> +<p>Properties can be stored minimally in properties, xml-properties or ini-format.</p> +</li> +</ul> +</div> +</div> +<div class="sect3"> +<h4 id="_minimalistic_property_source">Minimalistic Property Source</h4> +<div class="paragraph"> +<p>For enabling easy integration of custom built configuration sources a minimalistic API/SPI must be defined, that</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>is modelled by an interface</p> +</li> +<li> +<p>is a minimal subset of Configuration necessary to implement a configuration.</p> +</li> +<li> +<p>must be convertible to a "Configuration+.</p> +</li> +</ul> +</div> +</div> +<div class="sect3"> +<h4 id="_extension_points">Extension Points</h4> +<div class="paragraph"> +<p>For supporting more complex scenarios, Configuration</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>must implement the composite pattern, meaning new Configuration instances can be created by combining existing +configurations.</p> +</li> +<li> +<p>must be adaptable, by creating a new configuration by applying a UnaryOperator<COnfiguration> to it.</p> +</li> +<li> +<p>must be queryable, by passing a ConfigQuery to an Configuration instance.</p> +</li> +</ul> +</div> +</div> +<div class="sect3"> +<h4 id="_type_safety">Type Safety</h4> +<div class="paragraph"> +<p>Besides Strings Configuration should also support the following types:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>Primitive types</p> +</li> +<li> +<p>Wrapper types</p> +</li> +<li> +<p>All other types (by using a PropertyAdapter</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p>Hereby type conversion should be done as follows:</p> +</div> +<div class="olist arabic"> +<ol class="arabic"> +<li> +<p>Check if for the given target type an explicit adapter is registered, if so, use the registered adapter.</p> +</li> +<li> +<p>If no adapter is present, check if the target type T has static methods called T of(String), T getInstance(String), T valueOf(String), T from(String). If so +use this method to create the non value of T.</p> +</li> +<li> +<p>Check if the target type has a constructor T(String). If so, try to instantiate an instance using the constructor.</p> +</li> +<li> +<p>Give up, throw a IllegalArgument exception.</p> +</li> +</ol> +</div> +</div> +</div> +<div class="sect2"> +<h3 id="_configuration_fomats">Configuration Fomats</h3> +<div class="paragraph"> +<p>By default Tamaya support the following configuration formats:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>.properties</p> +</li> +<li> +<p>.xml properties</p> +</li> +<li> +<p>.ini files</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p>It must be possible to add additional formats by registering them with the current ServiceContext.</p> +</div> +</div> +<div class="sect2"> +<h3 id="_mutability">Mutability</h3> +<div class="ulist"> +<ul> +<li> +<p>Configurations can be mutable, mutability can be accessed as a property.</p> +</li> +<li> +<p>Configuration can be changed by collecting the changes into a ConfigCHangeSet and apply this set to the +given Configuration instance.</p> +</li> +<li> +<p>Besides the points above, Configuration is immutable.</p> +</li> +</ul> +</div> +</div> +<div class="sect2"> +<h3 id="_serializability_and_immutability_of_configuration">Serializability and Immutability of Configuration</h3> +<div class="ulist"> +<ul> +<li> +<p>Configuration is modelled as a service. Therefore serialization may not work. This can be mitigated by adding +a freeze feature, where the know key/value pairs are extracted into an immutable and serializable form.</p> +</li> +</ul> +</div> +</div> +<div class="sect2"> +<h3 id="_configuration_combination_requirements">Configuration Combination Requirements</h3> +<div class="paragraph"> +<p>At least the following composition policies must be supported:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>override: subsequent entries override existing ones.</p> +</li> +<li> +<p>aggregate-exception: key/values were added, in case of conflicts a ConfigException must be thrown.</p> +</li> +<li> +<p>aggregate-ignore-duplicates: similar to union, whereas duplicates are ignored (leaving the initial value loaded).</p> +</li> +<li> +<p>aggregate-combine: conflicting entries were resolved by adding them both to the target configuration by +redefining partial keys.</p> +</li> +<li> +<p>custom: any function determining the key/values to be kept must be possible</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p>When combining configuration it must also be possible to override (file/classpath) configuration by</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>system properties.</p> +</li> +<li> +<p>command line arguments.</p> +</li> +</ul> +</div> +</div> +<div class="sect2"> +<h3 id="_configuration_injection_2">Configuration Injection</h3> +<div class="paragraph"> +<p>As metnioned configuration can be injected by passing a unconfigured instance of an annotated class to the +Configuration.configure static method:</p> +</div> +<div class="listingblock"> +<div class="title">Configuring a POJO</div> +<div class="content"> +<pre class="prettyprint highlight"><code class="language-java" data-lang="java">MyPojo instance = new MyPojo(); +Configuration.configure(instance);</code></pre> +</div> +</div> +<div class="paragraph"> +<p>Hereby +* It must be possible to define default values to be used, if no valid value is present. +* It must be possible to define dynamic expressions, at least for default values. +* The values configured can be reinjected, if the underlying configuration changes. This should also be the case + for final classes, such as Strings. +* Reinjection should be controllable by an loading policy. +* It must be possible to evaluate multiple keys, e.g. current keys, and as a backup deprecated keys + from former application releases. +* It must be possible to evaluate multiple configurations. +* The type conversion of the properties injected must be configurable, by defining a PropertyAdapter. +* The value evaluated for a property (before type conversion) must be adaptable as well. +* It must be possible to observe configuration changes.</p> +</div> +<div class="paragraph"> +<p>The following annotations must be present at least:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><strong>@ConfiguredProperty</strong> defining the key of the property to be evaluated. It takes an optional value, defining the +property name. It must be possible to add multiple annotations of this kind to define an order of evaluation +of possible keys.</p> +</li> +<li> +<p><strong>@DefaultValue</strong> (optional) defines a default String value, to be used, when no other key is present.</p> +</li> +<li> +<p><strong>@WithConfig</strong> (optional) defines the name of the configuration to be used. Similar to @ConfiguredProperty multiple +configuration can be defined for lookup.</p> +</li> +<li> +<p><strong>@WithConfigOperator</strong> allows to adapt the String value evaluated, <strong>before</strong> it is passed as input to injection or +type conversion.</p> +</li> +<li> +<p><strong>@WithPropertyAdapter</strong> allows to adapt the conversion to the required target type, hereby overriding any default +conversion in place.</p> +</li> +<li> +<p><strong>@WithLoadPolicy</strong> allows to define the policy for (re)injection of configured values.</p> +</li> +<li> +<p><strong>@ObservesConfigChange</strong> allows to annotate methods that should be called on configuration changes.</p> +</li> +<li> +<p>*@DefaultAreas" allows to define a key prefix key to be used for the configured key, if no absolute key +is defined.</p> +</li> +</ul> +</div> +</div> +<div class="sect2"> +<h3 id="_configuration_templates_2">Configuration Templates</h3> +<div class="paragraph"> +<p>For type safe configuration clients should be able to define an interface and let it implement by the +configuration system based on Configuration available:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>Clients define an interface and annotate it as required (similar to above)</p> +</li> +<li> +<p>The interface methods must not take any arguments</p> +</li> +<li> +<p>The configuration system can be called to return such an interface implementation.</p> +</li> +<li> +<p>The configuration system returns a proxy hereby providing type-safe access the values required.</p> +</li> +<li> +<p>Similar to configured types also templates support multiple values and custom adapters.</p> +</li> +<li> +<p>It is possible to listen on configuration changes for templates, so users of the templates +may react on configuration changes.</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p>The following snippet illustrates the requirements:</p> +</div> +<div class="listingblock"> +<div class="title">Type Safe Configuration Template Example</div> +<div class="content"> +<pre class="prettyprint highlight"><code class="language-java" data-lang="java">public interface MyConfig { + + @ConfiguredProperty("myCurrency") + @DefaultValue("CHF") + String getCurrency(); + + @ConfiguredProperty("myCurrencyRate") + Long getCurrencyRate(); + + @ConfigChange + default configChanged(ConfigChange event){ + ... + } + +}</code></pre> +</div> +</div> +<div class="paragraph"> +<p>Templates can be accessed by calling the Configuration.current(Class) method:</p> +</div> +<div class="listingblock"> +<div class="title">Accessing a type safe Configuration Template</div> +<div class="content"> +<pre class="prettyprint highlight"><code class="language-java" data-lang="java">MyConfig config = Configuration.current(MyConfig.class);</code></pre> +</div> +</div> +</div> +<div class="sect2"> +<h3 id="RequirementsServer">Server Configuration Requirements</h3> +<div class="ulist"> +<ul> +<li> +<p>Ensure Configuration can be transferred over the network easily.</p> +</li> +<li> +<p>Beside serializability text based formats for serialization in XML and JSON must be defined.</p> +</li> +<li> +<p>A management API must be defined, which allows to inspect the configuration in place, e.g. using +JMX or REST services.</p> +</li> +</ul> +</div> +<div id="RequirementsJavaEE" class="paragraph"> +<p>Java EE leads to the following requirements:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>Configuration must be contextual, depending on the current runtime context (e.g. boot level, ear, war, …​).</p> +</li> +<li> +<p>Hereby contextual aspects can even exceed the levels described above, e.g. for SaaS scenarios.</p> +</li> +<li> +<p>Resources can be unloaded, e.g. wars, ears can be restarted.</p> +</li> +<li> +<p>The different contextual levels can also be used for overriding, e.g. application specific configuration +may override ear or system configuration.</p> +</li> +<li> +<p>Configuration may be read from different sources (different classloaders, files, databases, remote locations).</p> +</li> +<li> +<p>Configuration may be read in different formats (deployment descriptors, ServiceLoader configuration, alt-DD feature, …​)</p> +</li> +<li> +<p>JSF also knows the concept of stages.</p> +</li> +<li> +<p>Many SPI’s of Java EE require the implementation of some well defined Java interface, so it would be useful if the +configuration solution supports easy implementation of such instances.</p> +</li> +<li> +<p>In general it would be useful to model the Environment explicitly.</p> +</li> +<li> +<p>Configuration used as preferences is writable as well. This requires mutability to be modelled in way, without the +need of synchronization.</p> +</li> +<li> +<p>JNDI can be used for configuration as well.</p> +</li> +</ul> +</div> +<div id="RequirementsMultitenancy" class="paragraph"> +<p>Configurations made in the tenant or user layer override the default app configuration etc., so</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>It must be possible to structure Configuration in layers that can override/extend each other.</p> +</li> +<li> +<p>The current environment must be capable of mapping tenant, user and other aspects, so a corresponding configuration +(or layer) can be derived.</p> +</li> +</ul> +</div> +</div> +<div class="sect2"> +<h3 id="RequirementsExtensions">Extensions Requirements</h3> +<div class="paragraph"> +<p>It must be possible to easily add additional functionality by implementing external functional interfaces operating +on Configuration.</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>UnaryOperator<Configuration> for converting into other version of Configuration.</p> +</li> +<li> +<p>ConfigQuery<T> extending Function<T, Configuration>.</p> +</li> +</ul> +</div> +</div> +<div class="sect2"> +<h3 id="RequirementsNonFunctional">Non Functional Requirements</h3> +<div class="paragraph"> +<p>THe following non-functional requirements must be met:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>tbd</p> +</li> +</ul> +</div> +</div> +</div> +</div></p> + + <hr /> + </div> + </div> + <div> + <div id="push"></div> + + <div id="footer"> + <div class="container"> + <p class="muted credit">© 2014-2016 Apache Software Foundation | Mixed with <a href="http://getbootstrap.com/">Bootstrap v3.1.1</a> + | Baked with <a href="http://jbake.org">JBake <span>v2.5.0</span></a> + at <span>2016-12-18</span> + </p> + <p> + <b>Disclaimer</b> + Apache Tamaya (incubating) is an effort undergoing + incubation at + The Apache Software Foundation (ASF), sponsored by + the name of Apache Incubator. Incubation is required of + all newly accepted projects until a further review indicates + that the infrastructure, communications, and decision making + process have stabilized in a manner consistent with other + successful ASF projects. While incubation status is not + necessarily a reflection of the completeness or stability of + the code, it does indicate that the project has yet to + be fully endorsed by the ASF.<br /> + <a href="http://incubator.apache.org/guides/website.html" style="border:0px;" target="_target"><img class="incubator-logo" src="../logos/egg-logo2.png"/></a> + </p> + </div> + </div> + + <!-- Le javascript + ================================================== --> + <!-- Placed at the end of the document so the pages load faster --> + <script src="../js/jquery-1.11.1.min.js"></script> + <script src="../js/bootstrap.min.js"></script> + <script src="../js/prettify.js"></script> + + </div> + </body> +</html>