This is my first post, so I'd like to say hello to everyone.
I'm trying to get Folder object by its path in SharePoint 2010 client application using Client Side Object Model (.Net 4.0).
I need to check whether folder described by 'folderPath' variable exists in the library and then get the Folder object for further operations. To enhance performance, I chose to use CAML query to filter the list.
My code:
IEnumerable<List> library = this.clientContext.LoadQuery( this.clientContext.Web.Lists.Where(p => p.Title == this.documentLibrary)); this.clientContext.ExecuteQuery(); List libraryList = library.FirstOrDefault(); //code to handle libraryList == null CamlQuery camlQuery = new CamlQuery(); camlQuery.ViewXml = "<View Scope=\"RecursiveAll\">" + "<Query>" + "<Where>" + "<And>" + "<Eq>" + "<FieldRef Name=\"FSObjType\"/>" + "<Value Type=\"Integer\">1</Value>" + "</Eq>" + "<Eq>" + "<FieldRef Name=\"FileRef\" />" + "<Value Type=\"Text\">" + folderPath + "</Value>" + "</Eq>" + "</And>" + "</Where>" + "</Query>" + "</View>"; ListItemCollection items = libraryList.GetItems(camlQuery); clientContext.Load(items); clientContext.ExecuteQuery(); To this point everything is OK. But I don't have any idea how get the 'Folder' object from an item. I tried to do it in this way:
Folder folder = items.FirtsOrDefault().Folder; clientContext.Load(folder); clientContext.ExecuteQuery(); and that way (used instead of last three lines from first code snippet):
ListItemCollection items = libraryList.GetItems(camlQuery); clientContext.Load(items, collection => collection.Include(item => item.Folder)); clientContext.ExecuteQuery(); But in both cases I got an Exception:
1st: 'Field or property 'Folder' does not exist.'
2nd: 'Column 'Folder' does not exist. It may have been deleted by another user.'
Is there a way to do it? Or maybe I'm doing something wrong? Thanks in advance for the help.