Package org.nuxeo.directory.mongodb
Class MongoDBSession
java.lang.Object
org.nuxeo.ecm.directory.BaseSession
org.nuxeo.directory.mongodb.MongoDBSession
- All Implemented Interfaces:
AutoCloseable
,EntrySource
,Session
MongoDB implementation of a
Session
- Since:
- 9.1
-
Nested Class Summary
Modifier and TypeClassDescriptionclass
MongoDB Query Builder that knows how to resolved directory properties.Nested classes/interfaces inherited from class org.nuxeo.ecm.directory.BaseSession
BaseSession.FieldDetector
-
Field Summary
Fields inherited from class org.nuxeo.ecm.directory.BaseSession
autoincrementId, computeMultiTenantId, directory, directoryName, MULTI_TENANT_ID_FORMAT, passwordHashAlgorithm, permissions, POWER_USERS_GROUP, readAllColumns, READONLY_ENTRY_FLAG, referenceClass, schemaName, substringMatchType, TENANT_ID_FIELD
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionprotected void
boolean
authenticate
(String username, String password) Checks that the credentials provided by the UserManager match those registered in the directory.protected org.bson.Document
buildQuery
(Map<String, Serializable> fieldMap, Set<String> fulltext) protected boolean
checkEntryTenantId
(String entryTenantId) void
close()
Closes the session and all open result sets obtained from this session.protected Object
convertToType
(Object value, Type type) protected DocumentModel
createEntryWithoutReferences
(Map<String, Object> fieldMap) To be implemented for specific creation.void
To be implemented for specific deletion.protected DocumentModelList
doQuery
(Map<String, Serializable> filter, Set<String> fulltext, Map<String, String> orderBy, boolean fetchReferences, int limit, int offset, boolean checkTenantId) protected DocumentModel
fieldMapToDocumentModel
(Map<String, Object> fieldMap) protected com.mongodb.client.MongoCollection<org.bson.Document>
Retrieve the collection associated to this directoryprotected com.mongodb.client.MongoCollection<org.bson.Document>
Retrieve the counters collection associated to this directoryTo be implemented with a more specific return type.getEntryFromSource
(String id, boolean fetchReferences) protected Type
protected String
getIdFromState
(State state) protected String
protected String
boolean
Returns true if session has an entry with given id.protected boolean
boolean
Tells whether the directory implementation can be used as an authenticating backend for the UserManager (based on login / password check).query
(Map<String, Serializable> filter, Set<String> fulltext, Map<String, String> orderBy, boolean fetchReferences, int limit, int offset) Executes a query with the possibility to fetch a subset of the results. org.nuxeo.ecm.directory.BaseSession provides a default implementation fetching all results to return the subset.query
(QueryBuilder queryBuilder, boolean fetchReferences) Executes a query with the possibility to fetch a subset of the results.queryIds
(QueryBuilder queryBuilder) Executes a query with the possibility to fetch a subset of the results.updateEntryWithoutReferences
(DocumentModel docModel) To be implemented for specific update.Methods inherited from class org.nuxeo.ecm.directory.BaseSession
addTenantId, applyQueryLimits, applyQueryLimits, canDeleteMultiTenantEntry, checkDeleteConstraints, checkPermission, computeMultiTenantDirectoryId, createEntry, createEntry, createEntryModel, createEntryModel, createEntryModel, createEntryModel, createEntryModel, deleteEntry, deleteEntry, getCurrentTenantId, getEntry, getEntry, getIdField, getPasswordField, getProjection, getProjection, hasPermission, hasPermission, isMultiTenant, isReadOnly, isReadOnlyEntry, query, query, query, query, setReadAllColumns, setReadOnlyEntry, setReadWriteEntry, toStringList, updateEntry
-
Constructor Details
-
MongoDBSession
-
-
Method Details
-
getDirectory
Description copied from class:BaseSession
To be implemented with a more specific return type.- Specified by:
getDirectory
in classBaseSession
-
getEntryFromSource
- Specified by:
getEntryFromSource
in interfaceEntrySource
- Overrides:
getEntryFromSource
in classBaseSession
-
createEntryWithoutReferences
Description copied from class:BaseSession
To be implemented for specific creation.- Specified by:
createEntryWithoutReferences
in classBaseSession
-
convertToType
-
updateEntryWithoutReferences
Description copied from class:BaseSession
To be implemented for specific update.- Specified by:
updateEntryWithoutReferences
in classBaseSession
-
deleteEntryWithoutReferences
Description copied from class:BaseSession
To be implemented for specific deletion.- Specified by:
deleteEntryWithoutReferences
in classBaseSession
-
query
public DocumentModelList query(Map<String, Serializable> filter, Set<String> fulltext, Map<String, String> orderBy, boolean fetchReferences, int limit, int offset) Description copied from interface:Session
Executes a query with the possibility to fetch a subset of the results. org.nuxeo.ecm.directory.BaseSession provides a default implementation fetching all results to return the subset. Not recommended.limit
- maximum number of results ignored if less than 1offset
- number of rows skipped before starting, will be 0 if less than 0.- See Also:
-
doQuery
protected DocumentModelList doQuery(Map<String, Serializable> filter, Set<String> fulltext, Map<String, String> orderBy, boolean fetchReferences, int limit, int offset, boolean checkTenantId) -
buildQuery
-
addField
-
query
Description copied from interface:Session
Executes a query with the possibility to fetch a subset of the results.- Parameters:
queryBuilder
- the query to use, including limit, offset, ordering and countTotalfetchReferences
- boolean stating if references have to be fetched- Returns:
- the list of documents, where the total size may be present if countTotal was true
-
queryIds
Description copied from interface:Session
Executes a query with the possibility to fetch a subset of the results. Returns the matching ids.- Parameters:
queryBuilder
- the query to use, including limit, offset and ordering- Returns:
- the list of document ids
-
close
public void close()Description copied from interface:Session
Closes the session and all open result sets obtained from this session.Releases this Connection object's resources immediately instead of waiting for them to be automatically released.
TODO: should this operation auto-commit pending changes?
-
authenticate
Description copied from interface:Session
Checks that the credentials provided by the UserManager match those registered in the directory. If username is not in the directory, this should return false instead of throrwing an exception.- Returns:
- true is the credentials match those stored in the directory
-
isAuthenticating
public boolean isAuthenticating()Description copied from interface:Session
Tells whether the directory implementation can be used as an authenticating backend for the UserManager (based on login / password check).- Specified by:
isAuthenticating
in interfaceSession
- Overrides:
isAuthenticating
in classBaseSession
- Returns:
- true is the directory is authentication aware
-
hasEntry
Description copied from interface:Session
Returns true if session has an entry with given id. -
hasEntry0
-
getCollection
protected com.mongodb.client.MongoCollection<org.bson.Document> getCollection()Retrieve the collection associated to this directory- Returns:
- the MongoDB collection
-
getCountersCollection
protected com.mongodb.client.MongoCollection<org.bson.Document> getCountersCollection()Retrieve the counters collection associated to this directory- Returns:
- the MongoDB counters collection
-
fieldMapToDocumentModel
-
getIdFromState
-
checkEntryTenantId
-
getPrefixedIdField
-
getPrefixedPasswordField
-
getIdFieldType
-