Créer votre premier package pour Composer

28 octobre 2013 - 559 mots - developpement

Composer est un outil de gestion de dépendances pour PHP. Cela vous permet de déclarer les librairies dont votre projet a besoin, et cela les installera dans votre projet pour vous.
Mais comment à partir d’une librairie la transformer pour Composer ?

Dans cet article, le but sera de transformer la classe YATSPHP pour l’intégrer dans Packagist.

Installation de Composer

On commence par télécharger l’installeur :

1
curl -sS https://getcomposer.org/installer | php

On le déplace pour un accès global :

1
mv composer.phar /usr/local/bin/composer

Description d’un package

Le nom d’un package est composé de cette facon : « vendor/packagename ». Ainsi, pour notre exemple, le « vendor » sera « Progi1984 », et le « packagename » sera « YATSPHP ».
La structure du dossier doit être facile à comprendre et permettre la maintenance facile du projet.
Donc à la racine, il y a un dossier « src » qui contient un dossier du « vendor » qui contient le fichier de classe « packagename ».php.

1
2
3
src
- Progi1984
-- YATSPHP.php

Initialisation de votre package

Il faut d’abord vous placer dans le dossier racine du projet (celui qui contient le dossier src) et lancer un composer init.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
[franck@eureka YATSPHP]$ composer init

                                            
  Welcome to the Composer config generator  
                                            


This command will guide you through creating your composer.json config.

Package name (<vendor>/<name>) [franck/yatsphp]: progi1984/yatsphp
Description []: Yet Another System of Template, but in PHP
Author [Progi1984 <progi1984@gmail.com>]: Franck LEFEVRE <progi1984@gmail.com>
Minimum Stability []: dev
License []: Apache License

Define your dependencies.

Would you like to define your dependencies (require) interactively [yes]? no
Would you like to define your dev dependencies (require-dev) interactively [yes]? no

{
    "name": "progi1984/yatsphp",
    "description": "Yet Another System of Template, but in PHP",
    "license": "Apache License",
    "authors": [
        {
            "name": "Franck LEFEVRE",
            "email": "progi1984@gmail.com"
        }
    ],
    "minimum-stability": "dev",
    "require": {

    }
}

Do you confirm generation [yes]? yes
Would you like the vendor directory added to your .gitignore [yes]?yes

On ajoute dans le composer.json deux clés :

  • require : On définit PHP 5.3 comme pré-requis.
1
2
3
"require": {
  "php": ">=5.3.0"
}
  • autoload : On dit à Composer d’autoload tous les fichiers avec le namespace « Progi1984 » dans le dossier « src ».
1
2
3
4
5
"autoload": {
  "psr-0": {
    "Progi1984": "src/"
  }
}

Envoyer votre package à Packagist

Après avoir commité le composer.json, ajouté après l’init, il faut aller se connecter sur packagist.org.

A chaque nouveau commit, vous devrez forcer la mise à jour sur packagist à moins d’automatiser la mise à jour :

  • Aller sur votre repository
  • Aller sur la page « Settings »
  • Aller sur l’onglet « Services Hooks »
  • Choisir Packagist
  • Remplir les informations :
    • User : votre login de Packagist
    • Token : vous pouvez le récupérer sur votre page de préférences sur Packagist.org
    • Domain : packagist.org
  • Valider

Et voilà, vous avez créer votre premier package avec Composer et vous l’avez proposé au téléchargement sur Packagist.

Commentaires

Mika
Mika

Merci pour ce tutoriel, mais comment gère-t-on les versions de nos package ?
Par défault c’est dev-master 🙁

3 juin 2014 à 09:01


Progi1984
Progi1984

Pour PHPWord, on ne l’indique pas du tout dans le composer.json. Ainsi Packagist et Composer prennent les différents tags de GitHub comme numéro de version.

3 juin 2014 à 12:58


Mika
Mika

Ok merci de l’information, je vais essayer de créer des tags sur github 😉

3 juin 2014 à 15:07


Mika
Mika

Pour info mon package: https://packagist.org/packages/mkframework/mkframework

4 juin 2014 à 08:56


Progi1984
Progi1984

Bien joué… Donc ce sont bien les tags qui permettent de gérer les numéros de version.

4 juin 2014 à 09:01


Mika
Mika

Oui ce sont bien les tags, attention d’ailleurs

4 juin 2014 à 12:33


Progi1984
Progi1984

@Mika : Attention à quoi ?

4 juin 2014 à 12:56


Mika
Mika

Mon commentaire a été coupé 🙁 (je reposte sans retour chariot) Attention à ne pas préfixer les tags avec par exemple « v ». Perso, j’avais commencé par créé v4.95, il affichait partout 4.95, mais on ne pouvait pas le recuperer avec composer install, j’ai renommé le tag en 4.95 (sans le v) et c’etait ok 😉

4 juin 2014 à 17:41


Progi1984
Progi1984

@Mika : Merci de l’information. Elle pourra être utile à d’autres. Et c’est vrai que pour PHPWord, nous ne mettons pas de « v » devant nos numéros de tag.

4 juin 2014 à 17:42


Laisser un commentaire

Merci. Votre message a bien été enregistré.