Box

Box, Inc. This company focuses on cloud content management and file sharing service for businesses. Official clients and apps are available for Windows, macOS, and several mobile platforms.

www.box.com


Authentication Connection

This connector require an Authentication Connection to function. Authentication connectors are used to authenticate repository/output connections that need certain authentication fields like access tokens or refresh tokens.

Authentication Connections Overview

Box has two types of Authentication methods. Box JWT Authentication and Box OAuth Authentication. Each connection has it's own Authentication Configuration. The Logging and Proxy tabs are the same.

Creating a Box Application

Before you can set up your Box Cloud Authentication Connection you must first create the necessary Authorisations via the Box App.

Box JWT Authentication

Configuration

  • Name: Name of this connection.

  • JWT JSON Key File: If you have downloaded the JWT key file from the Box Admin Console, and it is on the same file system as 3Sixty, then you can refer to it here (i.e. C:/Users/3Sixty/mykeyfile.json).

  • JWT JSON: Alternatively you can copy the contents of the JWT key file and paste it in this text area.

  • App Users Count: While in Output mode, the 3Sixty Box Connector allows you to create Box App Users to do bulk uploads to Box. This is an advanced setting and is only recommended for large integrations since there is a start-up cost in creating the app users in Box. Set to 0 to not use app users.

  • Base name of the app users: Base name that will be used for each app user.

  • The ID of the managed user you wish to act as: The connection will act as the user id for all actions.

  • Box Connection Timeout: Connection timeout interval.

  • Box Read Timeout: Read timeout interval.

Box OAuth Authentication

  • Name: Unique name for this auth connector.

  • Box Developer Token: (Optional) Developer Token to be used instead of clientId and secret. Developer tokens expire 60 minutes after creation

  • Box Client ID: Client ID box will give you once you've set up the Application in Box.

  • Box Secret Key: Secret Key Box will generate for you as part of the Application Setup in Box.

Note:  AUTHENTICATION: After filling in your client id and secret. Hit the "Authenticate" button. You will be redirected to a screen in Box asking you to confirm the application permissions. You should be returned to 3Sixty after accepting. If you receive an error, your redirect uri in the Box Application config may not be correct.

Proxy Configurations

This tab is for if you're connecting through a proxy, and is optional. Leave this tab blank if you aren't using a proxy.

Proxy Information

  • Proxy URL: The URL of the proxy server

  • Proxy Port: The port of the proxy server

  • Proxy Username: The username to authenticate to the proxy server

  • Proxy Password: The password to authenticate to the proxy server

Logging

  • Enable SDK Logging: Check to enable


Discovery Connection

The Box Discovery Connector requires a working authentication connection. It will gather all metadata templates and their associated fields. However, there is one type of metadata, known as "Custom Metadata" that is applied to individual documents, but not part of a global template.

In order to find Custom Metadata, you will need to supply the id of a folder to crawl for documents. The id of a folder is visible in its URL.

3Sixty will attempt to extract the custom metadata elements of any folder or file it finds, adding it to the schema.

The values will have a type of "properties" for the purposes of mappings.


Content Service Connection

This connection will provide a full ECM API for interacting with files, folders, metadata, versions, and renditions.

Content Service Connections Overview

Basic Configuration

  • Connector ID: Give your connector a unique name

  • Description: Provide a description for this connection

  • Type: Select the Filesystem Content Service Connector

  • Keep Connection Alive: Keep this connection active

  • Keep alive in Milliseconds (300000 is 5 minutes): How long until connection expires if unused

  • Connection URL: The web address for your connection

  • Security Mode: None needed for this connection

  • Mapping Type: Choose single map or group mapping if you are using mapping for jobs


Job Configuration

A 3Sixty Job is the process of moving or syncing content (including versions, ACL's, metadata) from one CMS (content management system) to another. Add tasks to your job to have better control over how your data gets migrated. Click here for details on how to set up an integration job.

Guide to Integration jobs

Repository

Box Query

This tab gives you three ways to retrieve data from Box. They construct a query using Box's Search API and can be mixed and matched as needed

Box Query: Used as a query parameter

Folder ID's (comma delimited): A comma delimited list of folder ids to restrict the search

Content Types (comma delimited): Available options are:

  • file - Limits the search results to files

  • folder - Limits the search results to folders

  • web_link - Limits the search results to web links, also known as bookmarks

Repository Crawl

Retrieve Folders: Folders will be retrieved as repository documents.

Retrieve Files: Checked by default, files will be retrieved.

Retrieve only listed folderIds: The connector will only collect the documents and folders configured in the Box Query tab, and will not crawl.

Retrieve Collaborations: Will retrieve collaborations in the format [user]=[role].

Truncate parent paths to exclude folders above specified folders:

As a default, the parent paths of files are absolute, and will include the root folder All Files as well as any folders above the configured ones. When this box is checked, only folder paths up to the "crawled" folders will be included.

Tip:  BOX FOLDER PATHS
If we have the file /AFolder/subfolder/testfile.txt at our root in Box, and we migrate subfolder, the file's final parent path will be /All Files/AFolder/subfolder/. With the truncate option checked, it will be /subfolder/testfile.txt

Important:  COMMON ISSUE: PKIX PATH BUILDING FAILED: This is a common issue when attempting to download files from box.
The full error will look like this in the logs:

Copy
Caught exception: Couldn't connect to the Box API due to a network error.
com.box.sdk.BoxAPIException: Couldn't connect to the Box API due to a network error
....(About fifteen lines of stacktrace)...
Caused by: javax.net.ssl.SSLHandshakeException: PKIX path building failed:
sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target

In order to fix this, first, attempt to install Box's ssl certificate in your Java keystore.

If that does not work, you can also download the Java Cryptography Extension (JCE) Unlimited Strength from Oracle and install the files in <JAVA_HOME>/jre/lib/security.

Output

Tip:  COMMON ISSUE: BLOCKED UPLOADS
The upload APIs for box are different from most others used by 3Sixty. Make sure your firewall is set to allow upload.box.com, or you will receive the error:
Error while uploading file <filename>.pdf Extended Response is: Couldn't connect to the Box API due to a network error.

Output Specification

  • Output Folder Path:
    The root folder to output too. Your repository folder structure will be replicated under this directory

  • Output Folder ID:
    Another option for selecting the output folder. Folder Ids can be retrieved from the url when viewing the folder in a browser. This will take precedence over path if supplied

  • Include Un-Mapped Properties
    All metadata will be output, even if no mappings are supplied. These values will be applied as global properties to the file.

  • Date/Date-Time Format
    Output format for the date. Box is restrictive on this, so changing either is not recommended.

Collaborations

  • Add Collaborations:
    Add collaborations to files written. Collaborations will need to be added as part of a task in the format of [email]=role. The JavaScript task is useful for this.

  • Strip Collaborations:
    Will remove all collaborations before adding them.

  • Collaborators Can View Path:
    Sets the option to true on a collaboration. The collaborator can see the parent path of the document.

  • Notify Collaborators on Add:
    Collaborators will receive an email (not recommended).

  • User ID to add Collaborations (Group Only):
    Use a group id instead of an email.

Data

  • Remove document and previous versions if it fails to fully upload:
    Used when outputting versions to Box. If a document is a version series fails to upload, 3Sixty will delete the previously uploaded versions as well. They will be counted in the Removed column in the job status page

  • Milliseconds to wait in response eto rate limit errors (multiplies times retries):
    Box has a very strict rate limit and will return an error code 429 (Too Many Requests) fairly often. This tells 3Sixty how long to wait before automatically retrying the call that failed.

  • Number of retries to attempt before failing a document:
    The name says it all.

  • If a file with the name already exists in the parent folder, create a new version:
    If unchecked, documents with the same name will fail if a document already in the target folder has the same name

  • Move Files Instead of Write (Box to Box only):
    Box has special methods for moving files within the same box organization. If this is checked, 3Sixty will use those methods instead of reading and writing content. To do this you will need a task to manipulate the parent path of the document in order to rehome it.

  • Copy Files Instead of Write (Box to Box only):
    Same as moving, but box will copy the files to their new location, instead of move them.

  • Pre Cache Folder Structure(experimental):
    3Sixty will recursively walk the structure below the target folder and cache their paths and ids. This can take a long time and is not really of use unless there is already content under the target folder.

  • Use Large Files Method on Files over 20 MB:
    Will use Box's large file APIs to more reliably upload large files

    Important:  WARNING
    This method is currently bugged and will cause an error if called by a Service User account. If you use JWT Authentication, leave this unchecked

  • Only Create Folders:
    Works in tandem with pre caching. Prebuild the folder structure, then use a different job that pre-caches to reduce overall times needed to move the content (experimental)

  • Only add template metadata if all listed fields are present:
    This field allows you to regulate what fields are allowed to be empty for documents receiving a metadata template

Tasks

Job tasks also known as processors provide a processing pipeline for documents and metadata. Post processors can also be added as a task to run after the files are processed.

Click here for a list of all the tasks you can add to your integration job.

Mapping

First, create a job that's going to write to Box or create a Job Mapping to be reused later.

For each metadata template you're mapping to, add the following Aspect mapping with the template key as the target.

Tip:  TEMPLATE KEYS (FROM BOX'S DOCUMENTATION ON METADATA TEMPLATE KEYS)
When a metadata template is created, a templateKey is automatically generated from the displayName of the template unless a templateKey is explicitly provided. When creating the template key any spaces and irregular characters in the name are removed, and the string is transformed to camel case. For example, a metadata template that is named Test Name (with-special_) Characters will have a templateKey of testNameWithspecialCharacters. This template key is then used when making any API requests to get the template's information or assign it to an item.

With that done, map your fields as normal to the fields on the template.

Here's an example

Using Calculated Fields With Templates

Box template fields will only be picked up during the mapping process if they have the right prefix. In this case, the prefix will be the Source of the Aspect Mapping you using for the template. So, for the mapping:

document -----Aspect Mapping----> simtemplate

The field mappings for the fields in simtemplate will need the prefix document.

Because of how Calculated Fields work, they are evaluated and added to the document as regular field values. So, if you wish to direct a calculated field to a template field in Box, you will need two mappings. First, a Calculated Field to generate the field value, then a Field Mapping.

For example, if we want to put the constant value 3Sixty on the field title in Box, we need the following:

'3Sixty' -----> Calculated Field -----> document.title

document.title -------> Field Mapping -----> title


API Keys

Box Connector: Read=true: Write=true: MIP=false

Repo (Read) Specs

Key

Description

Data Type

boxQuery Box Query String

boxFolderIds

Folder Id's (comma delimited)

String

boxContentTypes

Content Types (comma delimited)

String

(Read Spec Tab):Repository Crawl

 

 

crawlFolders

Retrieve Folders

Boolean

crawlFiles

Retrieve Files

Boolean

truncateParents

Truncate parent paths to exclude folders above specified folders

Boolean

getVersions

Get Versions

Boolean

vDepth

Select the number of versions to retrieve, going backwards from the original. 0 will retrieve all versions

Long

dontCrawl

Retrieve Only Listed Folders/Files

Boolean

addRepoCollaborations

Retrieve Collaborations

Boolean

Output (Write) Specs

Key

Description

Data Type

outputfolderpath Output Folder Path String

outputfolderid

Output Folder Id (Will take precedence over path if supplied)

String

includedUnMapped

Include Un-Mapped Properties

Boolean

boxDateFormat

Date Format

String

boxDateTimeFormat

Date Time Format

String

addCollaborations

Add Collaborations (Not needed if only adding to root folder)

Boolean

stripCollaborations

Strip Collaborations

Boolean

collaborationsViewPath

Collaborators Can View Path

Boolean

collaborationsNotify

Notify Collaborator on Add

Boolean

collaborationsId

Use ID to add Collaborations (Groups Only)

Boolean

collaborationsParents

Which folder to add collaboration. 0 for file, 1 for parent etc, -1 For configured root folder only. Please supply a list below if -1

String

collaborationsRoot

Comma Delimited List of Collaborations to add to the root folder in [user]=[role] format.

String

roll_back_onfail

Remove document and previous versions if it fails to fully upload.

Boolean

backOffInterval

Milliseconds to wait in response to rate limit errors (multiplies times retries).

Long

backOffRetried

Number of retries to attempt before failing a document.

Long

versionIfExists

If a file with the same name already exists in the parent folder, create a new version

Boolean

moveFiles

Move Files Instead of Write (Box to Box only)

Boolean

copyFiles

Copy Files Instead of Write (Box to Box only)

Boolean

preCache

Pre Cache Folder Structure (Not Recommended)

Boolean

large_files

Use Large Files Method on Files over 20MB

Boolean

only_create_folders

Only Create Folders

Boolean

check_template

Only add template metadata if all listed fields are present. Format is standard JSON {template1" ["field1" field2 field(n)] template2 ["field1"]}. If left blank unmapped template fields will be empty"

String


Need help integrating Box Cloud? We can help.