blob: 40e466bf2518ccbec7ac60db036fb88c978bd851 [file] [log] [blame]
/*
* Copyright (c) 2008, Rickard Öberg. All Rights Reserved.
*
* 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.
*
*/
package org.apache.zest.entitystore.prefs;
import org.apache.zest.api.concern.Concerns;
import org.apache.zest.api.mixin.Mixins;
import org.apache.zest.api.service.ServiceActivation;
import org.apache.zest.api.service.ServiceComposite;
import org.apache.zest.spi.entitystore.ConcurrentModificationCheckConcern;
import org.apache.zest.spi.entitystore.EntityStateVersions;
import org.apache.zest.spi.entitystore.EntityStore;
/**
* EntityStore backed by Preferences API.
* <p>
* A root node is created in the System preferences, whose name
* is the same as the Application name (default:"Application").
* </p>
* <p>
* Each entity is stored under its identity name.
* </p>
* <p>
* Property types are converted to native Preferences API types
* as much as possible. All others will be serialized to a string using JSON.
* </p>
* <p>
* Associations are stored as the identity of the referenced Entity, ManyAssociations are stored as multi-line strings
* (one identity per line), and NamedAssociations are stored as multi-line strings (one name on a line, identity on the
* next line).
* </p>
* <p>
* The main use of the EntityStore is for storage of ConfigurationComposites for ServiceComposites.
* </p>
* @see org.apache.zest.api.service.ServiceComposite
* @see org.apache.zest.api.configuration.Configuration
*/
@Concerns( ConcurrentModificationCheckConcern.class )
@Mixins( PreferencesEntityStoreMixin.class )
public interface PreferencesEntityStoreService
extends EntityStore, ServiceComposite, EntityStateVersions, ServiceActivation
{
}