This is the second time my crawl sticks on indexing files. It shows that it has been crawling for 85 hours. To solve this problem, the first time, I remember, I had to restart the SharePoint services and initialize the index. This time, I do not know how that happened but I found out that on one WFE no SharePoint service was running! So, I started all needed services. When I went back to my Search settings, I found that the stuck crawl has ended. I launched an incremental crawl for all my content sources. Every thing has worked as expected. I am glad I did not have to reinitialize my index this time. I have more than 100000 items in it. It would take me hours to reconstruct it. I tested my search and it is working fine.
Hope this helps.
Sunday, April 25, 2010
Saturday, March 6, 2010
System.InvalidOperationException: This access control list is not in canonical form and therefore cannot be modified
In this post I want to share a solution for a problem that may occur when you want to copy pages or sites from a location to another inside a site collection, using the content and structure 'copy' option. You may receive this error :
System.InvalidOperationException: This access control list is not in canonical form and therefore cannot be modified.
At System.Security.AccessControl.CommonAcl.ThrowIfNotCanonical()
At System.Security.AccessControl.CommonAcl.RemoveInheritedAces()
At System.Security.AccessControl.CommonSecurityDescriptor.SetDiscretionaryAclProtection(Boolean isProtected, Boolean preserveInheritance)
At System.Security.AccessControl.ObjectSecurity.SetAccessRuleProtection(Boolean isProtected, Boolean preserveInheritance)
At Microsoft.SharePoint.Deployment.DataFileManager.<>c__DisplayClass1.<CreateDirectoryAsProcessAccount>b__0()
At Microsoft.SharePoint.Utilities.SecurityContext.RunAsProcess(CodeToRunElevated secureCode)
At Microsoft.SharePoint.Deployment.DataFileManager.CreateDirectoryAsProcessAccount(String strDir, Boolean allowCurrentUserWriteAccess)
At Microsoft.SharePoint.Deployment.SPExport.AutoGenerateDataFolder()
At Microsoft.SharePoint.Deployment.SPExport.Run()
At Microsoft.SharePoint.Publishing.Internal.DeploymentWrapper.Copy(String[] sourceSmtObjectIds, String destSmtObjectId)
At Microsoft.SharePoint.Publishing.Internal.WebControls.CopyObjects.Copy()
At Microsoft.SharePoint.Publishing.Internal.WebControls.CopyObjects.DoWork()
At Microsoft.SharePoint.Publishing.Internal.LongRunningOperationJob.<>c__DisplayClass16.<ThreadEntryPoint>b__11()
At Microsoft.Office.Server.Diagnostics.FirstChanceHandler.ExceptionFilter(Boolean fRethrowException, TryBlock tryBlock, FilterBlock filter, CatchBlock catchBlock, FinallyBlock finallyBlock)
The problem is that the ACL for the 'Windows\temp' directory is corrupted and therefore, the accounts WSS_WPG and WSS_ADMIN_WPG have no access to the folder to put temporary stuff.
The solution is to redefine the ACL:
- Right-Click on the folder Windows\temp
- Click on the Security tab
- Click on the Advanced button
- Ensure that the account WSS_ADMIN_WPG as the full control permission
- Ensure that the account WSS_WPG has the Read & execute permission.
- Select both 'Allow inheritable permissions...' and 'Replace permission entries...'
- Click OK.
A 1000 thanks for my colleague Frédéric Lévesque the 'Security guy' for helping troubleshooting the issue.
Hope this helps.
Labels:
ACL,
CANONICAL,
Content and structure,
sharepoint
Saturday, February 27, 2010
Extracting SSP user profiles in a xml file
Have you ever wanted to get all user profiles in one listing, especially that in the SSP UI, profiles are displayed in a paginated list? If you happen to have thousands of users then expect to have hundred of pages. The SSP user profiles list is not very intuitive that's why I developed a console application to get all users in a single xml file that I can sort an filter as I wish. Here is the code :
For a full list of user profiles properties, please read Anne Stenberg's Blog.
Hope this helps.
Imports System.Text Imports System.IO Imports System Imports Microsoft.SharePoint Imports System.Xml Imports System.Web Imports Microsoft.Office.Server Imports Microsoft.Office.Server.UserProfiles Module SSPUserProfiles Sub Main() EnumUserProfiles() End Sub Private Sub EnumUserProfiles() Try Using Site As New SPSite("http://ServerName") Dim siteContext As ServerContext = ServerContext.GetContext(Site) Dim ProfileManager As New UserProfileManager(siteContext) ' Open a new XML file stream for writing Dim stream As IO.FileStream stream = File.OpenWrite("UserProfiles.xml") Dim writer As XmlTextWriter = New XmlTextWriter(stream, Encoding.UTF8) ' Causes child elements to be indented writer.Formatting = Formatting.Indented writer.WriteProcessingInstruction("xml", "version=""1.0"" encoding=""utf-8""") writer.WriteStartElement("UserProfiles") writer.WriteAttributeString("Count", ProfileManager.Count.ToString) For Each Userp As UserProfile In ProfileManager writer.WriteStartElement("UserProfile") writer.WriteAttributeString("AccountName", Userp("AccountName").Value.ToString()) writer.WriteAttributeString("PreferredName", Userp("PreferredName").Value.ToString()) If Userp("WorkEmail").Value IsNot Nothing Then writer.WriteAttributeString("E-Mail", Userp("WorkEmail").Value.ToString()) End If writer.WriteEndElement() 'UserProfile Next writer.WriteEndElement() 'UserProfiles ' Flush the writer and close the stream writer.Flush() stream.Close() End Using Catch exp As Exception Console.WriteLine(exp.Message) End Try End Sub End Module
For a full list of user profiles properties, please read Anne Stenberg's Blog.
Hope this helps.
Labels:
sharepoint,
SSP,
User profiles,
user properties,
users list
Tuesday, January 5, 2010
SharePoint log viewer
Finally, I had some time to develop a tool that I always wanted. A tool that will let me go trough the SharePoint log (where unfortunately I spend lot of time) with ease to find the information I want. Actually it is very simple : It is a small windows application that read the text log file, convert it to a xml file and then, bind it to DataGridView where it can be filtered By :
- Time stamp
- Process
- Area
- Category
- Level of severity
You can find it on CodePlex at : http://mosslogviewer.codeplex.com. It is still a beta version but many ideas are coming.
Your feedback is welcome.
Enjoy!
- Time stamp
- Process
- Area
- Category
- Level of severity
You can find it on CodePlex at : http://mosslogviewer.codeplex.com. It is still a beta version but many ideas are coming.
Your feedback is welcome.
Enjoy!
Subscribe to:
Posts (Atom)