Licensed to the Apache Software Foundation (ASF) under one
or more contributor license agreements.  See the NOTICE file
distributed with this work for additional information
regarding copyright ownership.  The ASF licenses this file
to you 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.

1. Introduction

2. What is Tamaya

Tamaya is the Apache standard for flexible and powerful configuration. Objective is to provide flavors for Java SE, ME as well as to ship with powerful features for Java EE and Cloud Solutions. All functions provided is build on top of a small but very powerful, flexible and extendible API. This API is implemented by a core implementation, which then can be extended or adapted for use in different runtime scenarios, such as SE, ME, EE, Spring, OSGI and more. Similarly additional modules may be provided that help also existing solution to be plugged into Tamaya, so you can start right away using Tamaya without having to rebuild/change your existing application.

2.1. Purpose of this Document

The document should help to organize people and ideas around the Apache Tamaya Library. It list possible features, ideas and tasks that need to be done. Everybody can have a look at and see, where hos contribution and capabilities would fit best.

3. Main Features

3.1. Metadata Model

Currently MetaInfo models metadata as a separate constuct. It has been shown that this leads to more complex handling when creating composites and makes the API overall more complex. The idea is to model metadata as simple key/value pairs, that are part of the provider/configuration data as well, but handled separately. Metadata hereby is identified by a starting _ character in its key. For example refer to the following configuration properties:

Basic Properties
a.b.Foo=foo
a.b.Bar=bar
a.AnyOther=whatelse
Something=none

Now we can model meta-data as follows:

Metadata Properties
[a.b].info=An area info
[a.b.Foo].auth=role1,role2
[a.b.Foo].encrypt=PGP
[a.b.Foo].sensitive=true
[].info=This is a test configuration example.

The above would model the following:

  • The area a.b has the meta property info.

  • The entry a.b.Foo has three meta properties auth,encrypt and sensitive. These could be interpreted by a security view and used to encrypt the values returned by the configuration instance, if not the current user has one of the specified roles.

  • The last meta data defines an attribute info for the whole provider/configuration (the root area).

Given that the overall entries would be as follows:

Full Properties with Meta Properties
[a.b].info=An area info
a.b.Foo=foo
[a.b.Foo].auth=role1,role2
[a.b.Foo].encrypt=PGP
[a.b.Foo].sensitive=true
a.b.Bar=bar
[].info=This is a test configuration example.
a.AnyOther=whatelse
Something=none

The current MetaInfo class could be adapted, so it is reading data from the underlying configuration/provider, instead of its own datastructure. This would make a later mapping of configuration and its metadata into DB table, JSON etc, much more easier. The providers on the other side may suppress any metadata from ordinary output, such as toString(), Similarly accessing metadata using the official config API (get, getOrDefault, getAreas etc) should be disabled. The MetaInfoBuilder must probably as well adapted or redesigned.

3.2. Collection Support

Add a key/value based model for mapping collections such as sets, maps, list. Implement according adapters. In combination with the metadata model above this could be something like:

Collection Support
mySet=[a,b,c,d,e\,e,f]
[mySet].type=set
#optional define the implementation class
[mySet].class=java.util.TreeSet

myList=[a,b,c,d,e\,e,f]
[myList].type=list
#optional define the implementation class
[myList].class=java.util.ArrayList

myMap=[a:aa,b:bb,c:cc,d:dd,e:e\,e,f:ff]
[myMap].type=map
#optional define the implementation class
[myMap].class=java.util.TreeMap

#Finally we could also add support for non String based types
myTypedSet=[1,2,3,4.5,6,7.10.123]
[myTypedSet].contentClass=java.lang.Double
myTypedList=[CHF 10.20, EUR 12.20, BTC 0.002]
[myTypedList].contentType=org.javamoney.moneta.FastMoney
myTypedMap=[CHF:CHF 10.20, EUR:EUR 12.20, BTC:BTC 0.002]
[myTypedMap].contentTypes=javax.money.CurrencyUnit,javax.money.MonetaryAmount

3.3. Management Client

A nice web-based client to manage configuration data would be nice as well. This also includes a UI for creating new configurations.

3.4. Mapping Configuration to a Database

A flexible mechanism should be implemented that allows the use of databases (SQL/JPA as well as non-SQL) for storing/retreiving/managing configuration:

  • JPA, Hibernate

  • MongoDB

  • …​

3.5. Integration with OSGI

Examples are to be created and tested, where OSGI is used as the basic runtime platform, e.g. Apache Felix, but as well others.

3.6. Integration with Jigsaw

Once Jigsaw is mature and in a usable (still early) stage, examples are to be created and tested, where OSGI is used as the basic runtime platform, e.g. Apache Felix, but as well others.

4. Distributed/Remote Configuration Support

4.1. Configuration Server

A configuration server should be implemented that provides access to configurations and triggers updates to registered clients (push). Similarly a poull model should be supported, where clients can asl for the current version id of a certain configuration and reload it if necessary.

4.2. Configuration Distribution Policies

Different configuration distribution policies should be defined any implemented, e.g. distributed cache, restful services, web services, EJB/RMI calls, asynchronous queues, publish/subsribe models, …​

4.3. Configuration Client

A subset of the API would be created that exposes only a well defined subset, of exactly one configuration targeted to a certain instance, VM or whatever. The client should be connectable to a server in different ways (see configuration distributiont policies).

4.4. Preferences Support

Write a PreferencesFactory for java.util.preferences.

5. Third Party Integration

5.1. Integration with Deltaspike Config

Integration with Deltaspike Config should be implemented and discussed with Deltaspike guys.

5.2. Integration with Spring

A Tamaya module should be created that allows Spring to be used either as client or configuration provider.

5.3. Integration with Jetty

A Tamaya module should be created that allows a Jetty instance to be deployed and started that is (completely) configured based on configuration server.

5.4. Integration with Tomcat

A Tamaya module should be created that allows a Tomcat instance to be deployed and started that is (completely) configured based on configuration server.

5.5. Configuration of Java EE

In the Java EE area there would be several options:

5.6. Configuration of Application Servers (administrative resources)

It should be possible to start a application server instance remotely and configure all administrative resources and the deployments based on the configuration service, server to be considered maybe

  • Wildfly

  • IBM

  • Weblogic

  • Glassfish

  • Apache Geronimo

5.6.1. Configuration of Bean Validation

  • Add configurable validators.

  • Configure bean validation based on configuration

  • …​

5.7. JNDI Support

Write a JCA adapter to provide configuration data through JNDI.

5.7.1. Configure JSF

Use the JSF XML Document event to completely configure JSF.

5.7.2. Configure Web Services

Provide a WebServiceProviderFactory that may be configured.

5.7.3. Configure JPA

Provide an implementation that allows configuration of persistence units. Talk with JPA EG people to see if we can get an SPI to hook in a stadardized way.

5.7.4. Configure EJBs

Provide an implementation that allows configuration of EJBs and MDBs:

  • Register beans

  • Unregister/disable beans

  • Intercept beans

  • Support Configuration Injection (in the worst case using a standard Interceptor, provide supporting artifacts to help developers to achive this easily).

  • Talk with EE8 Umbrella EG (Bill Shanon, Linda DeMichels) on a feasible SPI for EE8, if possible join the EG.

5.7.5. Configure …​

Just think of any Java EE aspects that might be worth to be configured. If it can be done, e.g. by managing CDI managed resources, it might be easy. For others it is a good idea to discuss things with our matter of experts…​

6. Special Goodies

6.1. Maintenance Mode Servlet Filter

Provide a servlet filter that is capable of switching to maintenance mode, based on configuration. Similarly also a forwarding servlet could be useful, wehere only request based on configuration are forwarded, other might be rejected or dropped as configured.

6.2. Dynamic Camel Routes

Provides dynamic (configurable) Camel routes, e.g. usable within ServiceMix or standalone.

6.3. Dynamic CXF

Provides dynamic (configurable) CXF adapters, e.g. usable within ServiceMix or standalone.

6.4. Configurable Apache MQ

Provides an implementation for configuring Apache MQ.

6.5. Dynamic …​

Interested to see what other ideas are around. Let us know!