Création d'un projet de code chaîne avec l'interface de ligne de commande de générateur d'applications de chaîne de blocs
Pour créer un projet de code chaîne à l'aide de l'interface de ligne de commande de Blockchain App Builder, vous devez mettre à l'échelle un projet de code chaîne à partir d'un fichier de spécification détaillé. Le projet généré contient alors tous les fichiers dont vous avez besoin.
Contexte
init
de Blockchain App Builder initialise et affiche un projet de code chaîne prêt à l'emploi. En fonction d'une entrée simple, la commande init
peut générer des projets de code chaîne complexes qui incluent les fonctionnalités suivantes :
- Plusieurs ressources (modèles) et leurs comportements (contrôleurs)
- Générer automatiquement des méthodes CRUD (Créer/Lire/Mettre à jour/Supprimer) et non CRUD
- Validation automatique des arguments
- Marquage/désérialisation des arguments
- Fonctionnalité de persistance transparente (ORM)
- Possibilité d'appeler des requêtes enrichies
Le projet généré suit le modèle de modèle/contrôleur et décorateur, ce qui permet de spécifier les propriétés d'une immobilisation qui sont tenues à jour dans le livre en tant que champs saisis et étendues avec des comportements spécifiques et des règles de validation. Ce modèle réduit le nombre de lignes de code, ce qui facilite la lisibilité et l'évolutivité.
Prérequis
Avant de soutenir un projet, vous devez créer un fichier de spécification d'entrée. Pour plus d'informations, reportez-vous à Fichier de spécification d'entrée.
Mise à l'échelle du projet de code chaîne à l'aide de la commande init
ochain init -h
répertorie l'utilisation de la commande avec toutes ses options. La commande init
possède les options suivantes :
- --cc/-c :
Nom du projet de code chaîne. La valeur par défaut est
MyChaincode
. - --lang/l
Le langage du code chaîne échafaudé. Blockchain App Builder prend en charge Typescript (
ts
) et Go (go
). Si aucune option n'est spécifiée, la langue par défaut estts
. - --conf/-f ou --spec
Chemin d'accès à un fichier de spécification d'entrée. Blockchain App Builder lit le fichier de spécification d'entrée et génère le projet échafaudé avec de nombreux outils d'aide, qui aident à réduire l'effort de développement global. Tirer pleinement parti du fichier de spécification d'entrée peut réduire considérablement le temps de développement.
Le fichier de spécification peut être au format
yaml
oujson
. Si le chemin n'est pas spécifié, il est défini par défaut sur le répertoire en cours. Reportez-vous à Fichier de spécification d'entrée. - --out/o
Répertoire de sortie du projet de code chaîne échafaudé. S'il n'est pas spécifié, le projet échafaudé est généré dans le répertoire actuel.
La sortie est un projet de code chaîne ou de type Typescript ou Go entièrement contenu, léger et évolutif.
- --racine/r
Valide et requis uniquement pour Go. Répertoire racine de la variable GOHOME pour les codes chaîne Go. La valeur par défaut est
example.com
.
my-mac:~ name$ ochain init --cc MyNewTsProject --lang ts --conf spec.yml
Valeurs par défaut
Si aucune option n'est indiquée dans la commande ochain init
, le nom du projet échafaudé est MyChaincode
et la langue est TypeScript.
Le fichier MyChaincode.model.ts
contient une seule ressource, appelée MyAsset
, avec une propriété nommée value
. Le fichier MyChaincode.controller.ts
contient un contrôleur avec les méthodes CRUD correspondantes pour le modèle MyAsset
.
Sortie