Introduction
In this series of articles, you will learn all the list operations performed on the SharePoint online site, using PnP Core Client Side Object Model (CSOM) libraries.
This article is part two of the series. In this article, we will learn the following -
- How to check if the list exists
- Create a list,
- Set user permissions, and
- Enable versioning
In my previous article, I have explained about PnP Core CSOM library and how it can be imported to Visual Studio Console application solution to run the samples.
Let's get started.
Check if the list exists
ListExists method is used to check whether the SharePoint list is already available on the site on not. The steps involved are,
- Input the site details, user details for authentication, and list name
- Authenticate and get the client context of the site.
- Check if the list exists, by using ListExists method with the list name
- Output the result on the console.
The following code snippet shows the operation.
-
- string siteUrl = "https://nakkeerann.sharepoint.com";
- string userName = "[email protected]";
- string password = "***";
-
-
- AuthenticationManager authManager = new AuthenticationManager();
-
- try
- {
-
-
- using (var clientContext = authManager.GetSharePointOnlineAuthenticatedContextTenant(siteUrl, userName, password))
- {
-
- string listName = "TestList";
-
- bool listExists = clientContext.Site.RootWeb.ListExists(listName);
- if (listExists)
- {
- Console.WriteLine("List is available on the site");
- }
- else
- {
- Console.WriteLine("List is not available on the site");
- }
- Console.ReadKey();
- }
- }
- catch (Exception ex)
- {
- Console.WriteLine("Error Message: " + ex.Message);
- Console.ReadKey();
- }
Create List
The list can be created, using PnP Core CSOM library. Once the client context is set, a single line of query execution helps create a list, rather than a traditional CSOM approach. The steps involved are,
- Input the site detail, user details for authentication, list name, and list template.
- Authenticate and get the client context of the site.
- Create the list using CreateList method with above input parameters.
- Output the result on the console.
The following code snippet help create a list.
-
- string siteUrl = "https://nakkeerann.sharepoint.com";
- string userName = "[email protected]";
- string password = "***";
-
-
- AuthenticationManager authManager = new AuthenticationManager();
-
- try
- {
-
-
- using (var clientContext = authManager.GetSharePointOnlineAuthenticatedContextTenant(siteUrl, userName, password))
- {
-
- ListTemplateType listTemplate = ListTemplateType.GenericList;
-
- string listName = "TestList";
-
- bool enableVersioning = false;
-
- List list = clientContext.Site.RootWeb.CreateList(listTemplate, listName, enableVersioning);
-
- Console.WriteLine("The list has been created.");
- Console.WriteLine("List Name : " + list.Title);
- Console.ReadKey();
- }
- }
- catch (Exception ex)
- {
- Console.WriteLine("Error Message: " + ex.Message);
- Console.ReadKey();
- }
Set List Permissions
The permissions can be granted to a list, using PnP Core CSOM library. The user or group will be provided the access with necessary permissions. The steps involved are,
- Input the site detail, user details for authentication, and list name.
- Authenticate and get the client context of the site.
- Get the list instance, using list name.
- Provide the permissions, using SetListPermission method using list object, user/group, permission type.
- Output the result on the console.
The following code snippet shows the list permissions update operations, using PnP core CSOM.
-
- string siteUrl = "https://nakkeerann.sharepoint.com";
- string userName = "[email protected]";
- string password = "***";
-
-
- AuthenticationManager authManager = new AuthenticationManager();
-
- try
- {
-
-
- using (var clientContext = authManager.GetSharePointOnlineAuthenticatedContextTenant(siteUrl, userName, password))
- {
-
- string listName = "TestList";
-
- List list = clientContext.Site.RootWeb.GetListByTitle(listName);
-
- list.SetListPermission(OfficeDevPnP.Core.Enums.BuiltInIdentity.Everyone, RoleType.Editor);
-
- Console.WriteLine("Provided permission");
- Console.ReadKey();
- }
- }
- catch (Exception ex)
- {
- Console.WriteLine("Error Message: " + ex.Message);
- Console.ReadKey();
- }
Enable List Versioning
The versioning for the list can be enabled or disabled using the update operation on PnP Core CSOM library. The steps involved are,
- Input the site detail, user details for authentication, and list name.
- Authenticate and get the client context of the site.
- Get the list instance, using list name.
- Change the versioning using UpdateListVersioning method with necessary boolean values.
- Output the result on the console.
The following code snippet shows the list version update operation, using PnP core CSOM.
-
- string siteUrl = "https://nakkeerann.sharepoint.com";
- string userName = "[email protected]";
- string password = "***";
-
-
- AuthenticationManager authManager = new AuthenticationManager();
-
- try
- {
-
-
- using (var clientContext = authManager.GetSharePointOnlineAuthenticatedContextTenant(siteUrl, userName, password))
- {
-
- string listName = "TestList";
-
- List list = clientContext.Site.RootWeb.GetListByTitle(listName);
-
- bool enableVersioning = true;
- bool enableMinorVersioning = false;
- bool updateQuery = true;
-
- list.UpdateListVersioning(enableVersioning, enableMinorVersioning, updateQuery);
-
- Console.WriteLine("Versioning enabled");
- Console.ReadKey();
- }
- }
- catch (Exception ex)
- {
- Console.WriteLine("Error Message: " + ex.Message);
- Console.ReadKey();
- }
Summary
Thus, you have learned how to perform basic list operations like creation, updating of permission/version, and checking if a list already exists, using PnP Core CSOM library. This article shows the basic operations. The complex logic can be built with the help of requirements.