Extension:CentralNotice/fr

L'extension CentralNotice délivre des annonces (habituellement sous la forme de bannières) sur les wikis Wikimedia. Elle est beaucoup utilisée par l'équipe Fundraising pour solliciter des donnations, et pour des annonces présentant un certain intérêt pour les communautés Wikimedia et les utilisateurs. CentralNotice peut cibler les annonces par pays, par langue, par projet, par appareil et selon l'état de connexion de l'utilisateur.

Cette page contient des informations pour les développpeurs de CentralNotice et pour les administrateurs de wikis qui veulent installer CentralNotice sur leur propres sites. Pour apprendre comment créer et configurer les campagnes CentralNotice, voir Help:CentralNotice sur Meta-Wiki. Pour les informations concernant la configuration de CentralNotice sur la grappe de la Fondation Wikimedia, voir CentralNotice sur Wikitech.

CentralNotice permet la distribution centrale d'annonces vers plusieurs wikis (appelés wikis abonnés) à partir d'un wiki central (le wiki d' infrastructure). Si vous devez adresser vos messages à un seul wiki, utilisez plutôt Sitenotice à la place.

Installation


Pour les wikis

 * 1) Téléchargez le dernier instantané et développez le dans le répertoire de votre extension.
 * 2) Ajoutez à ceci :
 * 3) Par défaut, la recherche GeoIP est désactivée. Néanmoins si le cookie  est pré-populé, sa valeur sera utilisée. Pour le développement local, vous pouvez activer une implémentation côté client qui utilise https://freegeoip.net comme suit. Pour plus d'informations, voir Recherche GeoIP.



Le wiki d'infrastructure

 * 1) A partir de la ligne de commande, allez à la racine du wiki et exécutez
 * 2) Modifiez   et initialisez...
 * 3)   à
 * 4)   à un tableau de projets qui vont s'abonner au wiki central. Par exemple
 * 5) Par défaut le groupe   est le seul groupe pouvant administrer CentralNotice. Si vous avez besoin de groupes supplémentaires, assignez leur les droits   et.



Les wikis abonnés
Modifiez  et initialisez...


 * 1)   à  ;
 * 2)   pour être une entrée de  ;
 * 3)   au protocole (potentionellement neutre) et au domaine du wiki central. Par exemple  ;
 * 4)   avec l'URL de Special:BannerLoader du wiki central, par exemple :  ;
 * 5) soit   avec le nom de la base de données du wiki d'infrastructure, soit   avec le point de terminaison d'API du wiki d'infrastructure; et
 * 6)   avec l'URL de Special:RecordImpression du wiki central. Par exemple :.



Configuration rapide du développeur
Pour la plupart des tâches de développement, vous pouvez utiliser un wiki unique pour les deux rôles d'infrastructure et d'abonné. Voici des lignes d'exemple à inclure dans. (Voir les notes dans les commentaires.)

Tout code qui s'exécute sur les wikis abonnés  devrait être testé avec, pour s'assurer qu'il fonctionne avec la version mobile du site.

Dépendances
Certaines fonctionalités de CentralNotice nécessitent d'autres extensions MediaWiki, y compris et.



Obtenir de l'aide
L'équipe de la Fondation Wikimedia est composée des mainteneurs de CentralNotice. Pour les questions concernant l'installation, la remontée des bogues, ou l'utilisation de CentralNotice, veuillez adresser vos courriels à la liste de diffusion wikitech-l@lists.wikimedia.org ou nous rejoindre sur IRC canal.

Droits

 *   — autorisation nécessaire pour modifier les campagnes et les bannières. N'a de sens que que pour les wikis d'infrastrusture (voir aussi 26377).
 *   est nécessaire pour modifier le contenu de la bannière.



Concepts d'architecture
D'un point de vue utilisateur, les objets CentralNotice de niveau supérieur sont des campaigns (c'est à dire des notices) et des banners (les modèles). Ils dépendent des fonctions du système selectors et allocation.


 * Banner — un bloc unique de html/wikitext/css/javascript traductible qui va s'afficher en haut des pages de . Les selectors de l'état connecté de l'utilisateur, le type de l'appareil, la langue de l'interface utilisateur, sont appliqués aux bannières.
 * Les bannières peuvent être groupées par category. Toutes les bannières d'une catégorie partagent les cookies du côté utilisateur, telles que le cookie de masquage qui est créé quand un utilisateur clique sur le bouton de fermeture d'une bannière.
 * Campaign — une collection de bannières. Les sélecteurs de projet, pays, et de langue du contenu, s'appliquent au niveau de la campagne. Le système autorise dynamiquement autant de campagnes actives que vous désirez à un même moment en calculant une allocation pour chaque bannière dans une campagne active. Les campagnes sont définies actives si l'heure du wiki central est postérieure à la date de début de la campagne, antérieure à la date de fin de la campagne, et que la campagne est marquée comme étant active.
 * Un bucket (compartiment) et un weight (poids) sont assignés aux bannières d'une campagne. Les 'buckets' sont cependant un autre sélecteur, et les poids affectent les allocations relatives des bannières à l'intérieur d'une campagne.
 * Il existe quatre niveaux de priorité dans CentralNotice. Les campagnes des priorités les plus hautes auront une place plus importante à l'affichage des pages.
 * Les campagnes peuvent être closes (locked) ce qui empêchera la modification et la suppression de la campagne; mais non pas des bannières à l'intérieur d'une campagne.
 * Selector — toute propriété qui peut être fitrée en vue de l'allocation. Ceci permet par exemple, à différentes bannières d'être affichées aux utilisateurs connectés (respectivement à ceux qui ne le sont pas), en Argentine, et qui consultent la wikipédia anglaise.
 * Un vecteur de sélection est l'ensemble complet des sélecteurs qu'un utilisateur présente au wiki central lorsqu'il demande une bannière.
 * Allocation — La probabilité qu'une bannière soit affichée à un utilisateur pour un vecteur de sélection donné.



Documents de conception

 * Projet de recherche d'architecture 2017
 * Algorithme d'allocation des bannières
 * Schéma de la base de données / structure des tables



Recherche GeoIP
Par défaut, CentralNotice n'a pas de service de recherche GeoIP configuré coté client. Ceci est optimisé pour la configuration de production de la Fondation Wikimedia où Varnish initialise le cookie  à partir du côté serveur. (Voir Geolocation). Vous pouvez configurer CentralNotice pour qu'il utilise une source de donnée personnalisée côté client au travers de la variable de configuration. Cette variable reçoit le nom d'un module ResourceLoader qui exporte une fonction. La fonction sera appelée sans paramètre et doit retourner une promesse qui se résoud avec un objet contenant les propriétés suivantes :


 * country: chaîne - code du pays sur deux lettres.
 * region: chaîne - dépend de l'implémentation.
 * city: chaîne - nom de ville.
 * lat: nombre - lattitude.
 * lon: nombre - longitude.

Utilisation
Les instructions complètes d'utilisation se trouvent sur meta:Help:CentralNotice.



Nouvelle bannière

 * 1) Chargez Special:CentralNoticeBanners
 * 2) Cliquez sur le lien d'addition de bannière en bas de la page (vous devez être connecté en tant qu'administrateur).
 * 3) Entrer un nom et le HTML brut de la bannière concernée.
 * 4) Si cette bannière devra être traduite, entourez les texte correspondant avec des triples parenthèses -.
 * 5) Soumettre

(A FAIRE: déplacer et développer cet extrait de code)


 * Chaque bannière possède sa définition enregistrée dans MediaWiki:Centralnotice-template-&lt;name>
 * Tous ses messages sont rangés sous la bannière définie dans MediaWiki:Centralnotice-template-&lt;name>-&lt;message>/&lt;language_code>



Nouvelle campagne

 * 1) Charger Special:CentralNotice
 * 2) Ajoutez une campagne, avec une date de début donnée en bas de la partie inférieure de la page, laissez un commentaire, et cliquez pour soumettre.
 * 3) Si cette campagne ne s'exécute que sur un seul wiki et/ou ne concerne qu'une seule langue, alors sélectionnez ces valeurs dans les menus déroulants.
 * 4) Cliquez sur la nouvelle campagne et ajoutez les bannières que vous voulez y voir figurer avec leur poids respectif.
 * 5) Si tout est cohérent, activez alors cette campagne et elle s'affichera le moment voulu.



Ecraser la sélection
Ajoutez tout paramètre d'URL suivant pour prévisualiser une bannière spécifique, défier les régimes diététiques, ou déboguer la sélection de bannière pseudo-aléatoire.


 * banner
 * Vous pouvez tester une bannière directement sur n'importe quel wiki en ajoutant  à la fin de l'URL.


 * randomcampaign
 * Un nombre décimal (random seed) entre 0 et 1, utilisé pour générer les séquences aléatoires pour choisir une campagne.


 * randombanner
 * Un nombre décimal (random seed) entre 0 et 1, utilisé pour choisir une bannière parmi les bannières disponibles pour la campgne sélectionnée.


 * country
 * Réécrase le code du pays, avant de filtrer les campagnes ciblées géographiquement. Accepte deux caractères du code ISO 3166-1.


 * uselang
 * sa signification habituelle dans MediaWiki, ceci détermine quelles bannières vous pouvez afficher. En fonction de la langue du contenu par rapport à la langue de l'utilisateur.


 * force
 * Réécrase tout code de masquage de la bannière, affiche la bannière


 * reset
 * Efface tout cookie utilisé pour personnaliser l'affichage de la bannière (par exemple fourniture du compteur d'impression).

Par exemple,


 * []
 * https://it.wikisource.org/wiki/Speciale:RandomRootpage?randomcampaign=0.142

Limitations
Les bannières ne s'affichent pas sur les pages de l'espace de noms , ni sur les pages de modification, ni sur celles des diffs.

API
CentralNotice ajoute deux modules API,  et. (Le module d'API centralnoticeallocations est obsolète et a été supprimé dans MediaWiki 1.25.)



Voir aussi

 * Help:CentralNotice et Modifications après restructuration (septembre 2015) sur méta
 * Requests for comment/CentralNotice Caching Overhaul - Frontend Proxy
 * [ Autres sous-pages de cette page] (attention: beaucoup sont obsolètes)
 * Requests for comment/CentralNotice Caching Overhaul - Frontend Proxy
 * [ Autres sous-pages de cette page] (attention: beaucoup sont obsolètes)
 * Requests for comment/CentralNotice Caching Overhaul - Frontend Proxy
 * [ Autres sous-pages de cette page] (attention: beaucoup sont obsolètes)
 * [ Autres sous-pages de cette page] (attention: beaucoup sont obsolètes)
 * [ Autres sous-pages de cette page] (attention: beaucoup sont obsolètes)
 * [ Autres sous-pages de cette page] (attention: beaucoup sont obsolètes)
 * [ Autres sous-pages de cette page] (attention: beaucoup sont obsolètes)
 * [ Autres sous-pages de cette page] (attention: beaucoup sont obsolètes)