In this blog, I am going to perform two actions -
- Identify if a page is a modern page or not.
- Migrate or copy that modern page (including its content) to another site collection or site (destination location)
I am going to accomplish these tasks by using CSOM (Client Object Model). After identifying the modern page, I will copy the modern page into another site collection (destination location) and then, will migrate all the page contents of this modern page (including web parts and other properties of source modern page) to a destination web using CSOM.
We are using a console application to achieve the above functionality using CSOM. In the below-mentioned code logic, we will get all pages from ‘Site Pages’ page library which is present in the source web and looping each page to check if that is a modern page or not.
If the page is found to be a modern page, then we are migrating that page to the destination web ‘Site Pages’ library.
Please have a look at the below code. The code is self-explanatory because of the comments.
- using System;
- using System.Net;
- using System.Security;
- using System.Text.RegularExpressions;
- using Microsoft.SharePoint.Client;
- namespace ConsoleApp1 {
- class Program {
- static void Main(string[] args) {
- ClientContext sourceContext = null;
- List sourceList = null;
- ListItemCollection srcItemCollection = null;
- ListItem sourceItem = null;
- string userName = string.Empty;
- string password = string.Empty;
- SecureString srcSiteSecurePassword = new SecureString();
- SharePointOnlineCredentials sourceOnlineCredentials = null;
- try {
- using(sourceContext = new ClientContext("http://sourcesiteurl")) {
- userName = "TestUser";
- password = "Password";
- if (!string.IsNullOrEmpty(password)) {
- foreach(char c in password.ToCharArray())
- srcSiteSecurePassword.AppendChar(c);
- }
-
- sourceOnlineCredentials = new SharePointOnlineCredentials(userName, srcSiteSecurePassword);
- sourceContext.Credentials = sourceOnlineCredentials;
- sourceContext.Load(sourceContext.Web);
- sourceContext.ExecuteQuery();
-
- sourceList = sourceContext.Web.Lists.GetByTitle("Site Pages");
-
- srcItemCollection = sourceList.GetItems(CamlQuery.CreateAllItemsQuery());
-
- sourceContext.Load(srcItemCollection, IC => IC.Include(I => I.Id, I => I.DisplayName));
- sourceContext.ExecuteQuery();
- if (srcItemCollection != null && srcItemCollection.Count > 0) {
- for (int iCount = 0; iCount < srcItemCollection.Count; iCount++) {
- try {
- sourceItem = srcItemCollection[iCount];
-
- if (IsModernPage(sourceContext, sourceItem)) {
-
- MigrateModernPageToAnotherWeb(sourceContext, sourceItem);
- }
- } catch (Exception ex) {}
- }
- }
- }
- } catch (Exception ex) {}
- }
-
- private static bool IsModernPage(ClientContext sourceContext, ListItem sourceItem) {
- bool isModernPage = false;
- try {
- sourceContext.Load(sourceItem, srcItm => srcItm["CanvasContent1"], srcItm => srcItm["LayoutWebpartsContent"]);
- sourceContext.ExecuteQuery();
-
- if (!string.IsNullOrEmpty(sourceItem["CanvasContent1"].ToString()) || !string.IsNullOrEmpty(sourceItem["LayoutWebpartsContent"].ToString())) isModernPage = true;
- } catch {
- isModernPage = false;
- }
- return isModernPage;
- }
-
- private static void MigrateModernPageToAnotherWeb(ClientContext sourceContext, ListItem sourceItem) {
- ClientContext destSiteContext = null;
- List destList = null;
- ListItem destItem = null;
- string userName = string.Empty;
- string password = string.Empty;
- SecureString destSiteSecurePassword = new SecureString();
- SharePointOnlineCredentials destOnlineCredentials = null;
- string canvasContent = string.Empty;
- string metaInfo = string.Empty;
- string layoutWebpartsContent = string.Empty;
- try {
- using(destSiteContext = new ClientContext("http://destinationsiteurl")) {
- userName = "TestUser";
- password = "Password";
- if (!string.IsNullOrEmpty(password)) {
- foreach(char c in password.ToCharArray())
- destSiteSecurePassword.AppendChar(c);
- }
-
- destOnlineCredentials = new SharePointOnlineCredentials(userName, destSiteSecurePassword);
- destSiteContext.Credentials = destOnlineCredentials;
- destSiteContext.Load(destSiteContext.Web);
- destSiteContext.ExecuteQuery();
-
- destList = destSiteContext.Web.Lists.GetByTitle("Site Pages");
-
- destSiteContext.Load(destList, L => L.RootFolder.ServerRelativeUrl);
- destSiteContext.ExecuteQuery();
-
- destItem = destList.RootFolder.Files.AddTemplateFile(destList.RootFolder.ServerRelativeUrl.TrimEnd('/') + "/" + sourceItem.DisplayName + ".aspx", TemplateFileType.ClientSidePage).ListItemAllFields;
- destSiteContext.Load(destItem);
- destSiteContext.ExecuteQuery();
-
- sourceContext.Load(sourceItem, i => i.ContentType.Id, i => i["CanvasContent1"], i => i["MetaInfo"], i => i["LayoutWebpartsContent"]);
- sourceContext.ExecuteQuery();
- try {
- destItem["ContentTypeId"] = sourceItem.ContentType.Id.ToString();
- canvasContent = sourceItem["CanvasContent1"].ToString();
-
- if (!string.IsNullOrEmpty(canvasContent) && canvasContent.Length > 0 && canvasContent.ToLower().Contains(sourceContext.Web.Id.ToString().ToLower())) canvasContent = Regex.Replace(canvasContent, sourceContext.Web.Id.ToString(), destSiteContext.Web.Id.ToString(), RegexOptions.IgnoreCase);
- } catch (Exception ex) {}
- try {
- metaInfo = sourceItem["MetaInfo"].ToString();
-
- if (!string.IsNullOrEmpty(metaInfo) && metaInfo.Length > 0 && metaInfo.ToLower().Contains(sourceContext.Web.Id.ToString().ToLower())) metaInfo = Regex.Replace(metaInfo, sourceContext.Web.Id.ToString(), destSiteContext.Web.Id.ToString(), RegexOptions.IgnoreCase);
- } catch (Exception ex) {}
- try {
- layoutWebpartsContent = sourceItem["LayoutWebpartsContent"].ToString();
-
- if (!string.IsNullOrEmpty(layoutWebpartsContent) && layoutWebpartsContent.Length > 0 && layoutWebpartsContent.ToLower().Contains(sourceContext.Web.Id.ToString().ToLower())) layoutWebpartsContent = Regex.Replace(layoutWebpartsContent, sourceContext.Web.Id.ToString(), destSiteContext.Web.Id.ToString(), RegexOptions.IgnoreCase);
- } catch (Exception ex) {}
-
- if (!string.IsNullOrEmpty(canvasContent) && canvasContent.Length > 0) destItem["CanvasContent1"] = canvasContent;
-
- if (!string.IsNullOrEmpty(metaInfo) && metaInfo.Length > 0) destItem["MetaInfo"] = metaInfo;
-
- if (!string.IsNullOrEmpty(layoutWebpartsContent) && layoutWebpartsContent.Length > 0) destItem["LayoutWebpartsContent"] = layoutWebpartsContent;
-
- destItem.Update();
- destSiteContext.ExecuteQuery();
- }
- } catch (Exception ex) {}
- }
- }
- }
Destination Page Library Before Migration,
Destination Page Library after Migration
After executing the above code behind, you can find the newly created modern page in the destination web 'Site Pages' library with the same page contents and "web parts" as they were in the source page.