Kader Yildirim
A la découverte de BizTalk Server 2006 2/3
Développer une orchestration pour BizTalk Server 2006 R2
Par Kader Yildirim publié le 31/03/2008 à 05:22
 
L'orchestration principale est en charge de la lecture du message multi-part et de son exploitation.
La première étape consiste à créer cette orchestration. Pour cela on ajoute un élément nommé Main.odx, de type Biztalk Orchestration, au projet PipelineComponentTester créé lors du précédent article.

A cette orchestration nous allons ajouter un port qui va être le canal de réception des messages :
 
/content/b7f3d130-7db8-4733-92c7-51adeb0a53ae/NewConfiguredPort.PNG
 
Ce port a pour nom InputPort, pour type InputPortType et les autres paramètres sont les suivants :
 
/content/b7f3d130-7db8-4733-92c7-51adeb0a53ae/NewPortBinding.PNG
 
Il est important de noter que le pipeline de réception (champ Receive pipeline) est celui qui avait permis de tester le désassembleur lors du premier article.

Le message de réception est de type multi-part :
 
/content/b7f3d130-7db8-4733-92c7-51adeb0a53ae/NewMessageType.PNG
 
Le premier bloc nommé, body, correspond au message reçu dans lequel les fragments reconnus ont été remplacés par des Guid. Ce dernier est un System.Xml.XmlDocument car on ne connaît pas à l'avance son type (qui est variable selon le message reçu en entrée).
 
/content/b7f3d130-7db8-4733-92c7-51adeb0a53ae/MultipartMessage.PNG
 
On ne crée pas les autres parts dans le designer car on ne connait ni leur nombre ni leur type. Le fait de se limiter à une seule part dans l'éditeur ne tronque pas les autres parts en provenance du désassembleur ; en effet elles sont encore accessibles par programmation.

Maintenant nous allons créer le message d'entrée de type PipelineComponentTester.MultipartMessageType que nous allons nommer InputMessage, puis, dans le designer nous allons ajouter un composant de type Receive et le configurer comme suit :
 
/content/b7f3d130-7db8-4733-92c7-51adeb0a53ae/InputReceive.PNG
 
Pour mémoire dans le premier article nous avions créé quatre variables pour passer au désassembleur des variables qui :
  1. Servent à filtrer les messages au niveau de l'orchestration cliente
  2. Permettent d'attacher à la part le nom du XSD qui la valide.
Pour cela il nous faut créer un property schema auquel nous allons ajouter deux noeuds:
 
/content/b7f3d130-7db8-4733-92c7-51adeb0a53ae/DecomposerProperties.PNG
 
Un premier, pour le message BizTalk, de type MessageContextPropertyBase ce qui lui permet d'être véhiculé dans le contexte du message et donc d'être facilement accessible. Si on avait choisi le type MessageDataPropertyBase alors l'information aurait circulé dans le message même et il aurait fallu le convertir vers son type avant de pouvoir y accéder.
 
/content/b7f3d130-7db8-4733-92c7-51adeb0a53ae/MessageProperty.PNG
 
Le second noeud est utile pour les parts et il a pour type PartContextPropertyBase.

Voici donc les paramètres à donner au désassembleur au niveau du pipeline de réception:
 
/content/b7f3d130-7db8-4733-92c7-51adeb0a53ae/PipelineProperties2.PNG
 
Grâce à ces propriétés nous pouvons maintenant filtrer les messages susceptibles d'être traités par notre orchestration :
 
/content/b7f3d130-7db8-4733-92c7-51adeb0a53ae/EditFilter.PNG
 
Le filtre s'applique sur la propriété de niveau message :
 
/content/b7f3d130-7db8-4733-92c7-51adeb0a53ae/Filter.PNG
 
Plutôt que de vous montrer en fin d'article comment débugger une orchestration je vais le faire maintenant car ces techniques seront utiles pour valider au fur et à mesure le bon fonctionnement de l'application.
Pour cela nous allons déposer un composant de type Terminate sur le designer pour interrompre le traitement :
 
/content/b7f3d130-7db8-4733-92c7-51adeb0a53ae/Terminate.PNG
 
Maintenant nous allons donner le nom de l'application BizTalk qui va héberger notre projet. Si cette application n'existe pas alors elle est automatiquement créée :
 
/content/b7f3d130-7db8-4733-92c7-51adeb0a53ae/ApplicationName2.PNG
 
Si nous souhaitons debugger l'application avec le Health Activity Tracker (HAT, nous allons découvrir cet outil dans un instant), il ne faut pas oublier d'activer la génération des pdb en sélectionnant l'option Generate Debugging Information dans le menu build de la section Configuration Properties.

Nous pouvons enfin déployer l'application avec Visual Studio :
 
/content/b7f3d130-7db8-4733-92c7-51adeb0a53ae/Deploy.PNG
 
Il faut maintenant activer les ports de réception dans la console d'administration de Biztalk :
 
/content/b7f3d130-7db8-4733-92c7-51adeb0a53ae/StartReceiver2.PNG
 
Puis préciser le nom du host dans lequel l'orchestration va s'exécuter :
 
/content/b7f3d130-7db8-4733-92c7-51adeb0a53ae/Host.PNG
 
On peut enfin démarrer l'orchestration :
 
/content/b7f3d130-7db8-4733-92c7-51adeb0a53ae/StartODX.PNG
 
Le test consiste à placer le fichier XML vue lors du premier article dans le répertoire c:\test\in puis à utiliser la console d'administration pour récupérer les messages reçus par l'orchestration afin d'afficher leurs détails :
 
/content/b7f3d130-7db8-4733-92c7-51adeb0a53ae/GetResult1.PNG
 
L'affichage correspond à nos attentes :
  1. Il y a bien un message multi-part composé de cinq parts dont le premier est le body (le Guid zéro)
  2. Le contexte du message contient bien notre propriété DecomposerMessageProperty
 
/content/b7f3d130-7db8-4733-92c7-51adeb0a53ae/Result1.PNG
 
Depuis cet écran il est possible de lancer le debugger d'orchestration :
 
/content/b7f3d130-7db8-4733-92c7-51adeb0a53ae/Debug1.PNG
 
Ce dernier lance le HAT. Là il faut s'attacher à l'application BizTalk pour suivre le cheminement du message:
 
/content/b7f3d130-7db8-4733-92c7-51adeb0a53ae/Attach1.PNG
 
Si votre compte de travail ne fait pas parti du groupe BizTalk Server Administrators alors une erreur d'affiche. Pour résoudre ce problème il suffit de mettre le compte de travail dans ce groupe.
 
/content/b7f3d130-7db8-4733-92c7-51adeb0a53ae/RightsError.PNG
 
Si on souhaite debugger le code du désassembleur par exemple, en plus de la technique vue lors du dernier article, vous pouvez vous attacher au process BTSNTSvc.exe et profiter de toutes les fonctionnalités de Visual Studio.
 
/content/b7f3d130-7db8-4733-92c7-51adeb0a53ae/AttachProcess.PNG
 
La première question qui vient à l'esprit est comment parcourir les parts du message d'entrée sachant qu'on ne connaît à l'avance ni leur nombre ni leur nom. Si on inspecte le code généré avec reflector on note qu'un message multi-part est un message XLANG qui implémente l'interface IEnumerable et qui offre des indexeurs pour accéder aux parts par leur nom ou index :
 
/content/b7f3d130-7db8-4733-92c7-51adeb0a53ae/PartsIteratorReflector.PNG
 
Pour accéder aux méthodes de cette interface il faut convertir notre message vers sa classe de base (sous le designer de BizTalk les méthodes héritées ne sont visibles qu'au niveau de la classe qui les implémente, dans notre cas XLANGMessage). Pour cela nous allons créer une variable de type XLANGMessage :
 
/content/b7f3d130-7db8-4733-92c7-51adeb0a53ae/BaseMessageVariable.PNG
 
Au niveau de l'orchestration nous allons ajouter un composant de type Set variables et faire les affectations suivantes :
InputBaseMessage = InputMessage;
Index = 0;

Ensuite il faut ajouter un composant de type loop pour parcourir les parts grâce à l'expression suivante :
Index < InputBaseMessage.Count
 
/content/b7f3d130-7db8-4733-92c7-51adeb0a53ae/Step2.PNG
 
Maintenant il nous reste à récupérer chaque part et à la traiter.
Une part est de type Microsoft.XLANGs.BaseTypes.XLANGPart, il faut donc céer une variable de ce genre pour acceuillir la part courante :
Part = (Microsoft.XLANGs.BaseTypes.XLANGPart)InputBaseMessage[Index];

Le nom du schema associé à la part est contenu dans la propriété PipelineComponentTester.DecomposerPartProperty car c'est à cet emplacement que le désassembleur a stocké cette information. Pour cela on ajoute un composant Set variables nommé Get part sur le designer avec le code suivant :
PartSchemaName = (System.String)(Part.GetPartProperty(typeof(PipelineComponentTester.DecomposerPartProperty)));

L'orchestration ressemble maintenant à ceci :
 
/content/b7f3d130-7db8-4733-92c7-51adeb0a53ae/Step3.PNG
 
Pour décider quelle sous-orchestration appeler nous allons ajouter un composant Decide qui fait un switch sur le nom du XSD retourné par la part. Dans notre cas elle se déclenche si la condition PartSchemaName == "SchemasContainer.City" est vraie :
 
/content/b7f3d130-7db8-4733-92c7-51adeb0a53ae/Step6.PNG
 
Nous allons maintenant créer une orchestration fille qui est spécialisée dans le traitement d'un message compatible avec le XSD City :

  <?xml version="1.0" encoding="utf-16" ?>

- <xs:schema xmlns:b="http://schemas.microsoft.com/BizTalk/2003"

            xmlns="http://www.thb.com/schemas/0"

            attributeFormDefault="unqualified"

            elementFormDefault="qualified"

            targetNamespace="http://www.thb.com/schemas/0"

            xmlns:xs="http://www.w3.org/2001/XMLSchema">

  <xs:element name="Ville" type="xs:string" />

  </xs:schema>

 Commentaire - A la découverte de BizTalk Server 2006 2/3 

 Dernières Publications      

Utilisation de jQuery avec ASP.NET MVC
  Développer une IHM à page unique avec ASP.NET MVC et jQuery
par Nicolas Moyère posté le 30/06/2008 à 10:28, lu 824 fois, #0
Tags: ASP.NET MVC, Ajax
Windows Media Center et WCF : développez votre maison intelligente
  Le développement d'applications pour Windows Media Center est facilité avec l'arrivée du SDK 5.3. Même si l'on sent un modèle objet bien lourd derrière, il devient plus facile d'exposer les fonctionnalités de WMC sous la forme de services WCF.
par Frédéric Colin posté le 23/06/2008 à 08:04, lu 891 fois, #0
Notions avancées avec Biztalk Server 2006 R2
  Utilisation des notions d'interchange, corrélation et convoi avec BizTalk Server 2006 R2
par Kader Yildirim posté le 09/06/2008 à 08:04, lu 705 fois, #0
Lucene Persistence Engine pour Evaluant Universal Storage Services
  Suite à l'article de Laurent Kempé, voici un moteur de stockage pour EUSS permettant l'indexation d'entités métier avec Lucene.
par Nicolas Penin posté le 01/06/2008 à 23:38, lu 1091 fois, #1
Tags: C#, Linq
XMLA Trivia : Découverte du XMLA
  Le XMLA (XML for Analysis) est un langage normalisé par plusieurs éditeurs BI pour simplifier l'accès aux données aux cubes et aux métadonnées des bases multidimensionnelles.
par Renaud Harduin posté le 25/05/2008 à 11:57, lu 1008 fois, #1
Exploiter les données CSV via Linq en toute simplicité
  A partir du requêteur dynamique fourni en exemple avec Visual Studio 2008, nous allons essayer de remplir les propriétés d'un ensemble d'objets à partir des données d'un fichier CSV. Nous enrichirons aussi le parseur de nos propres fonctions.
par Frédéric Mélantois posté le 17/05/2008 à 11:41, lu 2784 fois, #0
Comment manipuler simplement le contenu d'un fichier WordML ?
  Manipulations autour du format WordML
par Fabien Reinle posté le 14/05/2008 à 23:55, lu 1405 fois, #0
Polymorphisme et contrats de données WCF
  WCF aborde les types polymorphes du point de vue de la sérialisation. En effet, la connaissance du type réel potentiel est rendue nécessaire dès la description du contrat de données. Une fois n'est pas coutume, j'ai réalisé l'exemple en VB.NET.
par Frédéric Colin posté le 14/05/2008 à 08:40, lu 2931 fois, #2

 Dernières Actualités      

Reprise du projet Reflector par RedGate
  La nouvelle était connue depuis quelques jours par les développeurs de plugins, mais c’est désormais officiel : Lutz Roeder, le responsable de Reflector confie à la société RedGate le futur du projet....
Microsoft publie Visual Studio 2008 Service Pack 1
  Il est recommandé d’utiliser l’outil Visual Studio 2008 Service Pack preparation Tool avant de faire l’installation du Service Pack si vous avez installé des versions béta sur votre machine. Une fois que...
Tags: Framework .NET, Visual Studio 2008
Evaluant dévoile ses sources
  L'ensemble des projets R&D réalisés par les consultants de la SSII Evaluant sont en cours de publication sur CodePlex . L'objectif est de les centraliser et surtout d'augmenter leur visibilité. L'avantage...
Le Silverlight Tour en français!
  Le Silverlight Tour passe maintenant dans les pays francophones! En effet RunAtServer Consulting est partenaire du Silverlight Tour pour la gestion de cette formation Silverlight en français à commencer...
Microsoft publie ASP.NET AJAX 4.0 CodePlex Preview 1
  Cette pré-version contient les améliorations suivantes: Client-side template rendering Declarative instantiation of behaviors and controls DataView control Markup extensions Bindings Vous pouvez en lire...
Tags: Ajax
Deep Earth – Une belle utilisation de Virtual Earth et de Silverlight Deep Zoom
  Ce projet très intéressant est disponible sur Codeplex et vous pouvez voir une démo sur la page suivante . Bien entendu comme touts les projets sur Codeplex vous avez accès aux sources....
Tags: Silverlight