An open source DocSend alternative
Datahall is an open source DocSend alternative where you can share your files privately with anyone outside of your organization.
Currently, Datahall is in development. The current designs and the style guide can be viewed here.
- Uploading and editing files
- Sharing and link control
- Tracking and analytics
- Document viewer
- Company branding
User
Name | Type | Notes |
---|---|---|
userId |
string |
Primary Key. Unique ID for each user |
firstName |
string |
First name |
lastName |
string |
Last name |
email |
string |
Unique. User's email |
profilePicUrl |
string |
URL to User's picture |
isActive |
boolean |
Default: true |
isVerified |
boolean |
Default: false |
lastLogin |
Date |
Timestamp of the last login |
createdAt |
Date |
Not Null. Timestamp when the user was created |
updatedAt |
Date |
Not Null. Timestamp when the user was last updated |
Documents
Name | Type | Notes |
---|---|---|
fileId |
string |
Primary Key. Unique ID identifying the file |
parentFileId |
string |
Foreign Key. References Documents.fileId |
fileName |
string |
Name of the file |
type |
string |
File type / extension |
fileDirectory |
string |
Directory where the file is located |
fileSize |
int |
Size of the file in bytes |
mimeType |
string |
MIME type of the file |
createdBy |
string |
Foreign Key. References User.userId |
createdAt |
Date |
Not Null. Creation time |
updatedAt |
Date |
Not Null. Last update time |
updatedBy |
string |
Foreign Key. References User.userId |
totalViews |
int |
Total number of times the file was viewed |
uniqueViews |
int |
Number of unique viewers of the file |
Links
Name | Type | Notes |
---|---|---|
linkId |
string |
Primary Key. Unique ID for the link |
fileId |
string |
Foreign Key. References Documents.fileId |
linkName |
string |
Name of the link |
linkUrl |
string |
URL of the link |
isPublic |
boolean |
Indicates if the link is public |
emailRequired |
boolean |
Indicates if an email is required for download |
passwordRequired |
boolean |
Indicates if a password is required to view and download the file |
linkPassword |
string |
Password reqired to view and download the file |
linkUrl |
string |
URL of the link |
canExpire |
boolean |
Indicates if the link can expire |
expirationTime |
Date |
Expiration date of the link (nullable) |
updatedAt |
Date |
Not Null. Last update time |
createdAt |
Date |
Not Null. Creation time |
createdBy |
string |
Foreign Key. References User.userId |
Datahall
Name | Type | Notes |
---|---|---|
folderId |
string |
Primary Key. Unique ID for the folder |
folderName |
string |
Name of the folder |
folderLocation |
string |
Location of the folder |
updatedAt |
Date |
Not Null. Last update time |
updatedBy |
string |
Foreign Key. References User.userId |
createdAt |
Date |
Not Null. Creation time |
createdBy |
string |
Foreign Key. References User.userId |
AccessLogs
Name | Type | Notes |
---|---|---|
logId |
string |
Primary Key. Unique ID for each access log |
linkId |
string |
Foreign Key. ID of the link accessed |
userId |
string |
Foreign Key. ID of the user who accessed the link |
accessTime |
Date |
Not Null. Timestamp when the link was accessed |
ipAddress |
string |
IP address of the user who accessed the link |
GET
/api/v1/auth/users
Method/Headers Value Method GET content-type application/json
Type Notes Array<User>
Returns an array containing all users
POST
/api/v1/auth/register
Method/Headers Value Method POST content-type multipart/form-data
Name Type Notes firstName string
lastName string
string
Valid email address password string
Min 8 chars, One Upper, one number, one special role Array<string>
Array of user roles
Type Notes User User data JWT JSON web token
POST
/api/v1/auth/login
Method/Headers Value Method POST content-type application/json
Name Type Notes string
Valid email address password string
Type Notes User User data JWT JSON web token
POST
/api/v1/auth/user/{userId}
Method/Headers Value Method POST content-type multipart/form-data
Name Type Notes firstName string
Optional lastName string
Optional profileIame file
Optional password string
Required to change password newPassword string
Required to change password
Type Notes User
Returns the updated user
POST
/api/v1/auth/recovery/request
Method/Headers Value Method POST content-type application/json
Name Type Notes string
User's email
Type Notes RecoveryToken
Returns a recovery token if email found
POST
/api/v1/auth/recovery/validate
Method/Headers Value Method POST content-type application/json
Name Type Notes recoveryToken string
Token issued in /recovery/request
Type Notes RecoveryToken
Returns the recovery token
POST
/api/v1/auth/recovery/reset
Method/Headers Value Method POST content-type application/json
Name Type Notes recoveryToken string
Token issued returned by /recovery/validate
password string
User's new password`
Type Notes User
Returns the updated user
GET
/api/v1/documents
Method/Headers Value Method GET content-type application/json
Type Notes Array<Document>
Array of all latest versions of documents
GET
/api/v1/documents/versions/{documentId}
Method/Headers Value Method GET content-type application/json
Type Notes Array<Document>
Array of all documents versions for the parent document
GET
/api/v1/document/{documentId}
Method/Headers Value Method GET content-type application/json
Type Notes Document
Document with the id in the request parameter
POST
/api/v1/document
Method/Headers Value Method POST content-type multipart/form-data
Name Type Notes Accepted Values fileData
string
The file to be uploaded fileName
string
Name of the file type
string
File type / extension fileDirectory
string
Directory where the file should go fileSize
int
Size of the file in bytes mimeType
string
MIME type of the file userId
string
UserId of current user
Type Notes Document
Returns newly created Document
POST
/api/v1/document/delete/{fileId}
Method/Headers Value Method POST content-type application/json
Type Notes None
No payload returned
POST
/api/v1/document/edit/{fileId}
Method/Headers Value Method POST content-type multipart/form-data
Name Type Notes Accepted Values fileData
string
The file to be uploaded fileName
string
Name of the file type
string
File type / extension fileDirectory
string
Directory where the file should go fileSize
int
Size of the file in bytes mimeType
string
MIME type of the file userId
string
UserId of current user
Type Notes Document
Returns updated Document
GET
/api/v1/datarooms
Method/Headers Value Method GET content-type application/json
Type Notes Array<DataRoom>
Array of all datarooms
GET
/api/v1/dataroom/{folderId}
Method/Headers Value Method GET content-type application/json
Type Notes DataRoom
Single dataroom with the id in the request parameter
POST
/api/v1/dataroom
Method/Headers Value Method POST content-type application/json
Name Type Notes Accepted Values folderName
string
Name of the file folderLocation
string
File type / extension userId
string
UserId of current user
Type Notes DataRoom
Returns newly created DataRoom
POST
/api/v1/dataroom/delete/{folderId}
Method/Headers Value Method POST content-type application/json
Type Notes None
No payload returned
POST
/api/v1/dataroom/edit/{folderId}
Method/Headers Value Method POST content-type application/json
Name Type Notes Accepted Values folderName
string
Name of the file folderLocation
string
File type / extension userId
string
UserId of current user
Type Notes DataRoom
Returns updated DataRoom
GET
/api/v1/links
Method/Headers Value Method GET content-type application/json
Type Notes Array<Links>
Array of all links
GET
/api/v1/link/{linkId}
Method/Headers Value Method GET content-type application/json
Type Notes Link
Singe Link with the id in the request parameter
POST
/api/v1/link
Method/Headers Value Method POST content-type application/json
Name Type Notes Accepted Values fileId
string
The fileId of the file the link is generated for linkName
string
Name of the link isPublic
boolean
Indicates if the link is public emailRequired
boolean
Indicates if email is required to download passwordRequired
boolean
Indicates if password is required to download linkPassword
string
Password required to download canExpire
boolean
Indicates if the link can expire expirationTime
Date
Date in which the link expires
Type Notes Link
Returns newly created Link
POST
/api/v1/link/delete/{linkId}
Method/Headers Value Method POST content-type application/json
Type Notes None
No payload returned
POST
/api/v1/link/edit/{linkId}
Method/Headers Value Method POST content-type application/json
Name Type Notes Accepted Values linkName
string
Name of the link isPublic
boolean
Indicates if the link is public emailRequired
boolean
Indicates if email is required to download passwordRequired
boolean
Indicates if password is required to download linkPassword
string
Password required to download canExpire
boolean
Indicates if the link can expire expirationTime
Date
Date in which the link expires
Type Notes Link
Returns updated Link