Maison > développement back-end > tutoriel php > Packages de compositeurs privés avec Gemfury

Packages de compositeurs privés avec Gemfury

Joseph Gordon-Levitt
Libérer: 2025-02-19 09:19:12
original
358 Les gens l'ont consulté

Private Composer Packages with Gemfury

Points clés

  • GEMFURY est une solution de plate-forme en tant que service (PAAS) pour héberger des forfaits de compositeurs privés, offrant une alternative aux options d'auto-hébergement telles que Toran Proxy ou Satis. Il prend en charge plusieurs langues, notamment le package PHP Composer, Ruby Gems, Node.js NPM, Python PYPI, APT, YUM et NU-GET.
  • Pour utiliser Gemfury, vous devez créer un compte, créer un package et le télécharger sur la plate-forme. Cela peut être fait en utilisant Git et en faisant gérer Gemfury le reste, ou en zippant manuellement le code source du package et en le téléchargeant sur le tableau de bord Gemfury.
  • Vous pouvez ajouter votre référentiel privé au fichier composer.json de votre projet. Cela vous permet d'utiliser tous les packages de compositeurs privés que vous créez avec Gemfury sans ajouter de référentiel séparé chaque fois que vous souhaitez utiliser le package.
  • Gemfury fournit également un outil de ligne de commande pour gérer vos packages. Cet outil vous permet de répertorier vos packages, d'afficher les versions de packages spécifiques, etc. Vous pouvez l'installer en utilisant la commande sudo gem install gemfury.

Supposons que vous connaissiez le compositeur, c'est le dernier et probablement le meilleur gestionnaire de packages PHP. Sinon, consultez l'introduction d'Alexander et je suis sûr que vous serez immédiatement attiré par elle. Vous devez avoir ses connaissances pratique pour tirer le meilleur parti de cet article.

Composer fonctionne de manière efficace et transparente avec Packagist, un référentiel complet de packages publics.

Cependant, tôt ou tard, vous rencontrerez un package que vous avez écrit vous-même, qui pour une raison quelconque ne peut pas être open source et partagé gratuitement via Packagist.

Il existe plusieurs options pour héberger ces forfaits privés. Vous pouvez configurer le fichier composer.json du projet en ajoutant séparément le référentiel du package. Alternativement, SATI vous permet de générer votre propre référentiel statique. Alternativement, Toran Proxy vous permet de créer une version privée auto-hébergée de Packagist qui, une fois configuré, est plus facile à gérer que de spécifier un référentiel dans votre composer.json.

Gemfury est une alternative au PaaS. Outre la tranquillité d'esprit (bien qu'il soit payé), les solutions hébergées sont un énorme avantage qu'il prend en charge non seulement le package PHP Composer, mais aussi Ruby Gems, Node.js NPM, Python PYPI, APT, YUM et NU -Obtenir. Ceci est très utile si vous avez plusieurs langues.

Plongeons comment l'utiliser.

Configurez votre compte

Tout d'abord, vous avez besoin d'un compte. Il y a une période d'essai de 14 jours, avec un compte gratuit limité à un collaborateur et à un forfait d'hébergement, et une gamme d'autres plans à partir de 9 $ par mois.

Vous pouvez vous inscrire à l'aide de votre adresse e-mail ou de votre compte GitHub. Allez sur le site Web pour vous inscrire.

Créez votre premier package

Pour démontrer comment utiliser Gemfury pour un package de compositeurs privé, créons un package étape par étape que nous soumettrons au service à utiliser dans d'autres projets plus tard.

La façon la plus simple de créer un nouveau package est d'utiliser la commande suivante:

composer init
Copier après la connexion
Copier après la connexion

Il vous pose une série de questions;

<code>...  (此处省略与原文相同的composer init交互过程) ...</code>
Copier après la connexion
Copier après la connexion
Comme vous pouvez le voir, nous créons un package simple avec un seul Faker de dépendance.

Ensuite, ajoutons une ligne au nouveau créé

et disons-le où trouver le code source du package. composer.json

"autoload": {        
    "psr-0": {
        "Acme\": "src/"
    }
},
Copier après la connexion
Copier après la connexion
Créons maintenant le package lui-même. Nous allons créer une classe avec un seul objectif; générer des codes de réduction pour les plates-formes de commerce électronique à l'aide d'algorithmes propriétaires complexes et top secrets.

Dans votre répertoire de travail, créez les répertoires

et src, puis créez le fichier suivant nommé src/Acme: Coupon.php

<?php namespace Acme;

use Faker\Factory;

class Coupon {

    public static function generate($percent) 
    {
        $faker = Factory::create();

        return sprintf('%s-%s-%d',
            strtoupper(date('M')),
            strtoupper($faker->word()),
            intval($percent));
    }

}
Copier après la connexion
Copier après la connexion
Exécutez maintenant

pour charger nos seules dépendances et configurer l'autoloader. composer install

C'est le package que nous avons construit. Maintenant, téléchargez-le sur Gemfury.

pour continuer, vous avez besoin de votre clé API. Si vous accédez à votre tableau de bord, vous le trouverez sous Paramètres.

La façon la plus simple de construire et de télécharger un package est simplement d'utiliser Git et de laisser Gemfury gérer le reste.

Créez d'abord un fichier

avec le contenu suivant: .gitignore

<code>vendor/
composer.lock</code>
Copier après la connexion
Copier après la connexion
Initialiser le référentiel maintenant:

git init
Copier après la connexion
Ajouter un fichier:

git add src
git add composer.json
Copier après la connexion
Maintenant, nous allons ajouter un référentiel distant GIT. Vous pouvez trouver l'URL pertinente en sélectionnant le démarrage du tableau de bord Gemfury, puis en sélectionnant l'onglet PHP Composer. Cela ressemblera à ceci:

<code>https://your-username@git.fury.io/your-username/<package-name>.git</code>
Copier après la connexion
Assurez-vous de remplacer

par votre nom d'utilisateur Gemfury (si vous vous inscrivez avec GitHub, ce sera le même que votre nom d'utilisateur GitHub) et l'ajoutez en tant que référentiel distant: your-username

git remote add fury https://your-username@git.fury.io/your-username/coupon.git
Copier après la connexion
À ce stade, vous avez deux choix. La première consiste à utiliser le contrôle de version explicite, où vous spécifiez la version dans le fichier

, comme indiqué ci-dessous: composer.json

{
    "name": "your-username/coupon",
    "description": "Generates a coupon code",
        "version": "1.0.0",
    ...
Copier après la connexion
Il est important que vous utilisiez le versioning sémantique. Sinon, votre package peut ne pas être construit correctement;

ou, vous pouvez utiliser la balise git. Par exemple, créez une nouvelle version avec une balise, comme illustré ci-dessous:

git tag -a 1.0.0 -m "Version 1.0.0"
Copier après la connexion
Quelle que soit la méthode que vous prenez, l'étape suivante consiste à soumettre:

git commit -a -m "Initial commit"
Copier après la connexion
Enfin, exécutez la commande suivante:

git push fury master --tags
Copier après la connexion
Cela pousse votre code à Gemfury, qui le construira ensuite automatiquement dans un package.

Maintenant, si vous accédez à votre tableau de bord, vous devriez voir que votre nouveau référentiel est répertorié. Ensuite, voyons comment vous l'utilisez dans votre projet.

Utilisation du package privé

Si vous revenez au tableau de bord et sélectionnez "Reposs" à gauche, vous trouverez votre URL de référentiel privé. Cela doit être maintenu privé, alors assurez-vous de le protéger. Cela ressemblera à ceci:

<code>https://php.fury.io/SECRET-CODE/your-username/</code>
Copier après la connexion
C'est

qui le rend imprévisible et est donc en fait privé. SECRET-CODE

Ajoutez-le maintenant aux

: composer.json de votre projet

composer init
Copier après la connexion
Copier après la connexion

Il vous suffit d'ajouter ce référentiel pour utiliser tous les packages de compositeurs privés que vous avez créés avec Gemfury. Il n'est pas nécessaire d'ajouter un référentiel séparé chaque fois que vous souhaitez utiliser le package.

Maintenant, vous pouvez avoir besoin de votre forfait privé comme vous le faites sur Packagist. Voici un exemple complet d'un projet composer.json:

<code>...  (此处省略与原文相同的composer init交互过程) ...</code>
Copier après la connexion
Copier après la connexion

Autres méthodes

Personnellement, je crois que l'utilisation de Git et des balises est le moyen le plus simple et le plus efficace de gérer les packages.

ou, si vous préférez, vous pouvez le construire vous-même en zippant le code source du package et en le téléchargeant sur le tableau de bord Gemfury.

outil de ligne de commande

Gemfury fournit également un outil de ligne de commande. Pour l'installer:

"autoload": {        
    "psr-0": {
        "Acme\": "src/"
    }
},
Copier après la connexion
Copier après la connexion

Pour répertorier votre package, vous pouvez utiliser la commande suivante:

<?php namespace Acme;

use Faker\Factory;

class Coupon {

    public static function generate($percent) 
    {
        $faker = Factory::create();

        return sprintf('%s-%s-%d',
            strtoupper(date('M')),
            strtoupper($faker->word()),
            intval($percent));
    }

}
Copier après la connexion
Copier après la connexion

pour afficher la version d'un package spécifique:

<code>vendor/
composer.lock</code>
Copier après la connexion
Copier après la connexion

Pour plus d'informations sur la CLI, veuillez visiter les sections pertinentes de la documentation.

Résumé

Dans cet article, je présente Gemfury, l'une des nombreuses options de gestion des référentiels privés. En tant que solution de PaaS, il ne nécessite pas le fardeau supplémentaire des options d'auto-hébergement comme Toran et est plus facile à utiliser que les Satis. Il a également l'énorme avantage de prendre en charge les packages dans une variété de langues, des packages PHP Composer à Ruby Gems et Node.js NPM. Bien sûr, en tant que solution de PaaS, elle doit payer pour cela - mais pourquoi ne pas l'essayer avec un essai gratuit ou un plan unique pour voir si cela vous convient?

(La partie FAQ d'origine est omise ici parce que cette partie est une question fréquemment posée, et elle a une répétition élevée du contenu principal de l'article, et sa valeur n'est pas élevée après la pseudo-originalité.)

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal