Bienvenue à Blogs CodeS-SourceS Identification | Inscription | Aide

The Mit's Blog

En plus d'intégrer et skier, il sait même écrire !
(Blog de Renaud Comte)

Actualités

[Best Practices] Customisation du My Site : Comment le modifier en amont et en aval

Sous entendu comment modifier les My Site de MOSS 2007 avant création et leur maintenance après création.

Le "My Site" est clairement une fonction incontournable de SharePoint 2007 lorsqu'il s'agit de gérer la notion de personnalisation et de réseau social.

Tout simplement, un "Must have".

Je vois déja certains douter et me rappeler les fameuses ritournelles :

  • C'est inutile
  • Mes utilisateurs, ils n'ont pas besoin de zones personnelles
  • C'est une clé usb en ligne
  • Tout mon savoir est dans des documents
  • Le moteur de recherche est bien suffisant
  • ......

Oui, et plus encore 
>>> Si vous vous reconnaissez dans les dernières remarques, attention, vous passez vraiment à coté d'une véritable mine d'or !!!

Je suis un converti /convaincu de l' intérêt réelle et de l'importance du "My Site". Cependant, comme tout bon développeur / intégrateur, ma seconde passion est la curiosité sur la customisation complète du modèle "My Site".

Certes la version "Out Of The Box" est déjà bien pensée, pourquoi ne pas aller encore BIEN plus loin

(N'est ce pas Patrick S. ?)

Nous sommes bien en technologie SharePoint donc vous connaissez déjà bien les bases :

  • C'est forcément plus compliqué que l'on pensait
  • Encore (et toujours) des Features + des solutions
  • Au pire ce n'est que de l'ASP.Net, donc pas de soucis

Voici quelques recommandations de premier ordre

  1. Le modèle ou "Site Definition" utilisé est le SPSMSite
    >>> Comme tout modèle de site installé par MS, il hérite du modèle Global et de plus, ne peut être mis à jour directement !
  2. Le "My Site" est géré par une Web Application séparée de votre portal via le Shared Services Provider.
    Mais ce n'est pas tout : chaque nouvelle création de "My Site" génére une nouvelle Site Collection

    Soit les avantages / inconvénients inhérents
    • utilisation de quotas dédiés
    • indépendance des "My Site" entre eux (ce sont des SPSite donc des "pyramides bien étanches en terme de gestion)
      • Attention au déploiement commun
      • Attention à l'autonomie des propriétaires
      • Pas de partage ou de centralisation des
        • content types,
        • des site columns,
        • des master pages,
        • des WebParts,
        • ...
  3. Un My Site existe en pratique sous 2 formes bien distinctes et séparés :
  4. La meilleur et unique manière de faire évoluer le modèle de "My Site" est de s'appuyer sur la notion de Site Stapling
    >>> sous entendu, utilisez la dépendance sur l'identifiant "SPSPERS#0" pour déployer tout un set de feature.

    Genre

    <Feature

    Id="4457E66E-6FCD-4352-AD4D-B870600B4696"

    Title="My Site Creation Feature Stapler"

    Scope="Farm"

    xmlns="http://schemas.microsoft.com/sharepoint/" >

    <ElementManifests>

    <ElementManifest Location="elements.xml" />

    </ElementManifests>

    </Feature>

    ------------------------------------------------------------

    <Elements xmlns="http://schemas.microsoft.com/sharepoint/" >

    <FeatureSiteTemplateAssociation

    Id="4DEFA336-EDC4-43cb-9560-FE2E27E76DFB"

    TemplateName="SPSPERS#0"/>

    </Elements>


    Donc, porte ouverte à toutes vos features avec ou sans Event Receivers.
    >>> C'est n'est point un mal, faire des features reste et restera le meilleur Best Practice de la plate forme SharePoint

    A noter que pour gérer l'ajout/edition/modification de WebPart, la solution ne se trouve pas forcément dans le FeatureReceiver mais plutôt par une petite astuce : un webcontrol discret de votre Master Page
    >>> Pourquoi ? simplement un soucis de cycle de vie : le SPFeatureReceiver via stapling s'execute simplement trop tôt, les bibliothéques de pages et les pages n'existant pas encore, vous ne pouvez les modifier  ... 

    Le tout est très bien documenté et expliqué dans un post du blog du Team SharePoint
  5. Le CAML des différents fichiers éléments d'une Feature ne peuvent cependant pas tout faire ...
    Mais rien n'empêche d'aller plus loin via les fameux et pourtant si simples Feature Receiver.
    >>> Vous pouvez ainsi accéder à tout le modéle objet SharePoint/.Net ainsi que le contexte du SPWeb nécessaire.
    Comme par exemple :
    • Rajouter des pages à WebParts
    • Ajouter des WebParts et les postionnez dans une page, même l'accueil
    • Reconfigurez les propriétés d'une WebPart
      >>> le tout via la classe :
      SPLimitedWebPartManager theMan = thePage.GetLimitedWebPartManager(System.Web.UI.WebControls.WebParts.PersonalizationScope.Shared)
  6. Si le mécanisme peut vous paraître finalement simple, retenez aussi que l'architecture du My Site ne repose pas que sur la notion de site collection et d'un modèle. il y a tout un système de vue publique/privée, d'accès et redirection ainsi que le systéme de création.
    En résumé :
    image 
    Pour plus de détails, je ne saurais trop vous conseiller la lecture du post de Mark Arend : MySite Pages and Architecture. Tout y est détaillé, classes et pages applicatives comprises.

 

Annexe de référence (à avoir absolument dans ses favoris ou dans son onenote) :

 

Bonne lecture et bonne personnalisation !

 

Renaud Comte aka TheMit (Me me me, still me)
Member of WygTeam
http://www.wygwam.com

Ce post vous a plu ? Ajoutez le dans vos favoris pour ne pas perdre de temps à le retrouver le jour où vous en aurez besoin :
Posted: vendredi 5 septembre 2008 10:47 par themit

Commentaires

Pas de commentaires

Les commentaires anonymes sont désactivés

Les 10 derniers blogs postés

- [Refactoring] ReSharper pour Visual Studio 2010 (Preview) par Thomas Jaskula le il y a 18 minutes

- [Refactoring] Analyser vos exceptions avec ReSharper Exceptional par Thomas Jaskula le il y a 1 heure et 32 minutes

- SharePoint 2007 : patterns & practices SharePoint Guidance par Philippe Sentenac [MVP SharePoint] le il y a 15 heures et 11 minutes

- [Visual Studio 2010] Les tests cases c’est bien, mais je vais devoir tout réécrire ? par Etienne Margraff le il y a 16 heures et 8 minutes

- MVP[Gribouillon].AddYear par The Grib's Lair [Sébastien PICAMELOT - MVP SharePoint] le il y a 16 heures et 23 minutes

- Clinique INSIA - Projet de fin d’Etudes (Silverlight 3 MVVM et OutOfBrowser, WCF, TFS) - Part 1 par David REI le 07-02-2009, 23:38

- C’est la crise ? Bah pourquoi cramer du budget pub alors ? par Nix's Blog le 07-02-2009, 15:31

- Soyons MVP ! par TheSaib .NET blog le 07-02-2009, 12:15

- SharePoint : Gestion des Erreurs 6398, 7076 et 6482 par Blog Technique de Romelard Fabrice le 07-02-2009, 11:53

- EF avec WPF par Matthieu MEZIL le 07-02-2009, 10:18