Modify documents

When editing a document, you must work with its master version.
To modify a document, perform the following:

  1. Get the master version.
    Get the master version of the document. When you modify a document, you must not work on its live version.

  2. Get a temp version.
    Check out the master version to get a temp version of the document.

  3. Modify the temp version.
    Set the properties of the temp version to the new values. You can also upload new document data.

  4. Update the master version.
    To transfer the changes to the master version, check in the temp version .

  5. Update the live version.
    To transfer the changes to the live version, publish the master version .

EXAMPLE: Modify a document by the ID of its master version.
The example below shows how to modify a document by the ID of its master version. For more information about working with the ID of the live version, see For developers: Edit content and For developers: Content lifecycle.
The following code modifies a document by the ID of its master version.

Native API

using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text.RegularExpressions;
using Telerik.Sitefinity.Libraries.Model;
using Telerik.Sitefinity.Modules.Libraries;
using Telerik.Sitefinity.Workflow;
namespace Telerik.Sitefinity.Documentation.CodeSnippets.DevGuide.SitefinityEssentials.Modules.MediaModules.DocumentsAndFiles.ManagingDocuments
{
public partial class DocumentsSnippets
{
public static void ModifyDocumentNativeAPI(Guid masterDocumentId, string newTitle, Stream documentStream, string documentFileName, string documentExtension)
{
LibrariesManager librariesManager = LibrariesManager.GetManager();
//Get the master version.
Document master = librariesManager.GetDocuments().Where(d => d.Id == masterDocumentId).FirstOrDefault();
if (master != null)
{
//Check out the master to get a temp version.
Document temp = librariesManager.Lifecycle.CheckOut(master) as Document;
//Make the modifications to the temp version.
temp.Title = newTitle;
temp.LastModified = DateTime.UtcNow;
temp.Urls.Clear();
temp.UrlName = Regex.Replace(newTitle.ToLower(), @"[^\w\-\!\$\'\(\)\=\@\d_]+", "-");
temp.MediaFileUrlName = Regex.Replace(documentFileName.ToLower(), @"[^\w\-\!\$\'\(\)\=\@\d_]+", "-");
librariesManager.Upload(temp, documentStream, documentExtension);
//Recompiles and validates the url of the document.
librariesManager.RecompileAndValidateUrls(temp);
//Checkin the temp and get the updated master version.
//After the check in the temp version is deleted.
master = librariesManager.Lifecycle.CheckIn(temp) as Document;
librariesManager.SaveChanges();
//Publish the document.
var bag = new Dictionary<string, string>();
bag.Add("ContentType", typeof(Document).FullName);
WorkflowManager.MessageWorkflow(masterDocumentId, typeof(Document), null, "Publish", false, bag);
}
}
}
}

First, you get an instance of the LibrariesManager class. Then, you get the master version with the corresponding ID. Then, to get a temp version of the document, you call Lifecycle.CheckOut with the master version as an argument. You make all the modifications to the temp version. In this example, you update the title of the document and its URL and upload new document data. Then, to transfer the changes to the master version, you call Lifecycle.CheckIn with the temp version as an argument. By default, when calling the CheckIn method the temp version gets deleted. To persist the changes, you call SaveChanges. Finally, to publish the master version, you call the MessageWorkflow method of the WorkflowManager class and pass the required parameters.

Fluent API

using System;
using System.Collections.Generic;
using System.IO;
using System.Text.RegularExpressions;
using Telerik.Sitefinity.Libraries.Model;
using Telerik.Sitefinity.Workflow;
namespace Telerik.Sitefinity.Documentation.CodeSnippets.DevGuide.SitefinityEssentials.Modules.MediaModules.DocumentsAndFiles.ManagingDocuments
{
public partial class DocumentsSnippets
{
public static void ModifyDocumentFluentAPI(Guid masterDocumentId, string newTitle, Stream documentStream, string documentFileName, string documentExtension)
{
var count = 0;
App.WorkWith().Documents().Where(i => i.Id == masterDocumentId).Count(out count);
if (count > 0)
{
App.WorkWith().Document(masterDocumentId).CheckOut().Do(document =>
{
document.Title = newTitle;
document.LastModified = DateTime.UtcNow;
document.Urls.Clear();
document.UrlName = Regex.Replace(newTitle.ToLower(), @"[^\w\-\!\$\'\(\)\=\@\d_]+", "-");
document.MediaFileUrlName = Regex.Replace(documentFileName.ToLower(), @"[^\w\-\!\$\'\(\)\=\@\d_]+", "-");
}).UploadContent(documentStream, documentExtension).CheckIn().Publish().SaveChanges();
}
}
}
}

First, you check whether a document with the specified ID exists. Then, you get the singular document facade of the master version with the specified ID. Then, to get the facade for the temp version, you call the CheckOut method. You make all the modifications in the Do method of the temp facade. In this example, you update the title of the document and its URL. To upload new document data, you call the UploadContent and pass the data as an argument. Then, to transfer the changes to the master version of the item, you call CheckIn. To save the changes, you call SaveChanges. Finally, to publish the document, you call the MessageWorkflow method of the WorkflowManager class and pass the required parameters.

Increase your Sitefinity skills by signing up for our free trainings. Get Sitefinity-certified at Progress Education Community to boost your credentials.

Get started with Integration Hub | Sitefinity Cloud | Sitefinity SaaS

This free lesson teaches administrators, marketers, and other business professionals how to use the Integration hub service to create automated workflows between Sitefinity and other business systems.

Web Security for Sitefinity Administrators

This free lesson teaches administrators the basics about protecting yor Sitefinity instance and its sites from external threats. Configure HTTPS, SSL, allow lists for trusted sites, and cookie security, among others.

Foundations of Sitefinity ASP.NET Core Development

The free on-demand video course teaches developers how to use Sitefinity .NET Core and leverage its decoupled architecture and new way of coding against the platform.

Was this article helpful?

Next article

Delete documents