Package com.illumon.iris.db.schema
Class StaticSchemaServiceImpl
java.lang.Object
com.illumon.iris.db.schema.StaticSchemaServiceImpl
- All Implemented Interfaces:
SchemaService,NamedImplementation,AutoCloseable
- Direct Known Subclasses:
SchemaServiceLegacyTransientImpl
Implement the SchemaService interface based on an immutable map of schemas. Derived classes are expected to handle
initialization of the map.
-
Nested Class Summary
Nested classes/interfaces inherited from interface com.illumon.iris.db.schema.SchemaService
SchemaService.Delegating -
Field Summary
FieldsModifier and TypeFieldDescriptionprotected final com.fishlib.configuration.Configurationprotected final com.fishlib.io.logger.Logger -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionAdd the specified schema to the service.Add the specified schema to the service.addSchema(TableDefinitionSchema newSchema) Add the specified schema to the service.addSchema(TableDefinitionSchema newSchema, String code, String comment) Add the specified schema to the service.booleanAuthenticate using default authentication.booleanauthenticate(String user, String password, String operateAs) Authenticate using the given user and password, operating as the operateAs user.booleancontainsNamespace(String namespace, boolean includeDeleted) Find out whether the given namespace is known to the schema service.booleancontainsSchema(String namespace, String tableName) Find out if the given schema exists.booleancreateNamespace(NamespaceSet namespaceSet, String namespaceName) Add a namespace with the given name to the schema service, in the requested namespace set.booleancreateNamespace(NamespaceSet namespaceSet, String namespaceName, String code, String comment) Add a namespace with the given name to the schema service, in the requested namespace set.voiddeleteSchema(String namespace, String tableName) Delete the specified schema.voiddeleteSchema(String namespace, String tableName, String code, String comment) Delete the specified schema.Get a collection of all known schemas in the system.getLatestSchema(String namespace, String tableName) Get the latest version of theSchemadefined by namespace and table namegetLatestSchemaXml(String namespace, String tableName) getLatestTableDefinitionSchema(String namespace, String tableName) Get the latest version of theTableDefinitionSchemadefined by namespace and table namegetNamespaceSet(String namespace) Get theNamespaceSetfor a particular namespace.getSchema(String namespace, String tableName, SchemaVersion version) Get the specified version of theSchemadefined by namespace and table namegetSchemas(NamespaceSet namespaceSet) Get a collection of all known schemas in the system, with the given namespace set.getSchemas(String namespace) Get a collection of all known schemas in the given namespace.Get a map of all known tables in all known namespaces for all namespace sets.listNamespaces(boolean includeDeleted) Get a collection of the namespaces available.listNamespaces(NamespaceSet namespaceSet, boolean includeDeleted) Get a collection of the namespaces available in the given namespace set.listTableNames(String namespace, boolean includeDeleted) Get a collection of all table names in the specified namespace.voidremoveNamespace(String namespaceName) Remove the given namespace.voidremoveNamespace(String namespaceName, String code, String comment) Remove the given namespace.updateSchema(Schema newSchema) Update the schema with the same namespace and table name with the specified new schema.updateSchema(Schema newSchema, String code, String comment) Update the schema with the same namespace and table name with the specified new schema.updateSchema(TableDefinitionSchema newSchema) Update the schema with the same namespace and table name with the specified new schema.updateSchema(TableDefinitionSchema newSchema, String code, String comment) Update the schema with the same namespace and table name with the specified new schema.Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface com.illumon.util.type.NamedImplementation
getImplementationNameMethods inherited from interface com.illumon.iris.db.schema.SchemaService
about, asElement, asSchemaXml, authenticate, close, containsNamespace, createNamespace, deleteSchema, deleteSchema, fromDefinition, fromDefinition, fromDefinition, fromDefinition, fromDefinition, fromElement, getLatestTableDefinition, getLatestTableDefinitionRequired, getSchema, getSchemasForNamespaceSet, initializationStage, listNamespaces, listNamespaces, listNamespaces, listTableNames, shutdown
-
Field Details
-
log
protected final com.fishlib.io.logger.Logger log -
configuration
protected final com.fishlib.configuration.Configuration configuration
-
-
Constructor Details
-
StaticSchemaServiceImpl
-
-
Method Details
-
authenticate
public boolean authenticate(@NotNull String user, @NotNull String password, @NotNull String operateAs) Description copied from interface:SchemaServiceAuthenticate using the given user and password, operating as the operateAs user. Implementations are not required to allow re-authentication.- Specified by:
authenticatein interfaceSchemaService- Parameters:
user- the user to authenticatepassword- the password for the useroperateAs- attempt to operate as this effective user- Returns:
- true only if the authentication succeeded
-
authenticate
public boolean authenticate()Description copied from interface:SchemaServiceAuthenticate using default authentication. This will be using the default private key or howeverAuthenticationClientManager.getDefault()has been authenticated.- Specified by:
authenticatein interfaceSchemaService- Returns:
- true only if the authentication succeeded
-
getLatestSchema
Description copied from interface:SchemaServiceGet the latest version of theSchemadefined by namespace and table name- Specified by:
getLatestSchemain interfaceSchemaService- Parameters:
namespace- the namespace of the tabletableName- the table name- Returns:
- the latest version of namespace.tablename or null if none was found
-
getLatestSchemaXml
Description copied from interface:SchemaServiceGet the latest version of theSchemadefined by namespace and table name, as an implementation supportingSchemaXml.- Specified by:
getLatestSchemaXmlin interfaceSchemaService- Parameters:
namespace- the namespace of the tabletableName- the table name- Returns:
- the latest version of namespace.tablename or null if none was found
-
getSchema
@Nullable public Schema getSchema(@NotNull String namespace, @NotNull String tableName, @NotNull SchemaVersion version) Description copied from interface:SchemaServiceGet the specified version of theSchemadefined by namespace and table name- Specified by:
getSchemain interfaceSchemaService- Parameters:
namespace- the namespace of the tabletableName- the table nameversion- the version of this schema to retrieve- Returns:
- the requested version of the schema for namespace.tableName or null if none was found
-
getAllSchemas
Description copied from interface:SchemaServiceGet a collection of all known schemas in the system. The latest version of each will be returned. // TODO: subject to ACL visibility?- Specified by:
getAllSchemasin interfaceSchemaService- Returns:
- a collection of all known schemas
-
getSchemas
Description copied from interface:SchemaServiceGet a collection of all known schemas in the system, with the given namespace set. The latest version of each will be returned.- Specified by:
getSchemasin interfaceSchemaService- Returns:
- a collection of all known schemas in the given namespace set
-
getSchemas
Description copied from interface:SchemaServiceGet a collection of all known schemas in the given namespace. The latest version of each will be returned.- Specified by:
getSchemasin interfaceSchemaService- Returns:
- a collection of all known schemas in the given namespace
-
getLatestTableDefinitionSchema
@Nullable public TableDefinitionSchema getLatestTableDefinitionSchema(@NotNull String namespace, @NotNull String tableName) Description copied from interface:SchemaServiceGet the latest version of theTableDefinitionSchemadefined by namespace and table name- Specified by:
getLatestTableDefinitionSchemain interfaceSchemaService- Parameters:
namespace- the namespace of the tabletableName- the table name- Returns:
- the latest version of namespace.tableName or null if none was found
-
getNamespaceSet
@NotNull public NamespaceSet getNamespaceSet(@NotNull String namespace) throws IllegalArgumentException Description copied from interface:SchemaServiceGet theNamespaceSetfor a particular namespace.- Specified by:
getNamespaceSetin interfaceSchemaService- Parameters:
namespace- The namespace name- Returns:
- the namespace set of the namespace
- Throws:
IllegalArgumentException- if the namespace does not exist
-
containsNamespace
Description copied from interface:SchemaServiceFind out whether the given namespace is known to the schema service.- Specified by:
containsNamespacein interfaceSchemaService- Parameters:
namespace- the namespace in questionincludeDeleted- true if deleted namespaces should be considered- Returns:
- true if the namespace is found
-
containsSchema
Description copied from interface:SchemaServiceFind out if the given schema exists. Does not check for deleted schemas.- Specified by:
containsSchemain interfaceSchemaService- Parameters:
namespace- the namespace of the tabletableName- the table name- Returns:
- true if a schema is found for namespace.tableName
-
listNamespaces
Description copied from interface:SchemaServiceGet a collection of the namespaces available.- Specified by:
listNamespacesin interfaceSchemaService- Parameters:
includeDeleted- true if deleted namespaces should be included- Returns:
- a collection of namespace names
-
listNamespaces
@NotNull public Collection<String> listNamespaces(@NotNull NamespaceSet namespaceSet, boolean includeDeleted) Description copied from interface:SchemaServiceGet a collection of the namespaces available in the given namespace set.- Specified by:
listNamespacesin interfaceSchemaService- Parameters:
namespaceSet- list namespaces in this set (User, System)includeDeleted- true if deleted namespaces should be included- Returns:
- a collection of namespace names
-
listTableNames
@NotNull public Collection<String> listTableNames(@NotNull String namespace, boolean includeDeleted) Description copied from interface:SchemaServiceGet a collection of all table names in the specified namespace.- Specified by:
listTableNamesin interfaceSchemaService- Parameters:
namespace- the name of the namespaceincludeDeleted- tf deleted schemas should be included- Returns:
- a collection of all available schemas in namespace, empty list if namespace does not exit
-
listAllTables
Description copied from interface:SchemaServiceGet a map of all known tables in all known namespaces for all namespace sets.- Specified by:
listAllTablesin interfaceSchemaService- Returns:
- all the table names, mapped by namespace set and namespace
-
createNamespace
public boolean createNamespace(@NotNull NamespaceSet namespaceSet, @NotNull String namespaceName) throws SchemaException Description copied from interface:SchemaServiceAdd a namespace with the given name to the schema service, in the requested namespace set. Returns true if the namespace was added, false if it already exists. Throws a SchemaException if the namespace could not be added.- Specified by:
createNamespacein interfaceSchemaService- Parameters:
namespaceSet- add namespaceName to this namespace setnamespaceName- name of the new namespace- Returns:
- true if the namespace was added, false if it already exists.
- Throws:
SchemaException- if the namespace could not be added to the given namespace set
-
createNamespace
public boolean createNamespace(@NotNull NamespaceSet namespaceSet, @NotNull String namespaceName, @NotNull String code, @NotNull String comment) throws SchemaException Description copied from interface:SchemaServiceAdd a namespace with the given name to the schema service, in the requested namespace set. Returns true if the namespace was added, false if it already exists. Throws a SchemaException if the namespace could not be added.- Specified by:
createNamespacein interfaceSchemaService- Parameters:
namespaceSet- add namespaceName to this namespace setnamespaceName- name of the new namespacecode- pass-thru to kv persistence, indicates the code source of this updatecomment- pass-thru to kv persistence - a comment for this update- Returns:
- true if the namespace was added, false if it already exists.
- Throws:
SchemaException- if the namespace could not be added to the given namespace set
-
removeNamespace
public void removeNamespace(@NotNull String namespaceName, @NotNull String code, @NotNull String comment) throws SchemaException Description copied from interface:SchemaServiceRemove the given namespace. The namespace must be empty (contain no schemas).- Specified by:
removeNamespacein interfaceSchemaService- Parameters:
namespaceName- the namespace to removecode- pass-thru to kv persistence, indicates the code source of this updatecomment- pass-thru to kv persistence - a comment for this update- Throws:
SchemaException- if the namespace cannot be removed
-
removeNamespace
Description copied from interface:SchemaServiceRemove the given namespace. The namespace must be empty (contain no schemas).- Specified by:
removeNamespacein interfaceSchemaService- Parameters:
namespaceName- the namespace to remove
-
addSchema
Description copied from interface:SchemaServiceAdd the specified schema to the service.- Specified by:
addSchemain interfaceSchemaService- Parameters:
newSchema- the schema to add- Returns:
- the schema actually stored in the SchemaService
- Throws:
SchemaException- if the schema could not be added
-
addSchema
@NotNull public Schema addSchema(@NotNull Schema newSchema, @NotNull String code, @NotNull String comment) throws SchemaException Description copied from interface:SchemaServiceAdd the specified schema to the service.- Specified by:
addSchemain interfaceSchemaService- Parameters:
newSchema- the schema to addcode- pass-thru to kv persistence, indicates the code source of this updatecomment- pass-thru to kv persistence - a comment for this update * @return the schema actually stored in the SchemaService- Throws:
SchemaException- if the schema could not be added
-
addSchema
Description copied from interface:SchemaServiceAdd the specified schema to the service.- Specified by:
addSchemain interfaceSchemaService- Parameters:
newSchema- the schema to add- Returns:
- the schema actually stored in the SchemaService
- Throws:
SchemaException- if the schema could not be added or already exists
-
addSchema
@NotNull public Schema addSchema(@NotNull TableDefinitionSchema newSchema, @NotNull String code, @NotNull String comment) throws SchemaException Description copied from interface:SchemaServiceAdd the specified schema to the service.- Specified by:
addSchemain interfaceSchemaService- Parameters:
newSchema- the schema to addcode- pass-thru to kv persistence, indicates the code source of this updatecomment- pass-thru to kv persistence - a comment for this update- Returns:
- the schema actually stored in the SchemaService
- Throws:
SchemaException- if the schema could not be added or already exists
-
updateSchema
@NotNull public Schema updateSchema(@NotNull Schema newSchema) throws IllegalArgumentException, SchemaException Description copied from interface:SchemaServiceUpdate the schema with the same namespace and table name with the specified new schema.- Specified by:
updateSchemain interfaceSchemaService- Parameters:
newSchema- the schema to update with- Throws:
IllegalArgumentException- if the namespace or table does not existSchemaException- if the schema could not be updated
-
updateSchema
@NotNull public Schema updateSchema(@NotNull Schema newSchema, @NotNull String code, @NotNull String comment) throws IllegalArgumentException, SchemaException Description copied from interface:SchemaServiceUpdate the schema with the same namespace and table name with the specified new schema.- Specified by:
updateSchemain interfaceSchemaService- Parameters:
newSchema- the schema to update withcode- pass-thru to kv persistence, indicates the code source of this updatecomment- pass-thru to kv persistence - a comment for this update- Returns:
- the schema actually stored in the SchemaService
- Throws:
IllegalArgumentException- if the namespace or table does not existSchemaException- if the schema could not be updated
-
updateSchema
@NotNull public Schema updateSchema(@NotNull TableDefinitionSchema newSchema) throws IllegalArgumentException, SchemaException Description copied from interface:SchemaServiceUpdate the schema with the same namespace and table name with the specified new schema.- Specified by:
updateSchemain interfaceSchemaService- Parameters:
newSchema- the schema to update with.- Returns:
- the schema actually stored in the SchemaService
- Throws:
IllegalArgumentException- if the namespace or table does not existSchemaException- if the schema could not be updated
-
updateSchema
@NotNull public Schema updateSchema(@NotNull TableDefinitionSchema newSchema, @NotNull String code, @NotNull String comment) throws IllegalArgumentException, SchemaException Description copied from interface:SchemaServiceUpdate the schema with the same namespace and table name with the specified new schema.- Specified by:
updateSchemain interfaceSchemaService- Parameters:
newSchema- the schema to update with.code- pass-thru to kv persistence, indicates the code source of this updatecomment- pass-thru to kv persistence - a comment for this update- Returns:
- the schema actually stored in the SchemaService
- Throws:
IllegalArgumentException- if the namespace or table does not existSchemaException- if the schema could not be updated
-
deleteSchema
public void deleteSchema(@NotNull String namespace, @NotNull String tableName) throws IllegalArgumentException, SchemaException Description copied from interface:SchemaServiceDelete the specified schema.- Specified by:
deleteSchemain interfaceSchemaService- Parameters:
namespace- the namespace of the schema to deletetableName- the name of the schema to delete- Throws:
IllegalArgumentException- if the namespace or table could not be foundSchemaException- if the schema could not be deleted
-
deleteSchema
public void deleteSchema(@NotNull String namespace, @NotNull String tableName, @NotNull String code, @NotNull String comment) throws IllegalArgumentException, SchemaException Description copied from interface:SchemaServiceDelete the specified schema.- Specified by:
deleteSchemain interfaceSchemaService- Parameters:
namespace- the namespace of the schema to deletetableName- the name of the schema to deletecode- pass-thru to kv persistence, indicates the code source of this deletecomment- pass-thru to kv persistence - a comment for this delete- Throws:
IllegalArgumentException- if the namespace or table could not be foundSchemaException- if the schema could not be deleted
-