Sébastien Pertus
Chapitre III : Sync Services for ADO.NET et WCF
Suite des deux premiers chapitres sur la synchronisation avec Sync Services for ADO.NET, voici un nouvel article impliquant WCF dans une synchronisation déconnectée.
Par Sébastien Pertus publié le 29/04/2008 à 09:14
 
Pour la solution de départ, nous allons partir d'une simple application, implémentant déjà une architecture WCF. La base de données reste la même que les deux premiers articles.
 
/content/0d058078-eb89-46e3-938c-6dbb400c1479/Starter.jpg
 
  1. Une application cliente : WCFClient
  2. Un projet contenant les interfaces : WCFInterfaces
  3. Un serveur de services, qui tournera grâce à WCFSvcHost: WCFService
Au départ, seul les références nécessaires à WCF ont été implémentées dans cette solution.
Note : Le Service WCF sera hébergé via WCFSvcHost.
Nous allons utiliser le designer Sync. pour créer notre synchronisation.
Sur le projet client, comme vous avez déjà l'habitude de le faire, nous allons rajouter un élément de type LocalDatabase Cache, et nous configurons notre synchronisation :
Je passe sur la définition des tables à synchronisation, je vous renvoie sur le premier article pour cette partie.
Le plus important ici est la partie « Advanced » du wizard, sur laquelle nous allons préciser que la synchronisation va se faire sur un projet serveur et un projet client :
 
/content/0d058078-eb89-46e3-938c-6dbb400c1479/Wizard01.jpg
 
Une fois validée, nous pouvons vérifier que le Wizard a bien réparti la synchronisation entre les deux projets :
D'une part le projet Client se retrouve avec :
 
/content/0d058078-eb89-46e3-938c-6dbb400c1479/Client01.jpg
 
  • Les références nécessaires pour la synchronisation cliente, avec notamment l'assembly contenant le fournisseur de synchronisation cliente (Microsoft.Synchronization.Data.SqlServerCe)
    • Notez au passage que la référence Microsoft.Synchronization.Data.Server sera utile sur le client pour l'utilisation d'une classe serveur proxy.
  • Un item de type BewiseSync.sync, qui contient un fichier BewiseSync.Designer.cs
  • La base de données déportée, au format .sdf (Sql Server Compact Edition)
  • Un Dataset représentant cette base de données en mémoire
D'autre part le projet Serveur se retrouve avec :
 
/content/0d058078-eb89-46e3-938c-6dbb400c1479/Serveur01.jpg
 
  • Les références uniquement nécessaires à la synchronisation serveur. Notez que l'assembly Microsoft.Synchronization.Data.SqlServerCe n'est pas référencée.
  • Un item de type BewiseSync.Server.sync, qui contient un fichier BewiseSync.Server.Designer.cs
  • Un fichier BewiseSync.Server.SyncContract.cs
Les classes générés cotés Client :
Afin de mieux comprendre et appréhender la structure, nous allons rentrer un peu dans le code généré par le Wizard Sync.
On peut noter que seuls les classes nécessaires au client qui ont été implémentées :
  • La classe BewiseSyncClientSyncProvider, qui hérite simplement de SqlCeClientSyncProvider : Notre fournisseur de synchronisation client pour SQL SERVER CE.
  • La classe BewiseSyncSyncAgent, qui hérite de SyncAgent : Notre orchestrateur de synchronisation.
  • Enfin les classes représentants les synctables, au nombre 5 dans mon exemple.
Si on observe un peu le code, notamment le constructeur de la classe BewiseSyncAgent :

public BewiseSyncSyncAgent(object remoteSyncProviderProxy) {

    this.InitializeSyncProviders();

    this.InitializeSyncTables();

    this.RemoteProvider = new Microsoft.Synchronization.Data.ServerSyncProviderProxy(remoteSyncProviderProxy);

    this.OnInitialized();

}

Notre constructeur prend en paramètre un type Object, au nom évocateur de remoteSyncProviderProxy.
Ce proxy va représenter notre objet proxy serveur, accessible via WCF, quelque soit le binding utilisé.
On note d'ailleurs qu'il existe dans Microsoft.Synchronization.Data, une classe représentant un ServerSyncProvider, sous forme de proxy : le ServerSyncProviderProxy, qui est utilisé dans le corps du code du constructeur.
Les classes générés coté Serveur:
Coté Serveur, nous ne serons pas surpris de ne retrouver que les classes nécessaires à la synchronisation coté serveur. Nous ne retrouvons pas de SyncAgent, celui-ci se trouvant coté client :
La classe BewiseSyncServerSyncProvider, qui hérite simplement de DbServerSyncProvider.
Les 5 SyncAdapters correspondant aux 5 syncTables à synchroniser.
Le plus intéressant reste à découvrir dans le fichier BewiseSync.Server.SyncContract.cs
Tout d'abord on y trouve une interface, taguée de multiples attributs, typique à WCF : IBewiseSyncSyncContract.
Cette interface contient 4 méthodes nécessaires à notre syncagent :
  1. ApplyChanges ()
  2. GetChanges ()
  3. GetSchema ()
  4. GetServerInfo ()
Ensuite une classe BewiseSyncSyncService, implémentant l'interface IBewiseSyncSyncContract.
Cette classe ne fait qu'encapsuler l'appel des méthodes de la classe BewiseSyncServerSyncProvider, ce choix d'implémentation restant le choix fait par l'équipe de développement du Wizard Sync ;)
Enfin on peut aussi noter l'effort de génération du Wizard Sync, qui nous propose même de récupérer le code XML généré pour l'implémentation de notre service coté serveur ;)

// *** TODO: ***

// To expose this service as an endpoint add the following to the services section of the app.config file

//

//       <service name="WCFService.BewiseSyncSyncService" behaviorConfiguration="WCFService.BewiseSyncSyncServiceBehavior">

//        <host>

//           <baseAddresses>

//            <add baseAddress ="http://localhost:8080/BewiseSyncSyncService/"/>

//           </baseAddresses>

//        </host>

//        <endpoint address ="" binding="wsHttpBinding" contract="WCFService.IBewiseSyncSyncContract"/>

//        <endpoint address="mex" binding="mexHttpBinding" contract="IMetadataExchange" />

//       </service>

//

// and the following to the serviceBehaviors section

//

//        <behavior name="WCFService.BewiseSyncSyncServiceBehavior">

//          <serviceMetadata httpGetEnabled="True" />

//          <serviceDebug includeExceptionDetailInFaults="False" />

//        </behavior>

 Commentaire - Chapitre III : Sync Services for ADO.NET et WCF 

 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