Package org.apache.juneau.config.store
Class FileStore
java.lang.Object
org.apache.juneau.Context
org.apache.juneau.config.store.ConfigStore
org.apache.juneau.config.store.FileStore
- All Implemented Interfaces:
Closeable,AutoCloseable
Filesystem-based storage location for configuration files.
Points to a file system directory containing configuration files.
Notes:
- This class is thread safe and reusable.
-
Nested Class Summary
Nested Classes -
Field Summary
FieldsModifier and TypeFieldDescriptionprotected final Charsetstatic final FileStoreDefault file store, all default values.protected final Stringprotected final booleanprotected final Stringprotected final booleanprotected final WatcherSensitivityFields inherited from class org.apache.juneau.Context
CONTEXT_APPLY_FILTER -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidclose()copy()Creates a builder from this context object.static FileStore.Buildercreate()Creates a new builder for this object.booleanChecks whether the configuration with the specified name exists in this store.protected voidGets called when the watcher service on this store is triggered with a file system change.Returns the properties on this bean as a map for debugging.Returns the contents of the configuration file.protected StringresolveName(String name) Subclasses can override this method to convert config names to internal forms.Called when the physical contents of a config file have changed.Saves the contents of the configuration file if the underlying storage hasn't been modified.Methods inherited from class org.apache.juneau.config.store.ConfigStore
getMap, register, unregister, updateMethods inherited from class org.apache.juneau.Context
createBuilder, createSession, getAnnotationProvider, getSession, init, isDebug, toString
-
Field Details
-
DEFAULT
Default file store, all default values. -
enableWatcher
-
updateOnWrite
-
charset
-
directory
-
extensions
-
watcherSensitivity
-
-
Constructor Details
-
FileStore
Constructor.- Parameters:
builder- The builder for this object.
-
-
Method Details
-
create
Creates a new builder for this object.- Returns:
- A new builder.
-
close
-
copy
Description copied from class:ContextCreates a builder from this context object.Builders are used to define new contexts (e.g. serializers, parsers) based on existing configurations.
-
exists
Description copied from class:ConfigStoreChecks whether the configuration with the specified name exists in this store.- Specified by:
existsin classConfigStore- Parameters:
name- The config name.- Returns:
true if the configuration with the specified name exists in this store.
-
read
Description copied from class:ConfigStoreReturns the contents of the configuration file.- Specified by:
readin classConfigStore- Parameters:
name- The config file name.- Returns:
- The contents of the configuration file.
A blank string if the config does not exist.
Nevernull . - Throws:
IOException- Thrown by underlying stream.
-
update
Description copied from class:ConfigStoreCalled when the physical contents of a config file have changed.Triggers calls to
ConfigStoreListener.onChange(String)on all registered listeners.- Overrides:
updatein classConfigStore- Parameters:
name- The config name (e.g. the filename without the extension).newContents- The new contents.- Returns:
- This object.
-
write
Description copied from class:ConfigStoreSaves the contents of the configuration file if the underlying storage hasn't been modified.- Specified by:
writein classConfigStore- Parameters:
name- The config file name.expectedContents- The expected contents of the file.newContents- The new contents.- Returns:
- If
null , then we successfully stored the contents of the file.
Otherwise the contents of the file have changed and we return the new contents of the file. - Throws:
IOException- Thrown by underlying stream.
-
onFileEvent
Gets called when the watcher service on this store is triggered with a file system change.- Parameters:
e- The file system event.- Throws:
IOException- Thrown by underlying stream.
-
properties
Description copied from class:ContextReturns the properties on this bean as a map for debugging.- Overrides:
propertiesin classConfigStore- Returns:
- The properties on this bean as a map for debugging.
-
resolveName
Description copied from class:ConfigStoreSubclasses can override this method to convert config names to internal forms.For example, the
FileStoreclass can take in both"MyConfig" and"MyConfig.cfg" as names that both resolve to"MyConfig.cfg" .- Overrides:
resolveNamein classConfigStore- Parameters:
name- The name to resolve.- Returns:
- The resolved name.
-