cloud.net

Monday, December 31, 2007

Online Open Port Check Tool

CanYouSeeMe.org - Open Port Check Tool. This is really useful for both security and usability (P2P). http://www.canyouseeme.org/

Friday, November 16, 2007

How to ruin a beautiful sunny Sunday


Sunday 23rd of September.
Beautiful sunny day. Get a call from a friend telling me “It’s on”, it’s on means it’s a good day to fly @ Stanwell Park (NSW, Australia). Get in the car drive the 60kms, unpack my glider take to the air.
Life is good... had a couple of flights, then the wind starts going north. Can’t fly Stanwell in Northerlies. Wind picks up and a bunch of us decide to go to “The World’s Greatest/Hill 60”... cool I’ve never flown there sounded OK. Drive down to Port Kembla.
Hill 60 looked a little dangerous. Wind had now picked up quite a bit. Saw a guy being dragged, so I decided to give it a mis. Couple of them started going to "The World’s Greatest". The World’s Greatest is a flat beach soaring site. There's a rock shelf, some sand and shrubbs.
People in the air seemed to be having fun. It was pretty windy now. The people I drove down wind wanted to do some ground handling in a park behind, so I could either watch or fly... I decided to fly.
It was windy 17-19kt, so I had to be careful launching. It needed to be windy to fly this site as there is very little elevation (2m). My main concern was launching safely, and this is where I made the first mistake that eventually lead to the disaster I'm going to describe shortly.
The very first thing I should have done was examin the terrain and look at my options if conditions changed, and mapped out my flight plan in my head. All I did was decide to go right after launching.
Above you have the site. The red line represents my flight path, the blue lines represent areas of lift and the big arrow represents the wind direction. As you can see from the above image I didn't really get in to lift. What you can't see is there's cliff wall (3m high) towards the end where I turn around. I turned around (mistake) because I didn't know what was around the corner, and I thought it best to try and get back to lift and sand. My options for landing were very limited, turn in to wind and risk going in the water. When I turned around I had the wind to my back, so my ground speed was +/- glider speed (38kmh) + wind speed (33kmh). On the beach there are large bolders 10-70 litres in volume. My harness/bum engaged one of those bolders, and the resulting impact fractured my back in 3 places; L2 severely fractured on all 3 columns, T4 and T5 fractured anterially, ribs 7 fractured on both sides.
Here's some CT scans. Pre Op Left to Right CT Scan

Pre Op Front to Back CT Scan

Pre Op Top to Bottom CT Scan

Post Op Front to Back CT Scan TPS (I'm not sure if I'll beep at the airport!)

Post Op Top to Down CT Scan TPS

FAQ

1.- How do I feel now?
A: Bad; but hey shit happens and life goes on.
Update 2010-10-10: Yup it still hurts. I get cramps. I can't feel my right foot properly.

2.- Do I beep when I go through metal detectors?
A: Haven't gone through any yet.
Update 2008-5-6: I don't beep.
Update 2010-10-10: Sometimes I beep sometimes I don't, depends on the detector.

3.- You going to fly again?
A: Yes, shit doesn't always happen.
Update 2010-10-10: Haven't flown much (just 2 times)... I get scared.


4.- Don't you think paragliding is dangerous?
A: Yes, but not as dangerous as drinking Tequila.

Friday, August 31, 2007

Recursive batch delete command

We all know the scenario: we have a list with a large number of junk testing records we need to get rid of.
We could write a console app with the following:
SPListItemCollection listItems = list.Items;
for (int id = 8; id <= listItems.Count; id++)
{
 try {
  listItems[id].Delete();
  Console.WriteLine("Deleting " + id.ToString());
 }
 catch(Exception ex){ }
} 
list.Update();

Now sit back and watch the numbers tick by... or you could what is widely considered the fastest way in SharePoint (WSS) to perform the operation, to use 'ProcessBatchData' as it avoids the Object Model and is considerably faster.
Here is some example code which will remove items from a SharePoint list.
StringBuilder oSBDelBat = new StringBuilder();
oSBDelBat.Append("<?xml version=\"1.0\" encoding=\"UTF-8\"?><batch>");
foreach (SPListItem item in CurrentList.Items)
{
 oSBDelBat.Append("<method>");
 oSBDelBat.Append("<setlist scope="\">" + CurrentList.ID + "</setlist>");
 oSBDelBat.Append("<setvar name="\">" + Convert.ToString(item.ID) + "</setvar>");
 oSBDelBat.Append("<setvar name="\">Delete</setvar>");
 oSBDelBat.Append("</method>");
}
oSBDelBat.Append("</batch>");
try
{
 SPContext.Current.Site.RootWeb.ProcessBatchData(oSBDelBat.ToString());
}
catch (Exception ex)
{
 Console.WriteLine("Delete failed: " + ex.Message);
 throw;
}

Tuesday, August 28, 2007

Deploying a dll to the GAC and recycling the application pool

When developing a sharepoint dll in Visual Studio 2005 the quickest way to deploy and test your dll is to automate it with a post build event.

How do we do this?
1.- Open the properties window for your project... solution explorer> right click project name > select properties.
2.- Click "Build Events".
3.- Paste
"C:\Program Files\Microsoft Visual Studio 8\SDK\v2.0\Bin\gacutil" -i "$(TargetPath)" } C:\Recycle.vbs
in to the "Post-build event command line" field.
4.- Create a new text file with the following script:
strAppPoolName = "Sharepoint - 80"
strComputer = "."
Set objWMIService = GetObject("winmgmts:{authenticationLevel=pktPrivacy}\\"& strComputer & "\root\microsoftiisv2")
Set colItems = objWMIService.ExecQuery("Select * From IIsApplicationPool Where Name = 'W3SVC/AppPools/" & strAppPoolName & "'")
For Each objItem in colItems
    objItem.Recycle
Next
Wscript.echo "Recycle Completed"
5.- Save as C:\Recycle.vbs

Tuesday, July 31, 2007

Request for the permission of type 'System.Data.SqlClient.SqlClientPermission, System.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561

A Web part/InfoPath form with managed code causes the above error.

Cause: DLL's that access databases require at least the WSS_Medium security policy in the web.config file. If you receive a security message from the web part, it's usually the trust element in the web.config file.
You could also have a dll outside the GAC that's trying to access some part of the SharePoint Object Model.
Fix: There's a couple of ways to resolve this issue.
  1. Put you dll in the GAC. I don't like putting limited use web parts in there and managed code for InfoPath doesn't like it.
  2. Open wss_mediumtrust.config & wss_minimaltrust.config usually (C:\Program Files\Common Files\Microsoft Shared\Web Server Extensions\12\config\) look in your web.config file for the exact path.
    Find in wss_mediumtrust.config:
    <SecurityClass Name="SqlClientPermission" Description="System.Data.SqlClient.SqlClientPermission, System.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"/>
    Copy and paste it in to the <SecurityClasses> node of wss_minimaltrust.config.
    In the PermissionSet section of this configuration file, add the following: Find in wss_mediumtrust.config: <IPermission class="SqlClientPermission" version="1" Unrestricted="true"/>
    Copy and paste it in to the a <PermissionSet> node of wss_minimaltrust.config. That about covers it.
  3. You could also set the trust level to "wss_mediumtrust" or create a custom trust level. Google it...

The file or folder name contains characters that are not permitted. Please use a different name.

Creating a new site based on a custom site definition, you get the above error.
 
Cause: This error is caused by one of the aspx files in your site definition referencing and invalid master page. ei not default.master
 
Work Around: The only work around I've found is to put your custom master page in the masterpage library of the top site.
 
Even if the master page exists in both \Program Files\Common Files\Microsoft Shared\web server extensions\12\TEMPLATE\GLOBAL & LAYOUTS it will not work.


Update: OK had this issue again and its caused by the SP dll not finding the master page defined in the aspx page.
The fix is to make sure it can.
Options:
  • Put the masterpage at the site collection level, use it's absolute path (/_catalogs/masterpage/new.master or ~sitecollection/_catalogs/masterpage/new.master)
  • Use a site local masterpage library and use (~site/_catalogs/masterpage/new.master)
  • Thursday, June 21, 2007

    Using ASP.Net user controls ASCX in MOSS/WSSv3

    Chris Johnson has posted a great article on using ASP.Net ASCX user controls in MOSS/WSSv3. I have been recently creating custom controls in Visual Studio (i.e. Control Classes not ASCX). To use these I add the controls to the GAC and then add an entry to the web.config to make it a safe control. The benefit of the ASCX model is that you can develop the user control in a more visual manner.

    The ASCX controls can be used in MOSS/WSSv3 via the following method:

    1. Create a Directory called “usercontrols” in the root of your sharepoint web site on the file system E.g. C:\Inetpub\wwwroot\wss\VirtualDirectories\moss.litwareinc.com80\UserControls

    2. Open IIS manager and in the root of your SharePoint site create a VirtualDirectory called “_controls” and point it to that newly created directory.

    3. Put your user control in that newly created directory on the filesystem

    4. Open the web.config file and add the following:

    <SafeControl src="~/_controls/*" mce_src="~/_controls/*" IncludeSubFolders="True" Safe="True" AllowRemoteDesigner="True" /">

    5. In your ASPX page add the following:

    <%@ Register src="~/_controls/SomeControl.ascx" mce_src="~/_controls/SomeControl.ascx" TagName="somecontrol" TagPrefix="uc2" %">

    And…

    <uc2:somecontrol id="mycontrol1" runat="server"></uc2:somecontrol>

    6. Run your ASPX page and your control should render correctly.

    Monday, May 28, 2007

    Launch ASP.NET Web Site Administration Tool without VS

    This is copied from http://blogs.neudesic.com/blogs/phil_scott/archive/2006/07/04/187.aspx
    Thank you Phil!
    Create a batch file with:


    @echo off
    SET FrameWorkFolder=C:\WINDOWS\Microsoft.NET\Framework\v2.0.50727
    SET VFolder=Asp.NetWebAdminFiles
    SET Port=8099
    SET App=/Portal
    SET AppPath=C:\Projects\SIS\Portal\
    explorer "http://localhost:%Port%/%VFolder%/default.aspx?applicationPhysicalPath=%AppPath%&applicationUrl=%App%"
    %FrameWorkFolder%\WebDev.WebServer.EXE /port:%Port% /path:%FrameWorkFolder%\%VFolder% /vpath:/%VFolder%

    Monday, May 14, 2007

    Adding to web.config across farm with SPWebConfigModification

    A web.config modification definition is expressed as a set of commands that, when processed by the web.config manipulator in Windows SharePoint Services, changes the state of web.config. You can string together a set of these commands to ensure that they apply the desired tags and attributes within web.config. Each modification is expressed as an object in the administrative object model.

    Use the WebConfigModifications property of the SPWebApplication or SPWebService class to get the collection of web.config modifications either in the Web application or in all Web applications within the Web service.

    Here's a console app as POC.
     
    using System;
    using Microsoft.SharePoint;
    using Microsoft.SharePoint.Administration; 
    class Program { 
     private const string ScriptResourceHandler = @"<add verb=""GET,HEAD"" path=""FOO.bar"" type=""System.Web.Handlers.ScriptResourceHandler, System.Web.Extensions"" validate=""false""/>" 
     static void Main(string[] args)
     {
      SPSite siteCollection = new SPSite("http://localhost");
      SPWebApplication webApp = siteCollection.WebApplication;
      SPWebConfigModification modification = new SPWebConfigModification();
      modification.Path = "configuration/system.web/httpHandlers"
      modification.Name = "Example"
      modification.Value = value;
      modification.Owner = "ExampleOwner"
      modification.Sequence = 0;
      modification.Type = SPWebConfigModification.SPWebConfigModificationType.EnsureChildNode;
      webApp.WebConfigModifications.Add(modification); 
      // .Remove doesn't remove it from the web.config, BTW... :(
      webApp.Farm.Services.GetValue<SPWebService>().ApplyWebConfigModifications(); 
     }
    } 
    

    Friday, April 27, 2007

    Activating Site Collection Feature: Office SharePoint Server Publishing Infrastructure - Access Denied

    Cause:
    This is caused by the Application Pool user account for the web application not having rights to access the feature resource.

    Fix:
    There are a couple ways you can fix this; either give the user higher rights or more easily:

    1. Open IIS Admin.
    2. Location the Web Site for your WSS web application.
    3. Goto to the properties and select the ‘Home Directory’ tab.
    4. Change the AppPool to be the same as Central Administration.
    5. Stop/Start the Web App.
    6. Activate the Publishing Infrastructure feature on your site.
    7. Change to AppPool back to the original.
    8. Stop/Start the Web App.

    Wednesday, April 25, 2007

    Wednesday, April 11, 2007

    Saturday, March 31, 2007

    Configuring Forms Authentication with AD (Scott Hillier)

    Forms authentication allows you to configure a SharePoint page as a login form instead of utilizing Windows authentication directly. SharePoint supports many different providers for authenticating users against other data stores such as SQL Server or an LDAP service. In this exercise, you will make use of the ActiveDirectoryMembershipProvider to configure Forms authentication against Active Directory. In this scenario, users will enter their Windows credentials into the login form to gain access to the secure site.

    Follow these steps to set up Forms authentication:

    1. Log in to <machine> as the local administrator.
    2. Open the File Explorer and navigate to \Inetpub\wwwroot\wss\VirtualDirectories.
    3. Under the VirtualDirectories folder, identify the subdirectory that is associated with your site and the folder associated with the Central Administration site.
    4. Open the web.config file for both the extranet site and the Central Administration site. The provider information must be added to both files.
    5. Directly above the <system.web> tag in both files, add the following section to define a connection to Active Directory:

    <connectionStrings>
    <add name="ADService" connectionString="LDAP://vspdc.domain.
    local/DC=domain,DC=local"
    />
    </connectionStrings>

    6. Directly underneath the <system.web> tag in both files, add the following section to utilize the ActiveDirectoryMembershipProvider as the authentication provider:

    <membership defaultProvider="AD">
     <providers>
      <add name="AD" 
       type="System.Web.Security.ActiveDirectoryMembershipProvider,
    System.Web, Version=2.0.0.0, Culture=neutral,
    PublickeyToken=b03f5f7f11d50a3a"
    connectionStringName="ADService" connectionUsername="DOMAIN\Administrator" connectionPassword="P@ssw0rd" connectionProtection="None" attributeMapUsername="sAMAccountName" />
    </providers> </membership>

    7. Save and close both files.
    8. Select Start > Run. In the Run dialog, type iisreset and click the Open button.
    9. Open the Central Administration site by selecting Start Administrative Tools SharePoint 3.0 Central Administration.
    10. In the Central Administration site, click the Application Management tab.
    11. Under the Application Security section, click the link titled Authentication Providers.
    12. If the correct web application is not already selected, drop down the Web Application selection list and click Change Web Application. Then click the link for the initial web application that you set up.
    13. On the Authentication Providers page, click the Windows link associated with the Extranet zone.
    14. On the Edit Authentication page, select Forms as the Authentication Type.
    15. In the Membership Provider Name field, type AD, which is the name of the provider as it appears in the web.config file.
    16. Click the Save button.
    17. In the Central Administration site, click the Application Management tab.
    18. Under the Application Security section, click the link titled Policy for Web Application.
    19. If the correct web application is not already selected, drop down the Web Application selection list and click Change Web Application. Then click the link for the initial web application that you set up.
    20. Click the Add Users button.
    21. On the Add Users page, select Extranet from the zone list.
    22. Click the Next button.
    23. On the Add Users page, type Administrator into the Users field and click the Check Names image button.
    24. Under the Choose Permissions section, check the box labeled Full Control – Has Full Control.
    25. Click the Finish button.

    Delete shared service provider

    I can't find a link in CA, so paste the below url replacing the sspID
     
    http://server/_admin/deletessp.aspx?sspId=e3b38b19-9d73-4fb0-b248-4ae796b09fc8

    System Event Log: The application-specific permission settings do not grant Local Activation permission for the COM Server application with CLSID

    System Event log:
    The application-specific permission settings do not grant Local Activation permission for the COM Server application with CLSID
    {61738644-F196-11D0-9953-00C04FD919C1}
     to the user <machine>\SPSharedServicesPool SID (S-1-5-21-974288755-3100551457-677853593-1023).  This security permission can be modified using the Component Services administrative tool.
    For more information, see Help and Support Center at http://go.microsoft.com/fwlink/events.asp.
     
    Cause:
    This is caused by SPSharedServicesPool not having rights to start the application
     
    Fix:
    Give WSS_WPG or the specific user the necessary rights.
    Copy the GUID following the CLSID above, and Start-->Run-->regedit

    With the registry editor open, ensure that your cursor is on the computer at the beginning of the tree (make sure you are not in the middle of some previous edit session in the registry editor).

    Edit-->Find and paste in the GUID. It'll stop at the application entry - and you will want to note the application name on the right side pane. In this example, it was the IIS WAMREG admin service that popped up.

    Now, open Component Services (typically, from the server - Start-->Administrative Tools-->Component Services), expand Component Services, Computers, My Computer, DCOM Config. Scroll down and find the application (IIS WAMREG in this case). Right-Click-->Properties and select the Security tab. You'll have some options here - the first block Launch and Activation Permissions - ensure that the Customize radio button is selected, and click Edit. Now, add your service account - giving it launch and activate - and in some requirements - remote launch / activate permission.

    Restart IIS and continue on.

    Application Event Log: There is no administration site associated with the Shared Services Provider SharedServices1

    Cause:
    This is caused by there not being a web application specifically for the SSP.
     
    Fix:
    Click on Shared Services Administration > then edit SharedServices1 and click on the New Web App link.