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
public abstract class StaticSchemaServiceImpl extends Object implements SchemaService
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
Fields Modifier and Type Field Description protected com.fishlib.configuration.Configuration
configuration
protected com.fishlib.io.logger.Logger
log
-
Constructor Summary
-
Method Summary
Modifier and Type Method Description Schema
addSchema(Schema newSchema)
Add the specified schema to the service.Schema
addSchema(Schema newSchema, String code, String comment)
Add the specified schema to the service.Schema
addSchema(TableDefinitionSchema newSchema)
Add the specified schema to the service.Schema
addSchema(TableDefinitionSchema newSchema, String code, String comment)
Add the specified schema to the service.boolean
authenticate()
Authenticate using default authentication.boolean
authenticate(String user, String password, String operateAs)
Authenticate using the given user and password, operating as the operateAs user.boolean
containsNamespace(String namespace, boolean includeDeleted)
Find out whether the given namespace is known to the schema service.boolean
containsSchema(String namespace, String tableName)
Find out if the given schema exists.boolean
createNamespace(NamespaceSet namespaceSet, String namespaceName)
Add a namespace with the given name to the schema service, in the requested namespace set.boolean
createNamespace(NamespaceSet namespaceSet, String namespaceName, String code, String comment)
Add a namespace with the given name to the schema service, in the requested namespace set.void
deleteSchema(String namespace, String tableName)
Delete the specified schema.void
deleteSchema(String namespace, String tableName, String code, String comment)
Delete the specified schema.Collection<Schema>
getAllSchemas()
Get a collection of all known schemas in the system.Schema
getLatestSchema(String namespace, String tableName)
Get the latest version of theSchema
defined by namespace and table nameSchemaXml
getLatestSchemaXml(String namespace, String tableName)
TableDefinitionSchema
getLatestTableDefinitionSchema(String namespace, String tableName)
Get the latest version of theTableDefinitionSchema
defined by namespace and table nameNamespaceSet
getNamespaceSet(String namespace)
Get theNamespaceSet
for a particular namespace.Schema
getSchema(String namespace, String tableName, SchemaVersion version)
Get the specified version of theSchema
defined by namespace and table nameCollection<Schema>
getSchemas(NamespaceSet namespaceSet)
Get a collection of all known schemas in the system, with the given namespace set.Collection<Schema>
getSchemas(String namespace)
Get a collection of all known schemas in the given namespace.Map<NamespaceSet,Map<String,Collection<String>>>
listAllTables()
Get a map of all known tables in all known namespaces for all namespace sets.Collection<String>
listNamespaces(boolean includeDeleted)
Get a collection of the namespaces available.Collection<String>
listNamespaces(NamespaceSet namespaceSet, boolean includeDeleted)
Get a collection of the namespaces available in the given namespace set.Collection<String>
listTableNames(String namespace, boolean includeDeleted)
Get a collection of all table names in the specified namespace.void
removeNamespace(String namespaceName)
Remove the given namespace.void
removeNamespace(String namespaceName, String code, String comment)
Remove the given namespace.Schema
updateSchema(Schema newSchema)
Update the schema with the same namespace and table name with the specified new schema.Schema
updateSchema(Schema newSchema, String code, String comment)
Update the schema with the same namespace and table name with the specified new schema.Schema
updateSchema(TableDefinitionSchema newSchema)
Update the schema with the same namespace and table name with the specified new schema.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, wait
Methods 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
-
Method Details
-
authenticate
public boolean authenticate(@NotNull String user, @NotNull String password, @NotNull String operateAs)Description copied from interface:SchemaService
Authenticate using the given user and password, operating as the operateAs user. Implementations are not required to allow re-authentication.- Specified by:
authenticate
in 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:SchemaService
Authenticate using default authentication. This will be using the default private key or howeverWAuthenticationClientManager.DEFAULT
has been authenticated.- Specified by:
authenticate
in interfaceSchemaService
- Returns:
- true only if the authentication succeeded
-
getLatestSchema
Description copied from interface:SchemaService
Get the latest version of theSchema
defined by namespace and table name- Specified by:
getLatestSchema
in 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
@Nullable public SchemaXml getLatestSchemaXml(@NotNull String namespace, @NotNull String tableName)Description copied from interface:SchemaService
Get the latest version of theSchema
defined by namespace and table name, as an implementation supportingSchemaXml
.- Specified by:
getLatestSchemaXml
in 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:SchemaService
Get the specified version of theSchema
defined by namespace and table name- Specified by:
getSchema
in 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:SchemaService
Get a collection of all known schemas in the system. The latest version of each will be returned. // TODO: subject to ACL visibility?- Specified by:
getAllSchemas
in interfaceSchemaService
- Returns:
- a collection of all known schemas
-
getSchemas
Description copied from interface:SchemaService
Get a collection of all known schemas in the system, with the given namespace set. The latest version of each will be returned.- Specified by:
getSchemas
in interfaceSchemaService
- Returns:
- a collection of all known schemas in the given namespace set
-
getSchemas
Description copied from interface:SchemaService
Get a collection of all known schemas in the given namespace. The latest version of each will be returned.- Specified by:
getSchemas
in 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:SchemaService
Get the latest version of theTableDefinitionSchema
defined by namespace and table name- Specified by:
getLatestTableDefinitionSchema
in 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 IllegalArgumentExceptionDescription copied from interface:SchemaService
Get theNamespaceSet
for a particular namespace.- Specified by:
getNamespaceSet
in 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:SchemaService
Find out whether the given namespace is known to the schema service.- Specified by:
containsNamespace
in 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:SchemaService
Find out if the given schema exists. Does not check for deleted schemas.- Specified by:
containsSchema
in 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:SchemaService
Get a collection of the namespaces available.- Specified by:
listNamespaces
in 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:SchemaService
Get a collection of the namespaces available in the given namespace set.- Specified by:
listNamespaces
in 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:SchemaService
Get a collection of all table names in the specified namespace.- Specified by:
listTableNames
in 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:SchemaService
Get a map of all known tables in all known namespaces for all namespace sets.- Specified by:
listAllTables
in interfaceSchemaService
- Returns:
- all the table names, mapped by namespace set and namespace
-
createNamespace
public boolean createNamespace(@NotNull NamespaceSet namespaceSet, @NotNull String namespaceName) throws SchemaExceptionDescription copied from interface:SchemaService
Add 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:
createNamespace
in 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 SchemaExceptionDescription copied from interface:SchemaService
Add 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:
createNamespace
in 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 SchemaExceptionDescription copied from interface:SchemaService
Remove the given namespace. The namespace must be empty (contain no schemas).- Specified by:
removeNamespace
in 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:SchemaService
Remove the given namespace. The namespace must be empty (contain no schemas).- Specified by:
removeNamespace
in interfaceSchemaService
- Parameters:
namespaceName
- the namespace to remove
-
addSchema
Description copied from interface:SchemaService
Add the specified schema to the service.- Specified by:
addSchema
in 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 SchemaExceptionDescription copied from interface:SchemaService
Add the specified schema to the service.- Specified by:
addSchema
in 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:SchemaService
Add the specified schema to the service.- Specified by:
addSchema
in 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 SchemaExceptionDescription copied from interface:SchemaService
Add the specified schema to the service.- Specified by:
addSchema
in 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, SchemaExceptionDescription copied from interface:SchemaService
Update the schema with the same namespace and table name with the specified new schema.- Specified by:
updateSchema
in 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, SchemaExceptionDescription copied from interface:SchemaService
Update the schema with the same namespace and table name with the specified new schema.- Specified by:
updateSchema
in 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, SchemaExceptionDescription copied from interface:SchemaService
Update the schema with the same namespace and table name with the specified new schema.- Specified by:
updateSchema
in 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, SchemaExceptionDescription copied from interface:SchemaService
Update the schema with the same namespace and table name with the specified new schema.- Specified by:
updateSchema
in 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, SchemaExceptionDescription copied from interface:SchemaService
Delete the specified schema.- Specified by:
deleteSchema
in 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, SchemaExceptionDescription copied from interface:SchemaService
Delete the specified schema.- Specified by:
deleteSchema
in 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
-