MongoDB
MongoDB is a source-available cross-platform document-oriented database program. Classified as a NoSQL database program, MongoDB uses JSON-like documents with optional schemas.
Note:  INFO
This page is only meant to cover using MongoDB without GridFS. The common use case for MongoDB without GridFS is to act as an indexing engine, like Elasticsearch
Authentication Connection
Authentication Configuration Fields
- 
                                                        Name: Unique name for this auth connector. 
- 
                                                        Username: The Username of the user to authenticate with to the Mongo DB Instance. 
- 
                                                        Password: The password associated with the above username. 
- 
                                                        Mongo URI: The Full mongodb connection URI to connect to. See this document for additional info on URI construction. 
- 
                                                        Database: The database to authorise to. 
- 
                                                        Use MongoDB GridFS Services: Using MongoDB GridFS Services. Leave unchecked for regular MongoDB 
Note:  MONGO URI
3Sixty inserts the username and password into the connection string. In order to include them as part of the uri we use
[[USER]]:[[PASS]]
Discovery Connector
Discovery Instance Configuration Fields
- 
                                                        Name: Unique name for your connector 
- 
                                                        Authentication Connection: Select the auth connector for this discovery 
- 
                                                        Ignore Types (comma delimited list): Chose document types to ignore when running discovery 
- 
                                                        Database: The name of the Mongo database to read data from. 
- 
                                                        Server And Port: The port used to connect to your Mongo database. 
Integration Connection
Integration Connection Fields
- 
                                                        Connection Name: This is a unique name given to the connector instance upon creation. 
- 
                                                        Description: A description of the connector to help identify it better. 
Job Configuration
Output Specification
- 
                                                        Collection: The name of the collection to create/write to. 3Sixty will handle the "files" and "chunks" collections internally 
- 
                                                        Insert 3Sixty Metadata: Required for Federation. Write 3Sixty metadata onto objects. Automatically included if GridFS is enabled in auth connection. 
- 
                                                        Use bulk write operations (MongoDB only): 3Sixty will use bulk write operations for better performance. 
- 
                                                        Number of documents to write per bulk operations: Number of documents to send per bulk write 
- 
                                                        Include Un-Mapped Properties: Add all metadata on the document 
Advanced Options
- 
                                                        Drop and Build Indexes: Indexes are created to speed up searches. This will rebuild them entirely. This can be a lengthy process and should only ever be performed on the initial run 
- 
                                                        Index Keys: A comma delimited list of field keys to index. For multiple collections use key1:collection1,key2:collection2. 
- 
                                                        Upsert Key: 'Upserting' is simply means "Update if exists". This key will be checked to see if the document already exists. Leave blank to use 3Sixty source repository key. If not set and Insert 3Sixty Metadata is not checked, then only creates will be called. 
- 
                                                        MongoDB Write Concern: Write concern describes the level of acknowledgement requested from MongoDB for write operations 
- 
                                                        File Store Connector ID: Connector ID of Content Service Connector to use as the File Store. Or leave blank to use native GridFS. This field is only used if MongoDB GridFS is Enabled in the Authentication Connector. 
Mongo Repository
- 
                                                        Comma delimited list of collections to crawl: As the name says. 
- 
                                                        Select what field will act as the source id for the document: The field which will appears as the "source_repository_id" field in the output document 
- 
                                                        Query: A Mongo Query. If left blank the query will be "{}", or "get all" 
Content Service Connection
Note:  
                                                    
This mode of connector does not interact with content stored in MongoDB. Use the GridFS mode.
Content Search Connection
Default Query: (3.1.1+) This field allows you to add a default mongodb query to all incoming queries. The query in this box will be wrapped in an $and clause with all other search parameters.
Get all versions and display versions on file name: Only used in GridFS Mode
Indexing Document Level Permissions
3Sixty content views offer a number of security layers. Using the JavaScript processor permissions can be added to each document, which can restrict widget usage and the ability to search for the document.
Repository Document ACLS
Each document, whether it has source permissions or not, will have an Allow and Deny ACL (Access Control List). Both lists exist as a list of strings (String []) on the document, and can be access through JavaScript. In order to apply document level permissions to documents, permissions will need to take the form
action=principal1,principal2,principal3
Where action can be Search, or the id of a Widget Definition The principals are 3Sixty user logins, or User Group names.
Note:  LIMITATIONS
Only the Search permission is checked at the API level. Meaning, that a user can still access documents directly through the Content Services API. These permissions simply alter content views to prevent them from performing these actions via Widgets.
{
  "allow": true,
  "action": "Search",
  "principals": [
    "everyone"
  ]
}Here is an example of some JavaScript that will prevent users in group1 from downloading documents through Discovery. It will also stop user1 from searching for the document.
var deny = ['DownloadWidget=group1', 'Search=user1'];rd.setDenyAcl(deny);API Keys
MongoDB Connector: Read=true: Write=true: MIP=false
Repo (Read) Specs
| Key | Description | Data Type | 
|---|---|---|
| collections | Comma delimited list of collections to crawl. | String | 
| idField | Select what field will act as the source id for the document. | String | 
| query | Query | String | 
Output (Write) Specs
| Key | Description | Data Type | 
|---|---|---|
| collection | Collection | String | 
| simMeta | Insert 3Sixty Metadata | Boolean | 
| useBulkWrite | Use bulk write operations (MongoDB only) | Boolean | 
| bulkCount | Number of documents to write per bulk operations | Long | 
| includedUnMapped | Include Un-Mapped Properties | Boolean | 
| dropAndBuildIndexes | Drop and Build Indexes | Boolean | 
| indexKeys | Index Keys | String | 
| textField | Text Index Keys | String | 
| upsertKey | Upsert Key | String | 
| writeConcern | MongoDB Write Concern | String | 
| fileStoreConnId | File Store Connector Id | String |