Creating a Feature with Common Resources
Excercise 1:-
Excercise 1:-
- If you haven’t already done so, run the batch file named SetupLabxx.bat, found in the c:\Student\Labs\xx_BestPractices\ folder, to create the new site collection that will be used to test and debug the code you will be writing in this lab. This batch file creates a new site collection at an URL of http://intranet.contoso.com/sites/Labxx.
- Start Visual Studio 2010.
- Select File » New » Project from the main menu.
- In the New Project dialog, select VisualC#/Visual Basic » SharePoint »2010 in the Installed Templates list.
- Select Empty SharePoint Project as the Project type.
- Ensure that the target framework is set to .NET Framework 3.5.
- Name the new project BestPracticesImages and click the OK button.
- When the SharePoint Customization Wizard, enter the address of the site you are using for this exercise: http://intranet.contoso.com/sites/Labxx/.
- Select to deploy the solution as a Farm Solution.
- Click the Finish button.
- In the Solution Explorer, right click the Features node and select Add Feature from the context menu.
- In the Solution Explorer, right click the BestPracticesImages project node and select Add » SharePoint “Images” Mapped Folder from the context menu.
- In the Solution Explorer, inside of the Images folder, right click the BestPracticesImages folder and select Add » Existing Item from the context menu.
- Locate the file C:\Program Files\Common Files\Microsoft Shared\web server extensions\14\Template\Images\delete.gif and add it to the folder.
- In the Solution Explorer, expand the Package node and double-click the Package.package node.
- In the Properties window (lower right side), locate the SolutionId property and copy the SolutionId property to Notepad for use later in the lab.(Note: your ID will be different from the one shown in the image below)
- DO NOT DEPLOY THE SOLUTION YET!
- Start a new instance of Visual Studio 2010.
- Select File » New » Project from the main menu.
- In the New Project dialog, select VisualC#/Visual Basic » SharePoint »2010 in the Installed Templates list.(Note: be sure to choose the same language here [C# or VB.NET] as before).
- Select Empty SharePoint Project as the Project type.
- Ensure that the target framework is set to .NET Framework 3.5.
- Name the new project BestPracticesParts and click the OK button.
- When the SharePoint Customization Wizard, enter the address of the site you are using for this exercise: http://intranet.contoso.com/sites/Labxx/.
- Select to deploy the solution as a Farm Solution.
- Click the Finish button.
- In the Solution Explorer, right click the BestPracticesParts project node and select Add » New Item from the context menu.
- Select to add a new Web Part.
- Name the Web Part StringProvider and click the Add button.
- In the Solution Explorer, right click the BestPracticesParts project node and select Add » New Item » expand Common Items and select Code » Interface from the Add New Item dialog box.
- Name the interface IStringConnection.cs or IStringConnection.vb (Note: the first character here is a capital i that is used to denote an interface class) and click the Add button.
- Open IStringConnection.cs/vb for editing in Visual Studio and add the code to create an interface as shown.
- C#
- public interface IStringConnection
- {
- string ProvidedString { get; }
- }
- C#
- Public Interface IStringConnection
- ReadOnly Property ProvidedString() As String
- End Interface
- Open StringProvider.cs/vb for editing in Visual Studio.
- Update the code so that the web part implements the interface as follows.
- C#
- [ToolboxItemAttribute(false)]
- public class StringProvider : WebPart, IStringConnection
- {
- private TextBox theString;
- [ConnectionProvider("String Provider")]
- public IStringConnection ConnectionInterface()
- {
- return this;
- }
- public string ProvidedString
- {
- get { return theString.Text; }
- }
- protected override void CreateChildControls()
- {
- theString = new TextBox();
- if (!Page.IsPostBack)
- theString.Text = "Web Part connections are good";
- this.Controls.Add(theString);
- }
- protected override void RenderContents(HtmlTextWriter writer)
- {
- writer.Write("<p>Enter a string</p>");
- theString.RenderControl(writer);
- }
- }
- Visual Basic
<ToolboxItemAttribute(False)> _ Public Class StringProvider Inherits WebPart Implements IStringConnection Private theString As TextBox <ConnectionProvider("String Provider")> _ Public Function ConnectionInterface() As IStringConnection Return Me End Function Public ReadOnly Property ProvidedString() As String _ Implements IStringConnection.ProvidedString Get Return theString.Text End Get End Property Protected Overrides Sub CreateChildControls() theString = New TextBox() If Not Page.IsPostBack Then theString.Text = "Web Part connections are good" End If Me.Controls.Add(theString) End Sub Protected Overrides Sub RenderContents(ByVal writer _ As HtmlTextWriter) writer.Write("<p>Enter a string</p>") theString.RenderControl(writer) End Sub End Class
- In the Solution Explorer, expand the Package node and double click the Package.package node.
- In the visual designer, click the Manifest button (located near the bottom of the Package.package window) and expand the Edit Options.
- Click the Open in XML Editor link.
- Modify the XML to add custom CAS policies as shown in the following code.
XAML
<?xml version="1.0" encoding="utf-8"?> <Solution xmlns="http://schemas.microsoft.com/sharepoint/"> <CodeAccessSecurity> <PolicyItem> <PermissionSet class="NamedPermissionSet" version="1" Description="Connection Permissions"> <IPermission class="AspNetHostingPermission" version="1" Level="Minimal" /> <IPermission class="SecurityPermission" version="1" Flags="Execution" /> </PermissionSet> <Assemblies> <Assembly Name="BestPracticesParts"/> </Assemblies> </PolicyItem> </CodeAccessSecurity> </Solution>
- In the Solution Explorer, select the BestPracticesParts project and in the Properties window, change the Assembly Deployment property to Web Application.
- In the Solution Explorer, expand the(if using C#) Properties node / (if using VB.NET) MyProject node, and open the AssemblyInfo.cs/vb file for editing.(Note: you may have to click the Show all files button in the solution explorer to see the items in these nodes)
- Verify that the following to assembly attribute exists somewhere in this file. This allows the web parts to run outside of the GAC.(Note: both C# and VB.NET should automatically add this.)
C#
[assembly: System.Security.AllowPartiallytrustedCallers()]
Visual Basic<Assembly: System.Security.AllowPartiallyTrustedCallers()>
- In the Solution Explorer, right click the project and select Build from the context menu.
- After you have a successful build, right click the project and select Package.
- In the Solution Explorer for BestPracticesParts, right click the project node and select Add » New Item from the context menu.
- Select to add a new Web Part.
- Name the Web Part StringConsumer and click the Add button.
- Open StringConsumer.cs/vb for editing in Visual Studio.
- Update the code so that the web part implements the interface as follows.
- C#
- public class StringConsumer : WebPart
- public void GetConnectionInterface(
- BestPracticesParts.IStringConnection ProviderPart)
- this.providerPart = ProviderPart;
- protected override void RenderContents(HtmlTextWriter writer)
- try
- {
- catch
- {
{
BestPracticesParts.IStringConnection providerPart = null;
[ConnectionConsumer("String Consumer")]
- public class StringConsumer : WebPart
- public void GetConnectionInterface(
- BestPracticesParts.IStringConnection ProviderPart)
- this.providerPart = ProviderPart;
- protected override void RenderContents(HtmlTextWriter writer)
- try
- {
- catch
- {
{
- public class StringConsumer : WebPart
- public void GetConnectionInterface(
- BestPracticesParts.IStringConnection ProviderPart)
- this.providerPart = ProviderPart;
- protected override void RenderContents(HtmlTextWriter writer)
- try
- {
- catch
- {
}
public class StringConsumer : WebPart public void GetConnectionInterface( BestPracticesParts.IStringConnection ProviderPart) this.providerPart = ProviderPart; protected override void RenderContents(HtmlTextWriter writer) try { catch {
{public class StringConsumer : WebPart public void GetConnectionInterface( BestPracticesParts.IStringConnection ProviderPart) this.providerPart = ProviderPart; protected override void RenderContents(HtmlTextWriter writer) try { catch {
writer.Write("<p>" + providerPart.ProvidedString + "</p>");}
- public class StringConsumer : WebPart
- public void GetConnectionInterface(
- BestPracticesParts.IStringConnection ProviderPart)
- this.providerPart = ProviderPart;
- protected override void RenderContents(HtmlTextWriter writer)
- try
- {
- catch
- {
writer.Write( @"<img src='/_layouts/images/BestPracticesImages/delete.gif'/>");}}}
- VB.NET
<ToolboxItemAttribute(false)> _ Public Class StringConsumer Inherits WebPart Private providerPart As BestPracticesParts.IStringConnection = Nothing <ConnectionConsumer("String Consumer")> _ Public Sub GetConnectionInterface(ByVal ProviderPart _ As BestPracticesParts.IStringConnection) Me.providerPart = ProviderPart End Sub Protected Overrides Sub RenderContents(ByVal writer As HtmlTextWriter) Try writer.Write("<p>" _ & Convert.ToString(providerPart.ProvidedString) & "</p>") Catch writer.Write( _ "<img src='/_layouts/images/BestPracticesImages/delete.gif'/>") End Try End Sub End Class
- In the Solution Explorer, expand the Package node, expand the Package.package node, and double click the Package.template.xml node.(Note: you may have to click the Show all files button in the solution explorer to see the items in these nodes)
- Edit the XML to apply a solution dependency to the solution contained in Exercise 1. Place the solution dependency code above the CAS policies as shown below. Be sure to use the SolutionId you saved to notepad in Exercise 1.
XAML
… <Solution xmlns="http://schemas.microsoft.com/sharepoint/"> <ActivationDependencies> <ActivationDependency SolutionId="Your Solution Id here"/> </ActivationDependencies> <CodeAccessSecurity> …
- In the Solution Explorer, right click the project and select Deploy from the context menu. Your solution deployment should fail because the BestPracticesImages solution has not been deployed.
- Open the BestPracticesImages solution in Visual Studio 2010.
- In the Solution Explorer, right click the project and select Deploy from the context menu.
- After successfully deploying the BestPracticesImages project, return to the BestPracticesParts project.
- In the Solution Explorer, right click the project and select Deploy from the context menu. Your solution should now deploy successfully.
- Open your test site in Internet Explorer.
- In the test site, add the StringProvider and StringConsumer web parts to the page.
- Initially, the consumer should be displaying the delete image indicating that it has no connection.
- Using the web part menu, connect the consumer and provider and verify that the text is passed between them.
No comments:
Post a Comment