Changes returned when folder deleted using ChangeQuery and GetChanges in CSOM

%3CLINGO-SUB%20id%3D%22lingo-sub-1518324%22%20slang%3D%22en-US%22%3EChanges%20returned%20when%20folder%20deleted%20using%20ChangeQuery%20and%20GetChanges%20in%20CSOM%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-1518324%22%20slang%3D%22en-US%22%3E%3CP%3EHave%20a%20folder%20in%20a%20SharePoint%20Document%20Library%20that%20has%203%20files%20in%20it.%3C%2FP%3E%3CP%3E%26nbsp%3B%3C%2FP%3E%3CP%3EWhen%20I%20delete%20the%20folder%2C%20I'm%20getting%20one%20change%20returned%20in%20the%20GetChanges%20function.%20It%20is%20a%20ChangeItem%20related%20to%20the%20deleted%20folder%2C%20but%20I%20don't%20get%20any%20changes%20returned%20for%20the%20files%20in%20the%20folder.%3C%2FP%3E%3CP%3E%26nbsp%3B%3C%2FP%3E%3CP%3EIs%20this%20correct%3F%3C%2FP%3E%3CP%3EI'm%20sure%20in%20the%20past%20I%20used%20to%20get%20the%20files%20that%20have%20been%20deleted%20too%2C%20but%20unable%20to%20confirm.%3C%2FP%3E%3CP%3E%26nbsp%3B%3C%2FP%3E%3CP%3EThis%20is%20the%20code%20I'm%20using%20currently.%3C%2FP%3E%3CP%3E%26nbsp%3B%3C%2FP%3E%3CP%3EHave%20tried%20at%20different%20scopes%20to%20(i.e.%20changes%20at%20Library%2C%20Root%20Folder%20etc.)%3C%2FP%3E%3CP%3E%26nbsp%3B%3C%2FP%3E%3CPRE%20class%3D%22lia-code-sample%20language-csharp%22%3E%3CCODE%3Eusing%20(var%20authenticationManager%20%3D%20new%20AuthenticationManager())%0Ausing%20(var%20context%20%3D%20authenticationManager.GetContext(siteUri))%0A%7B%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20var%20site%20%3D%20context.Site%3B%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20context.Load(site)%3B%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20var%20query%20%3D%20new%20ChangeQuery(true%2C%20true)%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%7B%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20File%20%3D%20true%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20Item%20%3D%20true%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20Folder%20%3D%20true%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20RecursiveAll%20%3D%20true%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20DeleteObject%20%3D%20true%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20Rename%20%3D%20false%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20Add%20%3D%20false%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20Update%20%3D%20false%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20Site%20%3D%20false%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20Web%20%3D%20false%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20List%20%3D%20false%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20User%20%3D%20false%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20View%20%3D%20false%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20SystemUpdate%20%3D%20false%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%7D%3B%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20var%20changes%20%3D%20site.GetChanges(query)%3B%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20context.Load(changes)%3B%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20await%20context.ExecuteQueryAsync()%3B%0A%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20foreach%20(Change%20change%20in%20changes)%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%7B%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20if%20(change%20is%20Microsoft.SharePoint.Client.ChangeItem)%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%7B%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20ChangeItem%20ci%20%3D%20change%20as%20ChangeItem%3B%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20Console.WriteLine(%24%22Item%20%7Bci.ItemId.ToString()%7D%3A%20%7Bci.ChangeType.ToString()%7D%22)%3B%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%7D%0A%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20if%20(change%20is%20Microsoft.SharePoint.Client.ChangeFolder)%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%7B%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20ChangeFolder%20cf%20%3D%20change%20as%20ChangeFolder%3B%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20Console.WriteLine(%24%22Folder%20%7Bcf.UniqueId.ToString()%7D%3A%20%7Bcf.ChangeType.ToString()%7D%22)%3B%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%7D%0A%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20if%20(change%20is%20Microsoft.SharePoint.Client.ChangeFile)%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%7B%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20ChangeFile%20cf%20%3D%20change%20as%20ChangeFile%3B%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20Console.WriteLine(%24%22Folder%20%7Bcf.UniqueId.ToString()%7D%3A%20%7Bcf.ChangeType.ToString()%7D%22)%3B%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%7D%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%7D%0A%20%20%20%20%20%20%20%20%20%20%20%20%7D%3C%2FCODE%3E%3C%2FPRE%3E%3CP%3E%26nbsp%3B%3C%2FP%3E%3C%2FLINGO-BODY%3E
Contributor

Have a folder in a SharePoint Document Library that has 3 files in it.

 

When I delete the folder, I'm getting one change returned in the GetChanges function. It is a ChangeItem related to the deleted folder, but I don't get any changes returned for the files in the folder.

 

Is this correct?

I'm sure in the past I used to get the files that have been deleted too, but unable to confirm.

 

This is the code I'm using currently.

 

Have tried at different scopes to (i.e. changes at Library, Root Folder etc.)

 

using (var authenticationManager = new AuthenticationManager())
using (var context = authenticationManager.GetContext(siteUri))
{
                var site = context.Site;
                context.Load(site);
                var query = new ChangeQuery(true, true)
                {
                    File = true,
                    Item = true,
                    Folder = true,
                    RecursiveAll = true,
                    DeleteObject = true,
                    Rename = false,
                    Add = false,
                    Update = false,
                    Site = false,
                    Web = false,
                    List = false,
                    User = false,
                    View = false,
                    SystemUpdate = false,
                };
                
                var changes = site.GetChanges(query);
                context.Load(changes);
                await context.ExecuteQueryAsync();

                foreach (Change change in changes)
                {
                    if (change is Microsoft.SharePoint.Client.ChangeItem)
                    {
                        ChangeItem ci = change as ChangeItem;
                        Console.WriteLine($"Item {ci.ItemId.ToString()}: {ci.ChangeType.ToString()}");
                    }

                    if (change is Microsoft.SharePoint.Client.ChangeFolder)
                    {
                        ChangeFolder cf = change as ChangeFolder;
                        Console.WriteLine($"Folder {cf.UniqueId.ToString()}: {cf.ChangeType.ToString()}");
                    }

                    if (change is Microsoft.SharePoint.Client.ChangeFile)
                    {
                        ChangeFile cf = change as ChangeFile;
                        Console.WriteLine($"Folder {cf.UniqueId.ToString()}: {cf.ChangeType.ToString()}");
                    }
                }
            }

 

0 Replies