Monday, August 24, 2009

Attend the SharePoint Conference 2009 for Free!

ShareSquared, Inc. and Kodak just announced a contest where you can win a free pass to the 2009 SharePoint Conference and four nights stay at Mandalay Bay in Vegas! You can also win some free consulting or a Kodak scanner! Visit http://www.sharepointgiveaway.com/ for more information and to enter to win - good luck!

Wednesday, August 19, 2009

Indexing PDFs in WSS3.0

My setup is simply WSS3.0 on a single server using the built-in embedded SQL edition.

1) Download and install the latest Adobe Reader 8. Since release 8, Reader has come with the necessary iFilter built-in.

2) Edit this registry key:
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Shared Tools\Web Server Extensions\12.0\Search\Applications\{GUID}\Gather\Search\Extensions\ExtensionList

Add a new string value with Name=(next sequential number available - usually 37 or 38 I believe) and set the Data=pdf

3) Although the Adobe Reader 8 install should have made the following registry change for you, I always like to double-check it:
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Shared Tools\Web Server Extensions\12.0\Search\Setup\Filters

There should be a Key with Name=.pdf
Within the .pdf key, the following entries should be present:
String Value with Name=Extension and Data=pdf
Binary Value with Name=FileTypeBucket and Data=1 (0x00000001)
String Value with Name=MimeTypes and Data=application/pdf

If the entries are not present, add them.

4) The Adobe Reader 8 install should also have made the following registry change for you, but I still check it too:
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Shared Tools\Web Server Extensions\12.0\Search\Setup\ContentIndexCommon\Filters\Extension

There should be a Key with Name=.pdf
and within the .pdf Key, there should be the following:
Default with Data={AdobeReaderGUID} (in my case it was = E8978DA6-047F-4E3D-9C78-CDBE46041603)

If the entries are not present, add them.

5) Add the Installation directory of Adobe Reader 8 to the System Path:

System Properties (Windows Key + Pause/Break key) - Advanced Tab.
Click Environment Variables button
Scroll down to Path in System Variables and click Edit
Append "C:\Program Files\Adobe\Reader 8\Reader" (or whatever your install path) to the end of the list.

6) Restart the WSS Search service:
net stop spsearch
net start spsearch

7) You are now ready to upload PDFs and they will be indexed for Searching. FYI, any PDFs already uploaded are NOT indexed. I've read you can update them (or their properties) and the Indexer will index them on the next run - but to be safe I generally DELETE and WAIT for the indexer to run again (so I'm sure it deletes any references to them) - and then I REUPLOAD them and WAIT for the indexer to run again. Then after it runs you're sure everything is indexed and searchable.

Monday, June 22, 2009

SPSource: Reverse engineering tool for SharePoint

SPSource is a tool for SharePoint developers to assist in the creation of WSS Solution Packages (WSPs) allowing for the use SharePoint Designer and the SharePoint web UI to make quick changes to items, then push those items into Visual Studio for later compilation into a WSP.

Some examples of what can be done using SPSource:
  • Completely define a custom Publishing Feature using SPD and the SharePoint UI, creating the master pages, page layouts, content types, style sheets, and images directly in the content database. Once at a point where it's ready for deployment, run SPSource against the project and pull everything into a pre-existing WSP. If changes are needed in the markup, make them using SPD, and re-run SPSource. The files in the WSP will be updated and ready for a solution upgrade.
  • Implement a class on an ASPX page (code behind) in SPD, and code that class in Visual Studio, or add custom server controls to the markup in SPD. Push your assembly directly to the GAC or bin as part of the build process, and the code-to-test time is much faster, as the markup files are already in the content database. Once everything is set, run SPSource again the project, and pull everything together into the WSP.
  • Add a custom Content Query Web Part (CQWP) .webpart file to the web part gallery, and change the properties and settings for the new CQWP via the UI and SPD to use custom XSL files that you add to the Style Library/XSL Style Sheets folder. Create new ItemStyles, change the Headers, or add new parameters to the Main XSL. The XSL files can be updated quickly using SPD, and changes can be seen right away. When all is ready for integration into the WSP, execute SPSource against the new files and create a new Feature for the new web part in minutes.
  • Create a complex List instance with Content Types and related Site Columns and reverse the whole lot out to a Feature to deployed to another environment as a Solution Package (wsp) using your favourite tool: VSeWSS, WSPBuilder or STSDev.
You can download it from here.

To use it you can make the following steps:

1. Create the following folder structure to mirror the 12 Hive folder structure:


2. Then create a folder for your Feature (which will deploy the List Template, Site Column and Content Type). For example at C:\temp\SPSource Demo\12\TEMPLATES\FEATURES\SPSourceDemoFeature.


3. Create a Feature.xml file

Create a Feature file at C:\temp\SPSource Demo\12\TEMPLATES\FEATURES\SPSourceDemoFeature\feature.xml file and place the default feature XML content in the file:

<Feature

Id="863BBC74-939E-4296-A538-931369C04433"

Title="SPSource Demo Feature"

Description=""

Version="1.0.0.0"

Scope="Site"

Hidden="False"

xmlns="http://schemas.microsoft.com/sharepoint/">

<ElementManifests>

</ElementManifests>

</Feature>


4. Create the .spsource file

Create a new .spsource file e.g. ‘C:\temp\SPSource Demo\12\TEMPLATES\FEATURES\SPSourceDemoFeature\lists.spsource’. The content of this file reflects the base schema for the Elements Manifest. So start with:


<Elements xmlns="http://schemas.microsoft.com/sharepoint/">

</Elements>

Because we want to reverse engineer the Site Column, Content Type and List you will need two elements in here. One to point to the List and one to point to the Content Type.

NOTE: Any associated Site Columns on the Content Type will automatically be reverse engineered.


<Elements xmlns="http://schemas.microsoft.com/sharepoint/">

<ListTemplate Name="Documents" />

<ContentType Name="Demo Document" />

</Elements>



5. Run SPSource

Now that you have set up the folder for SPSource to run, you now need to execute SPSource.

Open up a command prompt window and type:

Cd C:\temp\SPSource Demo

This will take you to the folder where you’ve created your files (if you chose a different name please adjust this).

Then simply type:

"C:\Program Files\SPSource \SPSource.exe" -designsite http://win-0xqbnqw37uf:41508/sites/DevDemo

NOTE: If you chose a different location for SPSource when you installed it you will have to modify this.

Friday, June 12, 2009

SharePoint 2007 Test Data Population Tool

Microsoft Office SharePoint Server Test Data Load Tool (MOSSDW.exe) is a tool that helps data population for MOSS deployments. It provides an XML based mechanism to populate multiple objects and associate XML tags to classes. It is available as a command line executable which accepts an XML file that specifies the objects to be populated.

The basic XML format for Microsoft Office SharePoint Server Test Data Load Tool is as follows:

<mossdwlib>
<object parameter="”value”">
<childobject parameter="value"></childobject>
</object>
</mossdwlib>

For example:


<mossdwlib>
<testportal>
<testarea num="5" urlname="PublishingWeb$num$"></testarea>
</testportal>
</mossdwlib>

This sample would create 5 web sites named PublishingWeb1 through PublishingWeb5 under the current portal site.

You can use a lot of nice features and options for this purpose. For a complete list you have to download the help for this tool.

You can download this tool from here.

BDC Meta Man - a time saver for integration

I've found a nice tool for generation of Application Definition files for BDC for SharePoint: BDC Meta Man. It is very easy to use and very efficient as you could see in the next video:



It knows to connect to SQL Server, Oracle, DB2, MySQL, InforMix, Web Services, Access or any ODBC connection. It knows even to get data from SAP (with the use of Sitrion).
For a deep dive into the BDC I recommend to you this book:

SharePoint 2007 Developer's Guide to Business Data Catalog.You can find a review for this book here.

Tuesday, June 2, 2009

Free Virtual Expo on SharePoint – June 10

Quest Software's Virtual Expo 2009 for SharePoint
Registration Information…

Wednesday June 10

"During this free online event, you can interact with our SharePoint experts and partners to learn how best to migrate to -- and manage -- this essential collaboration platform.  Join us for live webcasts on topics such as governance and recovery, and visit the booths to download white papers, gather product information or chat with a technology specialist. This event is accessible via any web-connected computer."

8 a.m. to 4 p.m. EDT

7am – 3pm CDT

6am – 2pm MDT

5am – 1pm PDT

Very decent times across Europe

1PM London, England

3PM Bucharest, Romania

Live webcasts:
  • SharePoint Governance: 10 Steps to Successful Deployments
  • Leveraging SharePoint and Performance Point as a Business Intelligence Platform
  • Ask the Experts: Live SharePoint Q&A
  • A Simple Game Plan to Master SharePoint Recovery

Plus, by attending you can:

· Enter to win prizes given away throughout the day including SharePoint books, gift cards and more!

· Interactive"Networking Lounge" with SharePoint experts

View on-demand webcasts
  • Migration tools and best practices
  • Administration and auditing
  • Recovery from your existing backups
  • Developing robust applications on SharePoint with no coding
  • Managing SQL Server

Register Now…

Friday, March 20, 2009

Visual Studio 2008 extensions for Windows SharePoint Services 3.0, v1.3 - Feb 2009 CTP

A new version of Visual Studio 2008 extensions for Windows SharePoint Services 3.0 arrived.
New features in version 1.3 include:
  • Can be installed on x64 Server OS machines running SharePoint x64. Previously only x86 Server OS could be used
  • Separate build commands for package, deploy and retract are added as Visual Studio menu items
  • WSP View improvements for consistency of deleting feature elements, merging features and adding event receivers to features
  • Command line build, package and retract commands are included enabling continuous integration and build servers. Previously command line build of SharePoint projects was very difficult
  • Refactoring support for renaming of Web Parts. Previously renaming a web part required changes in several files in the project
  • Solution Generator can now generate solutions from publishing sites. Previously only regular sites could be generated
  • Allowing partial trust BIN deployments of web parts
  • New project item template for SharePoint RootFiles items
  • Deployment will now optionally remove conflicting existing features on the development server prior to redeployment. Previously any feature name conflicts would result in an error
  • Ancillary assemblies such as for business logic can now be added to the SharePoint Solution WSP
  • Hidden features related to Site Definition projects are now shown in WSP View. They are no longer hidden
  • For advanced users a fast deploy is included to update only the compiled assembly on the SharePoint development installation
  • Deployment step logging is included
  • The List Definition from Content Type template now allows for the creation of a List Definition Event Receiver
  • The User Guide is now installed with the extensions instead of being a separate download

Tuesday, February 17, 2009

A Remote Content Editor Web Part in your SharePoint applications

A very interesting article was written by Christophe (or better known as PathToSharePoint) about a nice creative idea: How to control the home page (or any page) from your every SharePoint web on your every SharePoint SiteCollection on your every SharePoint Application. Christophe found (and implement) the idea to control those pages with the help of the Control Editor Web Part. This control will be connected to a shared file (over the entire SharePoint farm) and just execute the script from that file in your browser, so you can send mass messages to users, you can customize the page remotely (adding links, removing things from it), you can implement a custom security (or logging) mechanism with it etc.
The next step with this control is to create an administrative tool to manage the content of that file (not all users have JavaScript, HTML, CSS and SharePoint skills) and to integrate with your solutions, so your power users will have real time control over it. 
Indeed, a very interesting idea.
You can find more about this, on his blog here.

Monday, February 16, 2009

Feed your CAML some IntelliSense

Do you have problems in remembering all the key words and formats in CAML? Now this isn't a problem anymore! Thanks to John Holiday and his CAML.NET IntelliSense project. You can find more information about this on his blog: http://johnholliday.net/post/2009/01/18/Feed-your-CAML-some-IntelliSense-so-it-doesnt-bite-you-in-the-you-know-what!.aspx
To download the installer for the project follow this link: http://code.msdn.microsoft.com/camlintellisense/Release/ProjectReleases.aspx?ReleaseId=2212

Friday, February 13, 2009

Free MOSS 2007 WCM Learning Resources

Microsoft post a few free learning resources for those of you wanting to pickup MOSS 2007 WCM sites. 
These training modules provide architects with information about Microsoft Office SharePoint Server 2007 Web Content Management (WCM). The modules and accompanying videos explain the role of WCM architecture, building content management for your Web site, and server infrastructure and deployment. The modules also cover WCM design, security, and optimization.
You can download them from here:

Friday, January 30, 2009

SharePoint Dispose Checker Tool

A new must have tool has been released by Microsoft! This tool is called SharePoint Dispose Checker Tool. This tool analyzes your assemblies and helps to identify potential memory leaks. 
This tool was made to help you to check your assemblies that use the SharePoint API so that you can build better code. It provides assistance in correctly disposing of certain SharePoint objects to help you follow published best practice. This tool may not show all memory leaks in your code. 

Please review the MSDN article on using Deploy in SharePoint applications here.
The SPDisposeCheck tool can be downloaded here.
Roger Lamb maintains a nice blog for the SPDisposeCheck team here.

Monday, January 26, 2009

SharePoint Skinner

A great tool for customizing and branding a SharePoint Web Site or portal is SharePoint Skinner.
It is a desktop application which enables you to visual edit the css for your SharePoint and save it as a SharePoint Theme. It is very easy to use and very productive. You should read more about it on its tutorial here: http://www.elumenotion.com/Blog/Lists/Posts/Post.aspx?ID=4
You will find it on CodePlex too: http://www.codeplex.com/SP2007Skinner

JQuery with SharePoint