One or more field types are not installed properly

Here is the error:
The following exception was thrown when trying to enumerate the collection: “One or more field types are not installed properly. Go to the list settings page to delete these fields.”.
At C:\Users\me\AppData\Local\Temp\2\bca6fde0-a91f-427a-ad21-4794d47cebfc.ps1:24 char:17
+ $spList.GetItems <<<< ($spQuery)
+ CategoryInfo : NotSpecified: (:) [], ExtendedTypeSystemException
+ FullyQualifiedErrorId : ExceptionInGetEnumerator

Why?
Using PowerShell, I was trying to query a list. In my Where statement, I was calling a field by its display name, and not its INTERNAL name.

Bad code:

$web = Get-SPWeb "http://sharepointed.com/sites/taco"

$spList = $web.Lists["Taco History"]
$field = $spList.Fields["Taco Name"]
$value = "Grande Taco"

# Create Query based on field and value
$camlQuery =
'' +
$value +
'';
# SPQuery object
$spQuery = New-Object Microsoft.SharePoint.SPQuery
# Add query
$spQuery.Query = $camlQuery;
$spList.GetItems($spQuery)

This code will toss you the One or more field types are not installed properly….. error.

Using the friendly U2U Caml query tool, I rewrote my PowerShell Caml query. Doing this I noticed my field name issue. My fields display name is Taco Name but its internal name is Taco_x0020_Name. Doh!!!

Rewrite the PowerShell script and life is good!
Notice the new $field = $field.InternalName line in the script.

$web = Get-SPWeb "http://sharepointed.com/sites/taco"

$spList = $web.Lists["Taco History"]
$field = $spList.Fields["Taco Name"]
$field = $field.InternalName
$value = "Grande Taco"

# Create Query based on field and value
$camlQuery =
'' +
$value +
'';
# SPQuery object
$spQuery = New-Object Microsoft.SharePoint.SPQuery
# Add query
$spQuery.Query = $camlQuery;
$spList.GetItems($spQuery)

PowerShell Add Attachment to Item

Someone asked me how they could automatically add attachments to items. What I did was use a workflow action (ilovesharepoint) to call a powershell script. The script will grab a file from a document library and add it to the list item.

$web = Get-SPWeb "http://taco.com/subsite/"
$filePath = "http://taco.com/subsite/docs/grandetaco.docx"

$spList = $web.lists["Toppings"] 
$item = $splist.GetItemById(2)
$file = $web.GetFile($filePath).OpenBinary()

$item.Attachments.Add($filepath, $file)
$item.Update()

$web.Dispose()

live and learn!
i was having a hard time converting the file to bytes to be able to attach the document to the item.

Delete Distribution Groups Using PowerShell

We had a monster mess where Records Center was enable, and well, it created a TON of groups.
Each of these groups started with Records Center Web Service Submitters ….

Below is the PowerShell to delete the group from a given site. To make things more-funner, it would be better to start at the web app, then loop on the site collections, and sub sites.

$site = Get-SPweb "http://sharepointed.com/sites/TestSite/"

foreach($group in $site.Groups)
	{
		if ($group.Name.Contains("Records Center Web Service Submitters"))
			{
				$site.SiteGroups.Remove($group.Name)
			}
	}
$site.Dispose()

Display Quick Launch in Pages

When creating new web part pages in SharePoint, the left nav / quick launch doesn’t always display.

To allow the quick launch to display do the following.

Open SharePoint Designer.
Open the page you want to edit.
Switch to Split view of the page and code.
— In SharePoint Designer 2010 you will see this option at the bottom left of the page.
In the code window, do a CTRL+F to find these three items, once found remove them.
1.
2. asp:Content ContentPlaceHolderId=”PlaceHolderNavSpacer” runat=”server”>
3.


Once you have removed these item, click save.

Modify Default Search for My Sites

In SharePoint 2010 you can change your default search center for My Sites (mysites). In my case, I needed to setup a new Search Center on the My Site host.

The address is:
http://mysite.sharepointed.com/search/

To update your My Site search destination goto:
Central Administration –> Application Management –> Service Applications – Manage service application –> User Profile Service.

Under the My Site Settings, click on Setup My Sites.
Preferred Search Center

My URL looks like this:
http://mysite.sharepointed.com/search/pages/

I had to add to pages/ path to satisify the value being sent from the My Site people search box.

WebFldr link and SharePoint 2010

After migrating one of my Web Apps from SharePoint 2007 to SharePoint 2010, I ran into a small issue. In just about every site in every site collection, the users setup links to the Explorer View. Well, SharePoint 2010 doesn’t much care for the WebFldr.aspx link.

I had two options:
Update every link, in every site one at a time.
Use PowerShell to loop around and update the links for me.

Also noticed that when users clicked on these WebFldr.aspx link, the ribbion would get stuck in a Loading state.

What I’m doing with this script:
Define the items we are looing for and replacing.
Open the site collection.
Loop on each site in the collection.
Get the Quick Launch.
Loop on the Headers.
Loop on the Child Node of each Header.
If the Child Node contains our $stupidLink, we then replace that link with the $goodLink, and update it.
Dispose of our connections.

Add-PSSnapin Microsoft.SharePoint.PowerShell –erroraction SilentlyContinue

$stupidLink="WebFldr"
$goodLink="AllItems"

$sSiteColl = Get-SPSite  "http://sharepointed.com/SiteCollection/"
foreach($sSite in $sSiteColl.AllWebs)
	{
	 	$site = Get-SPWeb $sSite.Url
		$qlNav = $site.Navigation.QuickLaunch

		foreach($qHeader in $qlNav)
		{
			foreach($ChldNode in $qHeader.Children)
			{
				if ($ChldNode.Url.Contains($stupidLink)) 
				{
					Write-Host $site.Url -BackgroundColor DarkYellow
					Write-Host $ChldNode.URL -BackgroundColor DarkCyan
					$ChldNode.Url = $ChldNode.Url.Replace($stupidLink,$goodLink)
					$ChldNode.Update()
				}
			}
		}
	}
	$sSite.Dispose()
$sSiteColl.Dispose()

This script is also used to update the Quick Launch children nodes in SharePoint.

Distribution list status Creation request pending

Pay attention to the details!

I created a new SharePoint Group, chose Yes for Create an e-mail distribution group for this group?, then gave the group an email address. I clicked save, and went about my business.

What I didn’t notice was this:
Distribution list status:
Creation request pending

Where are these items approved at?
… Central Administration.

SharePoint 2010
Central Administration –> Security
In the Users section, you will want to click on Approve or reject distribution groups.

Here is the URL:
http://centraladmin:777/Lists/Distribution%20Groups/AllItems.aspx
centraladmin:777 = your central admin location.

SharePoint Server Enterprise Site Collection features Error

Tried to activate SharePoint Server Enterprise Site Collection features on a new Site Collection and would recevie the normal SharePoint error (some text and an error ID). I grabbed the error ID and went looking in the ULS logs.

Here is what I found.

Feature Activation: Threw an exception, attempting to roll back. Feature ‘IPFSSiteFeatures’ (ID: ‘c88c4ff1-dbf5-4649-ad9f-c6c426ebcbf5’). Exception: Microsoft.Office.InfoPath.Server.Util.InfoPathLocalizedException: The InfoPath Forms Services support feature is not properly activated. Document library could not be found
at FormServerTemplates
.

I went back to the Site Collection, created a FormServerTemplates form library (document library might have worked), then activated the feature again. And guess what, it worked!

Other tricks that worked for people:
http://social.technet.microsoft.com/Forums/en-US/sharepoint2010setup/thread/df474171-ee3b-4845-8e18-6a7119898bb9

PowerShell Get Value of a Hyperlink Field in SharePoint

I needed to get the hyperlink value from a field in a SharePoint List.

Here is how you do it.

$web = get-spweb http://sharepointed.com/sites/YourSite
$list = $web.Lists["Your List Name"]

foreach($i in $list.items)
	{
		$ofldurl= new-object Microsoft.SharePoint.SPFieldUrlValue($i["MyHyperlinkField"])
		write-host $ofldurl.URL 
                write-host $ofldurl.Description
	}
$web.Dispose()