Directus: Automatiser avec la CLI

Démarrez Directus, récupérez ses identifiants et modifiez sa configuration par programmation avec la CLI Stackhero

👋 Bienvenue sur la documentation de Stackhero !

Stackhero propose un service Directus cloud, prêt à l'emploi pour la production, en seulement 2 minutes :

  • Collections, items, utilisateurs, rôles, requêtes API et transferts illimités
  • Nom de domaine personnalisable sécurisé avec HTTPS (par exemple, https://cms.votre-entreprise.com)
  • Serveur d'e-mail dédié et illimité inclus
  • Serveur de cache Redis inclus pour une haute performance
  • Performance optimale et sécurité renforcée grâce à une VM privée et dédiée.
  • Mises à jour en un clic pour une maintenance simplifiée

Gagnez du temps et simplifiez-vous la vie : il suffit de 5 minutes pour essayer la solution Directus cloud de Stackhero !

Ce guide vous montre comment créer un service Directus, lire ses identifiants et mettre à jour sa configuration entièrement en ligne de commande, sans aucun clic sur le tableau de bord. C'est idéal pour les scripts, les pipelines CI et les agents IA.

Nous allons utiliser la CLI Stackhero pour toutes les opérations. Si ce n'est pas déjà fait, vous pouvez l'installer avec :

curl -fsSL https://www.stackhero.io/install.sh | sh

La façon la plus simple de commencer est de vous connecter via votre navigateur. Lorsque vous lancez la commande de connexion, la CLI ouvre une page web où vous pouvez approuver l'accès. Aucun mot de passe ni code 2FA n'est saisi dans la CLI elle-même.

stackhero login

Après la connexion, vos identifiants sont stockés localement et seront utilisés automatiquement par les prochaines commandes CLI.

Pour les environnements entièrement automatisés comme les scripts ou les pipelines CI, vous pouvez préférer un jeton d'accès non interactif. Vous pouvez en créer un depuis votre tableau de bord (Compte > Access tokens), puis l'exporter comme variable d'environnement. La CLI, ainsi que tout script que vous exécutez, le détectera automatiquement.

export STACKHERO_TOKEN="usr-xxxxxx:your-token"

Ensuite, vous voudrez lister les stores de service Directus disponibles sur votre compte. La CLI accepte directement le nom du store (directus), il n'est donc pas nécessaire de rechercher ou copier des IDs.

# Liste les stores de service Directus (ajoutez --organization si vous en gérez plusieurs)
stackhero services-store-list --name="directus"

Vous pouvez utiliser le nom du store directus dans les commandes suivantes, ou choisir un ID spécifique svs-xxxxxx de la liste si vous le souhaitez.

# Liste les tailles d'instance pour votre store de service (utilisez la colonne NAME pour --instance)
stackhero instances-store-list --service-store=directus

# Liste les régions disponibles (noms comme "europe")
stackhero regions-list

Voici un exemple de script qui crée un stack, ajoute votre service Directus dessus, attend son démarrage, récupère sa configuration (y compris les identifiants générés), puis applique une nouvelle configuration.

#!/bin/bash
set -e

export STACKHERO_TOKEN="usr-xxxxxx:your-token"

serviceStore="directus"   # Le nom du store de service Directus (voir étape 2)
instance="..."                # Une taille d'instance de l'étape 3
region="europe"               # Un nom de région de l'étape 3

# Créez un stack pour votre service (utilise votre organisation par défaut ; ajoutez --organization si besoin)
stackId=$(stackhero --format=script stack-create \
  --name="My Directus stack")
echo "Stack créé : ${stackId}"

# Ajoutez Directus au stack (les noms sont résolus automatiquement)
serviceId=$(stackhero --format=script service-add \
  --stack="My Directus stack" \
  --service-store="${serviceStore}" \
  --instance="${instance}" \
  --region="${region}")
echo "Service ajouté : directus"

# Attendez que le service soit totalement opérationnel (cela peut prendre quelques minutes)
stackhero service-wait-for --service="directus"

# Récupérez la configuration du service, y compris les identifiants générés
stackhero service-configuration-get --service="directus" --format=json

La commande service-configuration-get retourne la configuration complète de votre service, incluant les mots de passe générés automatiquement et les informations de connexion. Le résultat est au format JSON, ce qui facilite son utilisation dans des scripts et automatisations.

stackhero service-configuration-get --service=svc-xxxxxx --format=json

Vous pouvez consulter un exemple de schéma de configuration puis appliquer vos propres paramètres. Lors de la mise à jour de la configuration, le service peut redémarrer pour appliquer les changements.

# Affichez le schéma de configuration et un exemple pour votre service
stackhero service-configuration-example --service=svc-xxxxxx

# Appliquez une configuration personnalisée (le service redémarre si nécessaire)
stackhero service-configuration-set \
  --service=svc-xxxxxx \
  --configuration='{ "...": "..." }'

# Attendez que la nouvelle configuration soit appliquée
stackhero service-wait-for --service=svc-xxxxxx

Et voilà. Vous avez maintenant vu tout le cycle de vie : démarrer un service, récupérer ses identifiants et le reconfigurer, le tout de façon scriptable et automatisée. Pour aller plus loin, consultez la documentation complète de la CLI, qui couvre également l'authentification non interactive STACKHERO_TOKEN présentée ici.