Udostępnij za pośrednictwem


Upgrading from BT'04 GotDotNet WSS Adapter 1.0 to BT'06 native WSS Adapter

I finally found some time and tried upgrading from BizTalk 2004 and GotDotNet WSS adapter to BizTalk 2006 and the native BT'06 adapter for Windows SharePoint Services. The idea was to start from a BizTalk 2004 installation with version 1.0 of Steve Resnick & Co. WSS Adapter (https://www.gotdotnet.com/workspaces/workspace.aspx?id=0d1aa85c-cf8d-497e-84f4-3ffec8db115f) , setup a simple messaging scenario using SharePoint, upgrade to BizTalk 2006, verify that messaging still works, upgrade to the native BizTalk 2006 WSS Adapter and then verify that messaging works with the new adapter.

I followed the steps below, in order to create a sample messaging test for SharePoint:

  1. Created Source document library, then renamed it SourceDocLib (this trick causes the document library URL and the document library name to be different and this way I can see if WSSLib adapter really expects the URL or the display name of the document library). Created a View named ‘UpgradeDocuments’ that shows only those documents with ID >= 0 (probably all docs).
  2. Created document library named 'Destination', then renamed it to 'DestinationDocLib'. Created folder ‘Dest Folder’. Added columns SharePointColumn1, and SharePointColumn2.
  3. Created document library named 'Archive', then renamed it to 'ArchiveDocLib'. Created ‘My Folder’ folder in the library just created.
  4. Created receive port and receive location for WSSLib adapter. Used all the fields available in order to make sure that similar field exists in native BT'06 adapter.
  5. Created send port for WSSLib adapter, used all the fields.
    (See the exported bindings or the UI captures below to see how the ports were configured. If you want to repro my test, after importing the bindings, you will have to update the filter on the send port to process messages received from the receive location by adding BTS.ReceivePortName == WSSLib-Receive condition. Only then start the send port.)
  6. Sent test messages (see attached).
  7. Exported all bindings.

See images below for the receive location and send port settings:

WSSLib - Receive Location Receive Location XML
WSSLib - Send port (upper and lower part of configuration dialog box)
Send Port XML

Once I configured the messaging I've sent a couple of messages through (see attached) to make sure that everything is working fine.

UPGRADE

I followed these steps https://geekswithblogs.net/darko/archive/2006/01/24/66866.aspx in order to upgrade to BizTalk 2006. The upgrade went through without problems. Another place where you can find upgrade information is this blog https://blogs.msdn.com/biztalk_upgrade/default.aspx Because my BizTalk 2004 installation had the BAS feature installed, after upgrade, both BAS and Windows SharePoint Services Adapter Web Service features were installed on the machine (even though the latter does not show up as enabled in setup, it's there because BAS requires it). If your BizTalk 2004 installation didn't have BAS, after upgrading your SharePoint box, you will have to start setup, add Windows SharePoint Services Adapter Web Service feature, and configure it. That's easy and straight forward so I won't go into details.

After upgrade, I browsed to the BAS site (SharePoint site) to see if SharePoint was still working fine and it didn't. I received the following error:
This Windows SharePoint Services virtual server has not been configured for use with ASP.NET 2.0.50727.42. For more information, please refer to Knowledge Base article 894903 at https://go.microsoft.com/fwlink/?LinkId=42660 .

Troubleshoot issues with Windows SharePoint Services

The KB article just tells you to run one command. I run the command below:

stsadm.exe –o upgrade –forceupgrade –url https://demoappserver/sites/BASSite

restarted IIS and after that the BAS site shown up without problems. I started the BizTalk services that I stopped during upgrade, sent a few SharePoint messages through and everything worked fine.

Updating the ports

So I proceeded to update the receive location and send port in order to change from WSSLib adapter to 'Windows SharePoint Services' adapter. First thing I did, was to stop the BizTalk Host Instances that were used by the WSSLib adapter. This is probably not necessary, but in a couple of cases I noticed that the WSSLib ports don't shutdown appropriately and I didn't want to run into issues. After that, for each of the receive location or send port I changed the 'Transport Type' property from 'WSSLib' to 'Windows SharePoint Services' and then re-configured the send port/receive location like below.

'Windows SharePoint Services' - Receive Location Receive Location XML
'Windows SharePoint Services' - Send port (upper and lower part of configuration dialog box)
Send Port XML

Once I updated all the send ports and receive locations, I re-started the host instances, and sent a few messages through. All the messages were processed correctly in the same manner as before and this concluded my upgrade experience. Please notice that my upgrade test was done using version 1.0 of the WSSLib adapter. On GotDotNet there is an RC for the WSSLib adapter version 2.0. A comparision of that WSSLib2 adapter and BizTalk 2006 native 'Windows SharePoint Services' adapter can be found here https://blogs.msdn.com/ahamza/archive/2005/07/27/BizTalk2006WSSAdapters.aspx The only feature supported by WSSLib2 that is not available in the native BT'06 adapter is storing the Username/Password in SSO per send port/receive location. The native BT'06 adapter uses the identity of the host instance to connect and authenticate with SharePoint. Upgrade from WSSLib2 to BT'06 native WSS Adapter should be just as straight forward.

Regardless of the adapter version from which you are upgrading, if you are using some of the adapter context properties in your orchestrations you will have to update your orchestrations to use the WSS.* context properties and that will require you to recompile and redeploy your orchestrations.

WssAdapterUpgrade.zip

Comments

  • Anonymous
    September 08, 2006
    hi,

    I am creating WSS ports dynamically through orchestration. My wss site is extended at port 5000 on my server. So i am giving address in expression shape as SendTaskPO(Microsoft.XLANGs.BaseTypes.Address) = "wss://localhost:5000/sites/BTSTest/Lists/Tasks";. but it is showing me error when I am sending it to Tasks list. It is asking for Adapter Web Service Port.

    the exact error is
    The Windows SharePoint Services adapter Web service was not found at the specified URL, "http://localhost/BTSharePointAdapterWS/BTSharePointAdapterWS.asmx". The Windows SharePoint Services adapter Web service feature is required to be installed and configured on machine localhost. If the feature has been installed and configured, then verify that Adapter Web Service Port and SharePoint Site URL settings on the BizTalk port are correct.

    This error was triggered by the Windows SharePoint Services receive location or send port with URI wss://localhost:5000/sites/BTSTest/Lists/Tasks.

    My WSS adapter WS is installed on 5000 port only.


  • Anonymous
    September 08, 2006
    You also need to set the WSS adapter web service HTTP port like this before sending the message through that port

    message(WSS.ConfigAdapterWSPort) = 5000;

    See http://msdn.microsoft.com/library/en-us/BTS06CoreDocs/html/c64c43ac-05bb-427c-987a-71663ae8e43d.asp?frame=true

  • Anonymous
    May 29, 2007
    I am having BizTalk 2006 on one machine and Sharepoint 2007 on the othr machine. My wss Adapter is installed on the BizTalk machine but it does not hav ethe BAS feature and neither any wss adapter web service. Can you confirm me do I have to install the web service on the machine where biztalk is installed and do I need to make any other chnages. Any suggestion is appreciated

  • Anonymous
    May 29, 2007
    The comment has been removed