Search This Blog

Monday, December 12, 2011

URL Rewrite to Remove .aspx in IIS 7 (& DNN

Add this to the <system.webServer> section:

<rewrite>
<rules>
<rule name="RemoveASPX" enabled="true" stopProcessing="true">
<match url="(.*)\.aspx" />
<action type="Redirect" url="{R:1}" />
<conditions logicalGrouping="MatchAll">
<add input="{URL}" pattern="(.*)/default.aspx" negate="true" />
<add input="{URL}" pattern="(.*)/admin/*" negate="true" />
<add input="{URL}" pattern="(.*)/desktopmodules/*" negate="true" />
</conditions>
</rule>
<rule name="AddASPX" enabled="true">
<match url=".*" negate="false" />
<conditions>
<add input="{REQUEST_FILENAME}" matchType="IsFile" negate="true" />
<add input="{REQUEST_FILENAME}" matchType="IsDirectory" negate="true" />
<add input="{URL}" pattern="(.*)\.(.*)" negate="true" />
</conditions>
<action type="Rewrite" url="{R:0}.aspx" />
</rule>
</rules>
</rewrite>

URL Rewrite to Remove .aspx in IIS 7 (& DNN)


Add this to the section:























Thursday, December 8, 2011

SharePoint solution to deploy InfoPath Form template as administrator approved form template

An InfoPath form template can be published into SharePoint in many ways. Below are the options available to you when you try to publish an InfoPath Form from Microsoft Office InfoPath application.



  • Form Library: You can publish the info path form template as a template in a form library.

  • Site Content type: You can publish this form template into a library in a site collection which will then be accessible by a content type. This content type can be used by multiple libraries.

  • Administrator approved form template: Administrator can upload the form template in central admin form template gallery which can then be enabled into a specific site collection. When a template has been activated in a Site Collection, a copy of the template is stored in Site Collection “Form Templates” library which can be used by multiple sites, libraries within that site collection.



There might be times when you would want to be able to deploy/activate these form templates automatically via a SharePoint solution eliminating the manual processes. In this post, I will show you how you can package an InfoPath Form template into a WSP solution file and deploy it as administrator approved template. This will automatically, upload the template into the Central Admin Form Template gallery and also activate that form template to a Site Collection.


Tools: Microsoft Office InfoPath Designer 2010, Visual Studio 2010 Professional, SharePoint Server 2010


1) Create a new blank form using InfoPath Designer 2010 and add some controls to it. Mine looks like this.



2) Go to form options and in the security section, set the security level to “Domain”. Read more about the security level here.



3) Then you need to publish the form template. Mind you that we are not going to publish this form template directly into SharePoint server. This form template will be automatically published into SharePoint by our solution. So, we will publish this form template into a network location and include it in our SharePoint Solution.


Go to Publish section in InfoPath Designer and choose “Network Location”.




Select the published path with filename. Then go to next step.


Leave the input textbox blank and select next. You will receive a warning but you can ignore it for now.


After publish, you will get a screen like this.



4) You can now verify if this template can be uploaded into SharePoint server using “Upload form template” in central admin site.



select the published form template and then click verify. You should receive a message stating that the template is ready to be uploaded to the server.



5) Create a SharePoint 2010 project in Visual Studio 2010 and select “Module” to be added.



6) Opt to deploy as a farm solution



7) I’ve changed the name of the feature to “InfoPathDeploymentFeature”, “Module1” to “InfoPathFormModule” and also removed the default sample.txt file from the module.


8) Add the published InfoPathForm.xsn file, one we created earlier, under the “InfoPathFormModule” element. Select the xsn file and in the properties windows, under “Deployment Location” property, clear the path value. The Elements.xml file now looks like this.



9) Change the scope of the feature to “Site”. 


10) Double click the feature and in the properties window, set the values for “Receiver assembly” and “Receiver class” as below.


Receiver Assembly: Microsoft.Office.InfoPath.Server, Version=14.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c


Receiver Class: Microsoft.Office.InfoPath.Server.Administration.XsnFeatureReceiver




11) Check the SharePoint url where you are deploying this feature. Make sure that the feature “SharePoint Server Enterprise Site collection features” is already activated in that site. You can add feature activation dependency also.



12) Then in the packaging explorer, select the module “InfoPathFormModule”. Then you can add features properties from the properties window. These are very important, if you do not add them, the form will not be uploaded in central admin form templates gallery. The manifest will then look like this.



13) Buid and deploy the project.


Check the form templates in the central admin at this locaiton: Central Admin->General Application Settings->Manage form templates. you will see that the template has been uploaded.



You will also notice this form template has already been activated to the site collection where we deployed the feature.




Go to Site Settings->Site Content Type, you’ll see that a content type by the name “InfoPathForm” has been automatically created. This means that now, we can just add this content type into a form library which we can use to fill out our info path form through browser.


So create a new form library, change it to allow management of content types, and add the “InfoPathForm” content type to that library. The settings of content type will now look like this.



You will now see a new content type option available when we create new document which will open our infopath form in browser. But to enable the infopath forms to be displayed in browser, you need to configure the form library which you can do by setting the value of “Openinig document in browser” to “Open in browser” in settings of the library.



 


14) Lastly, click on the new content type in form library, which will open the info path form in a web page.


Sunday, November 6, 2011

Creating Custom Timer Job in SharePoint 2010

Creating Custom Timer Job in SharePoint 2010




 
 
 
 
 
 
i
 
20 Votes

Quantcast

In this post I will show you how to create Custom Timer Job in SharePoint 2010 but you must know this post is based on Creating Custom SharePoint Timer Jobs ,So let us start

Create Custom List and name it  ListTimerJob





Open Visual Studio 2010 >File > New >Project >SharePoint 2010>Empty SharePoint Project. >Name it Custom_TimerJob>Ok





Check Deploy as farm solution>Finish






create a class that inherits from the Microsoft.SharePoint.Administration.SPJobDefinition class. To implement this class, you need to create a few constructors and override the Execute() method as following


01namespace DotnetFinder
02{
03    class ListTimerJob : SPJobDefinition
04    {
05         public ListTimerJob()
06 
07            : base()
08        {
09 
10        }
11 
12        public ListTimerJob(string jobName, SPService service, SPServer server, SPJobLockType targetType)
13 
14            : base(jobName, service, server, targetType)
15        {
16 
17        }
18 
19        public ListTimerJob(string jobName, SPWebApplication webApplication)
20 
21            : base(jobName, webApplication, null, SPJobLockType.ContentDatabase)
22        {
23 
24            this.Title = "List Timer Job";
25 
26        }
27 
28        public override void Execute(Guid contentDbId)
29        {
30 
31            // get a reference to the current site collection's content database
32 
33            SPWebApplication webApplication = this.Parent as SPWebApplication;
34 
35            SPContentDatabase contentDb = webApplication.ContentDatabases[contentDbId];
36 
37            // get a reference to the "ListTimerJob" list in the RootWeb of the first site collection in the content database
38 
39            SPList Listjob = contentDb.Sites[0].RootWeb.Lists["ListTimerJob"];
40 
41            // create a new list Item, set the Title to the current day/time, and update the item
42 
43            SPListItem newList = Listjob.Items.Add();
44 
45            newList["Title"] = DateTime.Now.ToString();
46 
47            newList.Update();
48 
49        }
50}
51}


As you can see this job just add a new item to a ListTimerJob list every time it’s executed



Now that you have the job built> Right click on the Features >Add Feature





Right click on the Feature1 ” you can rename the Feature1 to any name” > Add Event Receiver






As you can see the event Receiver class inherits from the Microsoft.SharePoint.SPFeatureReceiver and This class handles events raised during feature activation, deactivation, installation, uninstallation, and upgrade. But we only need FeatureActivated & FeatureDeactivated event handler to install/uninstall our custom timer job as following

01namespace DotnetFinder.Features.Feature1
02{
03[Guid("9a724fdb-e423-4232-9626-0cffc53fb74b")]
04public class Feature1EventReceiver : SPFeatureReceiver
05    {
06        const string List_JOB_NAME = "ListLogger";
07        // Uncomment the method below to handle the event raised after a feature has been activated.
08 
09        public override void FeatureActivated(SPFeatureReceiverProperties properties)
10        {
11            SPSite site = properties.Feature.Parent as SPSite;
12 
13            // make sure the job isn't already registered
14 
15            foreach (SPJobDefinition job in site.WebApplication.JobDefinitions)
16            {
17 
18                if (job.Name == List_JOB_NAME)
19 
20                    job.Delete();
21 
22            }
23 
24            // install the job
25 
26            ListTimerJob listLoggerJob = new ListTimerJob(List_JOB_NAME, site.WebApplication);
27 
28            SPMinuteSchedule schedule = new SPMinuteSchedule();
29 
30            schedule.BeginSecond = 0;
31 
32            schedule.EndSecond = 59;
33 
34            schedule.Interval = 5;
35 
36            listLoggerJob.Schedule = schedule;
37 
38            listLoggerJob.Update();
39 
40        }
41 
42        // Uncomment the method below to handle the event raised before a feature is deactivated.
43 
44        public override void FeatureDeactivating(SPFeatureReceiverProperties properties)
45        {
46            SPSite site = properties.Feature.Parent as SPSite;
47 
48            // delete the job
49 
50            foreach (SPJobDefinition job in site.WebApplication.JobDefinitions)
51            {
52 
53                if (job.Name == List_JOB_NAME)
54 
55                    job.Delete();
56 
57            }
58 
59}
60 
61   }


Before Deploying you should select the right scope of the Feature in other words in which scope you will activate the Feature(Farm,Site,Web,WebApplication) in our case we will activate Feature1 on Site which is mean Site Collection.





Note : if you trying to activate the feature in the wrong scope will get the following error





Now let us deploy our custom timer job >Right Click on Custom_TimerJob project > Click Deploy






Open now your SharePoint site and select ListTimerJob List and you should see something similar to the following image








Our custom timer job is working fine now you can go and check it and modify the schedule as following

Go to SharePoint 2010 central administration >Monitoring >in the Timer Jobs Section Select Review Job Definitions

and you should See our Custom Timer Job






Click on it and you should see Edit Timer Job Page ,Modify Timer Job schedule based on your requirement



Note : you can also modify schedule of your custom Timer Job from the code but you need to add one of the following class in FeatureActviated Event Handler as following




After Specific Minutes use SPMinuteSchedule class


Hourly use SPHourlySchedule class



Daily use SPDailySchedule class


Weekly use SPWeeklySchedule class


Monthly use SPMonthlySchedule class




Updated [ 8/10/2011]


References

How to: Create a Web Application-Scoped Timer Job

Friday, November 4, 2011

TabContainer Setting Focus to a control inside the TabPanel

<%@ Control Language="VB" AutoEventWireup="false" CodeFile="SearchTabs.ascx.vb" Inherits="UserControls_SearchTabs" %>
<%@ Register Assembly="AjaxControlToolkit" Namespace="AjaxControlToolkit" TagPrefix="ajaxToolkit" %>

<%@ Register Assembly="System.Web.Extensions, Version=1.0.61025.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"
   
Namespace="System.Web.UI" TagPrefix="asp" %>
<div style="text-align:left">

<script type="text/javascript" language="javascript" >
 
var control;
 

function getControl_TabClicked1(sender, e) {  
        control
= $get('<%=txtName.ClientID%>');        
}

function getControl_TabClicked2(sender, e) {  
        control
= $get('<%=txtAddress.ClientID%>');        
}

function getControl_TabClicked3(sender, e) {  
        control
= $get('<%=txtID.ClientID%>');        
}

function getControl_TabClicked4(sender, e) {  
        control
= $get('<%=txtAttribute.ClientID%>');      
}
 

function setFocus(sender, e) {  
    control
.focus();  
}


 
</script>


<ajaxToolkit:TabContainer runat="server" ID="Tabs" CssClass="MyTab" Height="60px" Width="400px" OnClientActiveTabChanged="setFocus" >    
   
<ajaxToolkit:TabPanel runat="Server" ID="panName" HeaderText="By Name" ScrollBars="auto" OnClientClick="getControl_TabClicked1">                        
       
<ContentTemplate>  
             
<asp:UpdatePanel ID="updateTab1" runat="server" >
               
<ContentTemplate>                                              
                   
<table >
                       
<tr>
                           
<td align="left">Enter Business Name</td>
                           
<td align="left"><asp:TextBox ID="txtName" runat="server" Width="150px" CssClass="textbox"  TabIndex="1" /></td>
                           
<td align="center">
                               
<asp:Button ID="btnName" runat="Server" Text="Search" CssClass="textbox"/>
                           
</td>
                       
</tr>                      
                       
<tr>
                           
<td colspan="3" align="left">Enter at least 3 characters from the Business Name</td>
                       
</tr>
                   
</table>                                                    
               
</ContentTemplate>
           
</asp:UpdatePanel>                          
       
</ContentTemplate>
   
</ajaxToolkit:TabPanel>
   
   
<ajaxToolkit:TabPanel  runat="Server" ID="panAddress"  HeaderText="By Address" OnClientClick="getControl_TabClicked2">
       
<ContentTemplate>
             
<asp:UpdatePanel ID="updateTab2" runat="server">
               
<ContentTemplate>
                   
<table>
                       
<tr>
                           
<td align="left">Enter Business Address</td>
                           
<td align="left"><asp:TextBox ID="txtAddress" runat="server" CssClass="textbox"/></td>
                           
<td align="center">
                               
<asp:Button ID="btnAddress" runat="Server" Text="Search" CssClass="textbox"/>
                           
</td>
                       
</tr>                        
                   
</table>                    
               
</ContentTemplate>
           
</asp:UpdatePanel>    
       
</ContentTemplate>
   
</ajaxToolkit:TabPanel>

   
<ajaxToolkit:TabPanel runat="Server" ID="panID" HeaderText="By ID" OnClientClick="getControl_TabClicked3">
       
<ContentTemplate>
             
<asp:UpdatePanel ID="updateTab3" runat="server">
               
<ContentTemplate>
                   
<table>
                       
<tr>
                           
<td align="left">Enter Business ID</td>
                           
<td align="left"><asp:TextBox ID="txtID" runat="server" CssClass="textbox"/></td>
                           
<td align="center">
                               
<asp:Button ID="btnID" runat="Server" Text="Search"  CssClass="textbox"/>
                           
</td>
                       
</tr>
                       
<tr>                            
                           
<td colspan="3">
                               
<asp:RegularExpressionValidator runat="server" ID="revID" ControlToValidate="txtID" ValidationExpression="^\d+$" ErrorMessage="Must be an integer > 0!" Font-Size="X-Small" SetFocusOnError="true"></asp:RegularExpressionValidator>                            
                               
<asp:CompareValidator ID="cvID"  runat="server" ControlToValidate="txtID" ValueToCompare="0" Operator="NotEqual" ErrorMessage="Must be an integer > 0!" Font-Size="X-Small" SetFocusOnError="true"></asp:CompareValidator>                                
                           
</td>                            
                       
</tr>                        
                   
</table>                  
             
</ContentTemplate>
           
</asp:UpdatePanel>  
       
</ContentTemplate>
   
</ajaxToolkit:TabPanel>
   
   
<ajaxToolkit:TabPanel runat="Server" ID="panAttribute" HeaderText="By Attribute" OnClientClick="getControl_TabClicked4">
       
<ContentTemplate>
           
<asp:UpdatePanel ID="updateTab4" runat="server">
               
<ContentTemplate>
                   
<table>
                       
<tr>
                           
<td align="left">Select Attribute</td>
                           
<td align="left" colspan="2">
                               
<asp:DropDownList ID="ddlAttributes" DataSourceID="AttributesDataSource" DataTextField="text" DataValueField="value" runat="server" CssClass="textbox">
                               
</asp:DropDownList>
                               
<asp:XmlDataSource ID="AttributesDataSource" runat="server" DataFile="~/XML Files/AttributeNames.xml">
                               
</asp:XmlDataSource>
                           
</td>
                           
</tr>
                           
<tr>
                           
<td align="left">
                                Enter Value
                           
</td>
                           
<td align="left">
                               
<asp:TextBox ID="txtAttribute" runat="server" CssClass="textbox"></asp:TextBox>                                
                               
                           
</td>
                           
<td align="center">
                               
<asp:Button ID="btnAttribute" runat="Server" Text="Search" CssClass="textbox"/>
                           
</td>
                       
</tr>                                        
                   
</table>                                                                    
               
</ContentTemplate>
           
</asp:UpdatePanel>
       
</ContentTemplate>
   
</ajaxToolkit:TabPanel>                      
</ajaxToolkit:TabContainer>

</div>  

 

Thursday, November 3, 2011

TabContainer Setting Focus to a control inside the TabPanel

 Place this at the BOTTOM of your ASP.Net Page.  Replace txtPartNo with the name of your control.



<script language="javascript" type="text/javascript">
   
Sys.Application.add_load
   
(
       
function()
       
{
            window
.setTimeout(focus, 1);
       
}
   
)
   
function focus()
   
{
        document
.getElementById('<%=txtPartNo.ClientID %>').focus();
   
}
</script>

Monday, October 31, 2011

Enumerate all Site Collections in a SharePoint Farm

// BEGIN EnumSiteCollections.cs
using System;
using Microsoft.SharePoint;
using Microsoft.SharePoint.Administration;

namespace EnumSiteCollections
{
class Program
{
static void Main(string[] args)
{
foreach (SPWebApplication wa in SPWebService.ContentService.WebApplications)
{
foreach (SPSite sc in wa.Sites)
{
try
{
Console.WriteLine("Do something with site at: {0}", sc.Url);
}
catch (Exception e)
{
Console.WriteLine("Exception occured: {0}\r\n{1}", e.Message, e.StackTrace);
}
finally
{
sc.Dispose();
}
}
}
}
}
}
// END EnumSiteCollections.cs

Enumerate all Site Collections in a SharePoint Farm

// BEGIN EnumSiteCollections.cs
using System;
using Microsoft.SharePoint;
using Microsoft.SharePoint.Administration;

namespace EnumSiteCollections
{
class Program
{
static void Main(string[] args)
{
foreach (SPWebApplication wa in SPWebService.ContentService.WebApplications)
{
foreach (SPSite sc in wa.Sites)
{
try
{
Console.WriteLine("Do something with site at: {0}", sc.Url);
}
catch (Exception e)
{
Console.WriteLine("Exception occured: {0}\r\n{1}", e.Message, e.StackTrace);
}
finally
{
sc.Dispose();
}
}
}
}
}
}
// END EnumSiteCollections.cs

Wednesday, October 12, 2011

How to Create an ASMX Web Service on SharePoint 2010, Using Visual Studio 2010

http://www.thesharepointblog.net/Lists/Posts/Post.aspx?List=815f255a%2Dd0ef%2D4258%2Dbe2a%2D28487dc9975c&ID=67