Skip to main content

How to deloy InfoPath 2010 "Administrator-approved form template" to SharePoint 2010 programaticaly


Scenario: you've developed and InfoPath 2010 form. This form contains code that requires full trust, so you need to deploy it as a administrator-approved form template.

This requires an farm administrator to check, upload and activate the form for the site collection.

Solution: to automate this operation I created a farm level feature - when the feature is activated upload the form programmatically and when the feature is deactivated remove the form programmatically.

Here is how I did it:

1. Create an Empty SharePoint Project and set it to be deployed as a farm solution

2. Add an Empty element item - EmptyElement1. This will also generate a feature - Feature1

3. Delete the Elements.xml file of the EmptyElement1

4. Copy/Paste the InfoPath 2010 form into the EmptyElement1

5. Right click on the added form and click Properties:
 - Deployment Type: ElementFile
 - Deployment Location> Path: set it to blank

6. Open the generated feature, Feature1

7. Set the scope to Farm level and save it

8. Right click on the feature and select "Add Event Receiver"

9. Comment out the FeatureActivated and FeatureDeactivating methods

10. Add the following code to the FeatureActivated method to upload the form:

  SPSecurity.RunWithElevatedPrivileges(() =>
  {
   SPFarm localFarm = SPFarm.Local;
   FormsService localFormsService;
   string solutionPath = properties.Definition.RootDirectory + @"\Form.xsn";
   try
   {
    localFormsService = localFarm.Services.GetValue(FormsService.ServiceName);
    localFormsService.FormTemplates.UploadFormTemplate(solutionPath);
   }
   catch (Exception ex) {
    // Handle exception Here
   }
  });

10. Add the following code to the FeatureDeactivating method to remove the form:

  SPSecurity.RunWithElevatedPrivileges(() =>
  {
   SPFarm localFarm = SPFarm.Local;
   FormsService localFormsService;
   string solutionPath = properties.Definition.RootDirectory + @"\Form.xsn";
   try
   {
    localFormsService = localFarm.Services.GetValue(FormsService.ServiceName);
    FormTemplate formTemplateToRemove = (from formTemplates in localFormsService.FormTemplates
              where formTemplates.DisplayName == "Form"
              select formTemplates).Single();
    localFormsService.FormTemplates.RemoveFormTemplate(formTemplateToRemove);
   }
   catch (Exception ex) {
    // Handle exception Here
   }
  });

11. Build and deploy the solution.


That is it!


Note that you need to reference the Microsoft.Office.InfoPath.Server.dll. This is usually located here:  C:\Program Files\Microsoft Office Servers\14.0\Bin\

Comments

Popular posts from this blog

PowerShell script to add work email to the list fields for the author

The Author (Created By) field is actually an lookup field to the hidden User Information list. If you need to add the work email of the Author (Created By field) user to a specific list it can be done by adding a dependent lookup field for the Author field: $site = get - spsite "site url here"; $list = $site . RootWeb . Lists [ "list name" ]; $createdByEmailGuid = $web . Fields . AddDependentLookup ( "Work e-mail" , [ Microsoft . SharePoint . SPBuiltInFieldId ]:: Author ); $createdByEmail = $web . Fields . GetFieldByInternalName ( $createdByEmailGuid ); $createdByEmail . Description = "Work e-mail address of the Author."; $createdByEmail . LookupField = $web . Fields [[ Microsoft . SharePoint . SPBuiltInFieldId ]:: EMail ]. InternalName ; $createdByEmail . Update (); $web . Update (); $list . Fields . Add ( $createdByEmail ); $list . Update (); If additional fields are needed the same method can be applied. Here is a li

Emmet in Visual Studio Code | cheat sheet link

Support for   Emmet   snippets and expansion is built right into Visual Studio Code,   no extension required .   Emmet 2.0   has support for the majority of the   Emmet Actions   including expanding   Emmet abbreviations and snippets .   Emmet is a web-developer’s toolkit that can greatly improve your HTML & CSS workflow   Links: Emmet in Visual Studio Code   Cheat Sheet (emmet.io)  

SharePoint 2010 - Enable and configure unique Document IDs

There is a great article on how to Enable and configure unique Document IDs on Microsoft.com. In short you need to: Activate the Document ID site collection feature Enable and configure the use of Document IDs in a site collection But what it doesn't mention is that behind the scenes there are two time jobs that need to run to activate this feature: one to add the Document ID column and one to generate unique ids for the existing documents. But, these jobs are set to run once a day. So if you need your unique Document IDs to be activate right away, you need to go to Central Administration and run these two timer jobs for your respective web application: Document ID enable/disable job  Document ID assignment job