Upload Files to Zoho File System (ZFS)
Purpose
ZFS is the central storage system to all your files and attachments. Use this API to upload fields to ZFS. This API returns an encrypted file ID and the file name. You can use this encrypted ID to attach this file to a file/image upload field or a record in Zoho Vertical Solutions. You must upload the file with content type as multipart/form data.
Endpoints
Request Details
Request URL
{api-domain}/crm/v2/files
Header
Authorization: Zoho-oauthtoken 100xx.d92d4xxxxxxxxxxxxx15f52
Scope
scope=ZohoCRM.Files.{operation_type}
Possible operation types
CREATE - To add files to ZFS
Parameters
- typestring, optional
To upload inline images.
Resolution: The value is inline.
Sample Request
Copiedcurl "https://zylkercorp.zohoplatform.com/crm/v2/files"
-X POST
-H "Authorization: Zoho-oauthtoken 100xx.8cb99dxxxxxxxxxxxxx9be93.9b8xxxxxxxxxxxxxxxf"
-F "file=@connections.txt"
-F "file=@enable-signals.png"
Copied//Get instance of FileOperations Class
let fileOperations = new ZCRM.File.Operations();
//Get instance of FileBodyWrapper Class that will contain the request body
let request = new ZCRM.File.Model.BodyWrapper();
let paramInstance = new ParameterMap();
await paramInstance.add(ZCRM.File.Model.UploadFilesParam.TYPE, "inline");
/** StreamWrapper can be initialized in any of the following ways */
var filesToLoad = document.getElementById("file_api").files;
var files = [];
for(var fileData of filesToLoad) {
/**
* param 1 -> fileName
* param 2 -> Read Stream.
*/
let streamWrapper = new StreamWrapper.Model.StreamWrapper(null, fileData);
files.push(streamWrapper);
}
request.setFile(files);
//Call uploadFile method that takes BodyWrapper instance as parameter.
let response = await fileOperations.uploadFiles(request, paramInstance);
Copiedvar listener = 0;
class UploadFilestoZohoFileSystem {
async uploadFiles() {
var url = "https://zylkercorp.zohoplatform.com/crm/v2/files"
var parameters = new Map()
var headers = new Map()
var token = {
clientId:"1000.NPY9M1V0XXXXXXXXXXXXXXXXXXXF7H",
redirectUrl:"http://127.0.0.1:5500/redirect.html",
scope:"ZohoCRM.users.ALL,ZohoCRM.bulk.read,ZohoCRM.modules.ALL,ZohoCRM.settings.ALL,Aaaserver.profile.Read,ZohoCRM.org.ALL,profile.userphoto.READ,ZohoFiles.files.ALL,ZohoCRM.bulk.ALL,ZohoCRM.settings.variable_groups.ALL"
}
var accesstoken = await new UploadFilestoZohoFileSystem().getToken(token)
headers.set("Authorization", "Zoho-oauthtoken " + accesstoken)
parameters.set("type", "inline")
var filesToLoad = document.getElementById("files").files;
var file = filesToLoad[0];
var requestMethod = "POST"
var formDataRequestBody = new FormData();
formDataRequestBody.append("file", new Blob([file]),file.name);
var reqBody = formDataRequestBody
var params = "";
parameters.forEach(function(value, key) {
if (parameters.has(key)) {
if (params) {
params = params + key + '=' + value + '&';
}
else {
params = key + '=' + value + '&';
}
}
});
var apiHeaders = {};
if(headers) {
headers.forEach(function(value, key) {
apiHeaders[key] = value;
});
}
if (params.length > 0){
url = url + '?' + params.substring(0, params.length - 1);
}
var requestObj = {
uri : url,
method : requestMethod,
headers : apiHeaders,
body : reqBody,
encoding: "utf8",
allowGetBody : true,
throwHttpErrors : false
};
var result = await new UploadFilestoZohoFileSystem().makeAPICall(requestObj);
console.log(result.status)
console.log(result.response)
}
async getToken(token) {
if(listener == 0) {
window.addEventListener("storage", function(reponse) {
if(reponse.key === "access_token" && (reponse.oldValue != reponse.newValue || reponse.oldValue == null)){
location.reload();
}
if(reponse.key === "access_token"){
sessionStorage.removeItem("__auth_process");
}
}, false);
listener = 1;
if(sessionStorage.getItem("__auth_process")) {
sessionStorage.removeItem("__auth_process");
}
}
["granted_for_session", "access_token","expires_in","expires_in_sec","location","api_domain","state","__token_init","__auth_process"].forEach(function (k) {
var isKeyExists = localStorage.hasOwnProperty(k);
if(isKeyExists) {
sessionStorage.setItem(k, localStorage[k]);
}
localStorage.removeItem(k);
});
var valueInStore = sessionStorage.getItem("access_token");
var tokenInit = sessionStorage.getItem("__token_init");
if(tokenInit != null && valueInStore != null && Date.now() >= parseInt(tokenInit) + 59 * 60 * 1000){ // check after 59th minute
valueInStore = null;
sessionStorage.removeItem("access_token");
}
var auth_process = sessionStorage.getItem("__auth_process");
if ((valueInStore == null && auth_process == null) || (valueInStore == 'undefined' && (auth_process == null || auth_process == "true"))) {
var accountsUrl = "https://zylkercorp.zohoplatform.com/oauth/v2/auth"
var clientId;
var scope;
var redirectUrl;
if(token != null) {
clientId = token.clientId;
scope = token.scope;
redirectUrl = token.redirectUrl;
}
var fullGrant = sessionStorage.getItem("full_grant");
var grantedForSession = sessionStorage.getItem("granted_for_session");
if(sessionStorage.getItem("__token_init") != null && ((fullGrant != null && "true" == full_grant) || (grantedForSession != null && "true" == grantedForSession))) {
accountsUrl += '/refresh';
}
if (clientId && scope) {
sessionStorage.setItem("__token_init", Date.now());
sessionStorage.removeItem("access_token");
sessionStorage.setItem("__auth_process", "true");
window.open(accountsUrl + "?" + "scope" + "=" + scope + "&"+ "client_id" +"=" + clientId + "&response_type=token&state=zohocrmclient&redirect_uri=" + redirectUrl);
["granted_for_session", "access_token","expires_in","expires_in_sec","location","api_domain","state","__token_init","__auth_process"].forEach(function (k) {
var isKeyExists = localStorage.hasOwnProperty(k);
if(isKeyExists){
sessionStorage.setItem(k, localStorage[k]);
}
localStorage.removeItem(k);
});
valueInStore = sessionStorage.getItem("access_token");
}
}
if(token != null && valueInStore != 'undefined'){
token.accessToken = valueInStore;
}
return token.accessToken;
}
async makeAPICall(requestDetails) {
return new Promise(function (resolve, reject) {
var body, xhr, i;
body = requestDetails.body || null;
xhr = new XMLHttpRequest();
xhr.withCredentials = true;
xhr.open(requestDetails.method, requestDetails.uri, true);
for (i in requestDetails.headers) {
xhr.setRequestHeader(i, requestDetails.headers[i]);
}
xhr.send(body);
xhr.onreadystatechange = function() {
if(xhr.readyState == 4) {
resolve(xhr);
}
}
})
}
}
CopiedfileVariable = invokeurl
[
url: "https://file-examples-com.github.io/uploads/2017/10/file-sample_150kB.pdf"
type: GET
];
fileVariable.setParamName("file");
response = invokeurl
[
url :"https://zylkercorp.zohoplatform.com/crm/v2/files"
type :POST
files: fileVariable
connection:"crm_oauth_connection"
];
info response;
Possible Errors
- failure_in_attachment_handling HTTP 400
invalid oauth scope to access this URL
Resolution: Problem in uploading attachment. kindly upload the file properly - VIRUS_DETECTEDHTTP 400
Unable to process your request. Virus has been detected.
Resolution: A virus is found in the file that you uploaded. Upload a file without any viruses. - INVALID_URL_PATTERNHTTP 404
Please check if the URL trying to access is a correct one
Resolution: The request URL specified is incorrect. Specify a valid request URL. Refer to request URL section above. - OAUTH_SCOPE_MISMATCHHTTP 401
Unauthorized
Resolution: Client does not have ZohoCRM.Files.CREATE scope. Create a new client with valid scope. Refer to scope section above. - NO_PERMISSIONHTTP 403
Permission denied to create
Resolution: The user does not have permission to upload files to ZFS. Contact your system administrator. - INTERNAL_ERRORHTTP 500
Internal Server Error
Resolution: Unexpected and unhandled exception in Server. Contact support team. - INVALID_REQUEST_METHODHTTP 400
The http request method type is not a valid one
Resolution: You have specified an invalid HTTP method to access the API URL. Specify a valid request method. Refer to endpoints section above. - AUTHORIZATION_FAILEDHTTP 400
User does not have sufficient privilege to create.
Resolution: The user does not have the permission to add files to ZFS. Contact your system administrator.
The maximum size of each attachment is 20MB.
Sample Response
Copied{
"data": [
{
"code": "SUCCESS",
"details": {
"name": "connections.txt",
"id": "2cceafaxxxxxxxc065186"
},
"message": "connections.txt uploaded Succeessfully",
"status": "success"
},
{
"code": "SUCCESS",
"details": {
"name": "enable-signals.png",
"id": "2ccxxxxxxxxxxxb89e051a"
},
"message": "enable-signals.png uploaded Succeessfully",
"status": "success"
}
]
}