This page focuses on creating objects using the REST API. Details on creating objects using the COM API can be found in the dedicated page.
To create an object via the M-Files Web Service, make a POST request to /objects/(type). This endpoint takes an ObjectCreationInfo containing information for the new object and returns an ObjectVersion representing the newly-created object.
The examples below are written in C# and use objects from the downloadable code samples, which contains an MFWSStructs.cs file. This file contains structures that mimic the JSON structures expected by the M-Files Web Service. These are used to simplify the creation of objects, but are not directly required for use with the Web Service. Note the bug mentioned in the tips and tricks section below.
The code below uses JSON.NET to serialize and deserialize objects into JSON strings. This library is used simply to keep the code below as clean as possible, and is not required to use the M-Files Web Service. Some samples in the official documentation use the built-in DataContractJsonSerializer class, but this can have issues with JSON-formatted dates.
To create a non-document object, execute a POST request to /objects/(type) with the property values for the new object.
The sample code includes a dummy authentication token. For more information on authentication, see Authentication.
// Create a HttpClient. var client = new System.Net.Http.HttpClient(); // Authenticate using a token that we already have (not shown here). client.DefaultRequestHeaders.Add("X-Authentication", "DummyAuthenticationToken"); // Build up information for the new object. // Note: all mandatory properties must be set, but this is likely to be, at a minimum, // the class (property 100) and the name or title (typically property 0). var objectCreationInfo = new ObjectCreationInfo() PropertyValues = new [] new PropertyValue() PropertyDef = 100, // The built-in "Class" property Id. TypedValue = new TypedValue() DataType = MFDataType.Lookup, Lookup = new Lookup() Item = 1, // The built-in "Other Document" class Id. Version = -1 // Work around the bug detailed below. > > >, new PropertyValue() PropertyDef = 0, // The built-in "Name or Title" property Id. TypedValue = new TypedValue() DataType = MFDataType.Text, Value = "my test document" > > > >; // Serialise using JSON.NET (use Nuget to add a reference if needed). var stringContent = Newtonsoft.Json.JsonConvert.SerializeObject(objectCreationInfo); // Create the content for the web request. var content = new System.Net.Http.StringContent(stringContent, Encoding.UTF8, "application/json"); // We are creating a document (multi-file-document with no files). const int documentObjectTypeId = 0; // // Execute the POST. // NOTE: http://developer.m-files.com/APIs/REST-API/#iis-compatibility var httpResponseMessage = await client.PostAsync(new Uri("http://localhost/REST/objects/" + documentObjectTypeId + ".aspx"), content); // Extract the value. var objectVersion = Newtonsoft.Json.JsonConvert.DeserializeObjectObjectVersion>(await httpResponseMessage.Content.ReadAsStringAsync()); // Output the response. System.Console.WriteLine("New object Id was: " + objectVersion.ObjVer.ID);
The default “Name or Title” property always has the property Id of zero. However, each class may have the property used for the name or title altered during setup. Ensure that the property values sent match the expected properties from the class.
POST http://localhost/REST/objects/0.aspx HTTP/1.1 X-Authentication: DummyAuthenticationToken Content-Type: application/json; charset=utf-8 Host: localhost Cookie: ASP.NET_SessionId=3a2wrpaqv42g1qysstp5nmdz Content-Length: 451 Expect: 100-continue < "PropertyValues": [ < "PropertyDef": 100, "TypedValue": < "DataType": 9, "HasValue": false, "Value": null, "Lookup": < "Deleted": false, "DisplayValue": null, "Hidden": false, "Item": 1, "Version": -1 >, "Lookups": null, "DisplayValue": null, "SortingKey": null, "SerializedValue": null > >, < "PropertyDef": 0, "TypedValue": < "DataType": 1, "HasValue": false, "Value": "my test document", "Lookup": null, "Lookups": null, "DisplayValue": null, "SortingKey": null, "SerializedValue": null >> ], "Files": null >
HTTP/1.1 200 OK Cache-Control: private, must-revalidate, max-age=0 Content-Type: application/json; charset=utf-8 Expires: Wed, 25 Jan 2017 09:44:34 GMT X-Frame-Options: SAMEORIGIN X-Content-Type-Options: nosniff Strict-Transport-Security: max-age=31536000; includeSubDomains; Date: Fri, 26 Jan 2018 09:44:34 GMT < "Title": "my test document", "EscapedTitleWithID": "my test document (ID 659)", "DisplayID": "659", "ObjVer": < "Version": 1, "VersionType": 4, "ID": 659, "Type": 0 >, "Class": 1, "CheckedOutAtUtc": "1601-01-01T00:00:00Z", "CheckedOutAt": "1601-01-01T00:00:00Z", "LastModifiedUtc": "2018-01-26T09:44:33Z", "LastModified": "2018-01-26T09:44:33Z", "ObjectCheckedOut": false, "ObjectCheckedOutToThisUser": false, "CheckedOutTo": 0, "SingleFile": false, "ThisVersionLatestToThisUser": true, "CreatedUtc": "2018-01-26T09:44:33Z", "Created": "2018-01-26T09:44:33Z", "Files": [ ], "VisibleAfterOperation": true, "PathInIDView": "0\\0-999\\659\\S\\v1", "LastModifiedDisplayValue": "26.1.2018 9.44", "CheckedOutAtDisplayValue": "1.1.1601 0.00", "CreatedDisplayValue": "26.1.2018 9.44", "ObjectVersionFlags": 0, "Score": 0, "LastAccessedByMe": "2018-01-26T09:44:34Z", "AccessedByMeUtc": "2018-01-26T09:44:34Z", "AccessedByMe": "2018-01-26T09:44:34Z", "ObjectGUID": "", "ObjectCapabilityFlags": -1, "ObjectFlags": 68, "propertyID": 0, "BaseProperties": [ ] >
To create an object with files, the file content must first be POST ed to /files. The file will be saved into a temporary location on the server and an UploadInfo returned containing an ID for the temporary file. During the file creation, these UploadInfo objects are provided as part of the ObjectCreationInfo and the server automatically attaches the temporary files to the new object.
// Create a HttpClient. var client = new System.Net.Http.HttpClient(); // Authenticate. client.DefaultRequestHeaders.Add("X-Authentication", "DummyAuthenticationToken"); // Which file do we need to upload? var localFileToUpload = new System.IO.FileInfo(@"C:\temp\test.txt"); // Upload the file and retrieve the upload information. // NOTE: http://developer.m-files.com/APIs/REST-API/#iis-compatibility var uploadFileResponse = await client.PostAsync(new Uri("http://localhost/REST/files.aspx"), new System.Net.Http.StreamContent(localFileToUpload.OpenRead())); // Extract the value. var uploadInfo = Newtonsoft.Json.JsonConvert.DeserializeObjectUploadInfo>( await uploadFileResponse.Content.ReadAsStringAsync()); // Ensure the extension is set. // NOTE: This must be without the dot! uploadInfo.Extension = localFileToUpload.Extension.Substring(1); // Add the upload to the objectCreationInfo. var objectCreationInfo = new ObjectCreationInfo() PropertyValues = new PropertyValue[] // . > >; objectCreationInfo.Files = new UploadInfo[] uploadInfo >;
POST http://localhost/REST/files.aspx HTTP/1.1 X-Authentication: DummyAuthenticationToken Host: localhost Cookie: ASP.NET_SessionId=tsxugyihuwdyj4vtzalt34je Content-Length: 27 Expect: 100-continue This is my sample text file
HTTP/1.1 200 OK Cache-Control: private, must-revalidate, max-age=0 Content-Type: application/json; charset=utf-8 Expires: Wed, 25 Jan 2017 10:04:26 GMT X-Frame-Options: SAMEORIGIN X-Content-Type-Options: nosniff Strict-Transport-Security: max-age=31536000; includeSubDomains; Date: Fri, 26 Jan 2018 10:04:26 GMT Content-Length: 48
After a file is uploaded to /files, an UploadInfo will be returned containing the temporary upload given to the file. If the Extension property on this object is not correctly set (manually, as above) before creating the new object, then the file will not have an extension when it is saved into M-Files.
// Create a HttpClient. var client = new System.Net.Http.HttpClient(); // Authenticate. client.DefaultRequestHeaders.Add("X-Authentication", "DummyAuthenticationToken"); // Build up information for the new object. var objectCreationInfo = new ObjectCreationInfo() PropertyValues = new[] new PropertyValue() PropertyDef = 100, // The built-in "Class" property Id. TypedValue = new TypedValue() DataType = MFDataType.Lookup, Lookup = new Lookup() Item = 1, // The built-in "Other Document" class Id. Version = -1 // Work around the bug detailed below. > > >, new PropertyValue() PropertyDef = 0, // The built-in "Name or Title" property Id. TypedValue = new TypedValue() DataType = MFDataType.Text, Value = "my test document" > > > >; // Which file do we need to upload? var localFileToUpload = new System.IO.FileInfo(@"C:\temp\test.txt"); // Upload the file and retrieve the upload information. // NOTE: http://developer.m-files.com/APIs/REST-API/#iis-compatibility var uploadFileResponse = await client.PostAsync(new Uri("http://localhost/REST/files.aspx"), new System.Net.Http.StreamContent(localFileToUpload.OpenRead())); // Extract the value. var uploadInfo = Newtonsoft.Json.JsonConvert.DeserializeObjectUploadInfo>( await uploadFileResponse.Content.ReadAsStringAsync()); // Ensure the extension is set. // NOTE: This must be without the dot! uploadInfo.Extension = localFileToUpload.Extension.Substring(1); // Add the upload to the objectCreationInfo. objectCreationInfo.Files = new[] uploadInfo >; // What type of object are we creating? const int documentObjectTypeId = 0; // Execute the post. // NOTE: http://developer.m-files.com/APIs/REST-API/#iis-compatibility var createObjectResponse = await client.PostAsync(new Uri("http://localhost/REST/objects/" + documentObjectTypeId + ".aspx"), new System.Net.Http.StringContent(Newtonsoft.Json.JsonConvert.SerializeObject(objectCreationInfo), Encoding.UTF8, "application/json")); // Extract the value. var objectVersion = Newtonsoft.Json.JsonConvert.DeserializeObjectObjectVersion>( await createObjectResponse.Content.ReadAsStringAsync()); // Output the response. System.Console.WriteLine("New object Id was: " + objectVersion.ObjVer.ID);
This shows the HTTP request for the object creation, assuming the file(s) have already been uploaded.
POST http://localhost/REST/objects/0.aspx HTTP/1.1 X-Authentication: DummyAuthenticationToken Content-Type: application/json; charset=utf-8 Host: localhost Cookie: ASP.NET_SessionId=tsxugyihuwdyj4vtzalt34je Content-Length: 504 Expect: 100-continue < "PropertyValues": [ < "PropertyDef": 100, "TypedValue": < "DataType": 9, "HasValue": false, "Value": null, "Lookup": < "Deleted": false, "DisplayValue": null, "Hidden": false, "Item": 1, "Version": -1 >, "Lookups": null, "DisplayValue": null, "SortingKey": null, "SerializedValue": null > >, < "PropertyDef": 0, "TypedValue": < "DataType": 1, "HasValue": false, "Value": "my test document", "Lookup": null, "Lookups": null, "DisplayValue": null, "SortingKey": null, "SerializedValue": null >> ], "Files": [ < "UploadID": 1, "Title": null, "Extension": "txt", "Size": 27 >] >
This shows the HTTP response for the object creation, assuming the file(s) have already been uploaded.
HTTP/1.1 200 OK Cache-Control: private, must-revalidate, max-age=0 Content-Type: application/json; charset=utf-8 Expires: Wed, 25 Jan 2017 10:04:27 GMT X-Frame-Options: SAMEORIGIN X-Content-Type-Options: nosniff Strict-Transport-Security: max-age=31536000; includeSubDomains; Date: Fri, 26 Jan 2018 10:04:26 GMT Content-Length: 1435 < "Title": "my test document", "EscapedTitleWithID": "my test document (ID 663).txt", "DisplayID": "663", "ObjVer": < "Version": 1, "VersionType": 4, "ID": 663, "Type": 0 >, "Class": 1, "CheckedOutAtUtc": "1601-01-01T00:00:00Z", "CheckedOutAt": "1601-01-01T00:00:00Z", "LastModifiedUtc": "2018-01-26T10:04:26Z", "LastModified": "2018-01-26T10:04:26Z", "ObjectCheckedOut": false, "ObjectCheckedOutToThisUser": false, "CheckedOutTo": 0, "SingleFile": true, "ThisVersionLatestToThisUser": true, "CreatedUtc": "2018-01-26T10:04:26Z", "Created": "2018-01-26T10:04:26Z", "Files": [ < "Name": "my test document", "EscapedName": "my test document.txt", "Extension": "txt", "Size": 27, "LastModified": "2018-01-26T10:04:26Z", "ChangeTimeUtc": "2018-01-26T10:04:26Z", "ChangeTime": "2018-01-26T10:04:26Z", "CreatedUtc": "2018-01-26T10:04:26Z", "CreatedDisplayValue": "26.1.2018 10.04", "LastModifiedDisplayValue": "26.1.2018 10.04", "FileGUID": "", "ID": 678, "Version": 1, "FileVersionType": 3 > ], "VisibleAfterOperation": true, "PathInIDView": "0\\0-999\\663\\S\\v1", "LastModifiedDisplayValue": "26.1.2018 10.04", "CheckedOutAtDisplayValue": "1.1.1601 0.00", "CreatedDisplayValue": "26.1.2018 10.04", "ObjectVersionFlags": 0, "Score": 0, "LastAccessedByMe": "2018-01-26T10:04:26Z", "AccessedByMeUtc": "2018-01-26T10:04:26Z", "AccessedByMe": "2018-01-26T10:04:26Z", "ObjectGUID": "", "ObjectCapabilityFlags": -1, "ObjectFlags": 68, "propertyID": 0, "BaseProperties": [] >
/// /// Based on M-Files API. /// public class Lookup /// /// Based on M-Files API. /// public bool Deleted get; set; > /// /// Based on M-Files API. /// public string DisplayValue get; set; > /// /// Based on M-Files API. /// public bool Hidden get; set; > /// /// Based on M-Files API. /// public int Item get; set; > /// /// Based on M-Files API. /// public int? Version get; set; > >