Yeoman Generator to jump-start Full-Stack Cloud Applications
First, install Yeoman and generator-saphanaacademy-mta using npm
npm install -g yo
npm install -g generator-saphanaacademy-mta
We assume you have pre-installed node.js and the Cloud Foundry CLI with the multiapps plugin. In order to build the project ensure the Cloud MTA Build Tool (MBT) is installed. This is already the case for SAP Business Application Studio.
If using SAP HANA Cloud ensure you have created an instance and have configured a database mapping to the SAP BTP, Cloud Foundry runtime org and space that you will be deploying to.
Ensure that you are logged in to the SAP BTP, Cloud Foundry runtime CLI and are targeting the org and space into which you want to deploy the app.
To generate your new project:
yo saphanaacademy-mta
NB: If you prefer a rich user experience when generating your projects consider the Application Wizard.
We assume you have pre-installed node.js, have a Docker Hub ID and the ability to build and push containers either via Docker Desktop or an alternative such as Paketo Builder with the pack CLI, Rancher Desktop or podman or a CI/CD pipeline with kaniko.
The Kubernetes command-line tool kubectl is required with the kubelogin extension.
In order to build or deploy the project via the Makefile ensure that GNU Make is installed.
In order to deploy the project ensure that Helm is installed or use a CI/CD pipeline.
If using SAP HANA Cloud ensure you have created an instance and have configured a database mapping to the SAP BTP, Kyma runtime namespace that you will be deploying to.
Ensure that you have set the KUBECONFIG environment variable, have optionally created a namespace into which you would like to deploy the project and are logged in to Docker Hub. For example:
Mac/Linux:
chmod go-r {KUBECONFIG_FILE_PATH}
export KUBECONFIG={KUBECONFIG_FILE_PATH}
kubectl create ns dev
docker login
Windows:
$ENV:KUBECONFIG="{KUBECONFIG_FILE_PATH}"
kubectl create ns dev
docker login
You can also specify the path to your Kubeconfig file in the generator.
To generate your new project:
yo saphanaacademy-mta
NB: If you prefer a rich user experience when generating your projects consider the Application Wizard.
To build and push your project containers to Docker Hub:
cd <projectName>
make docker-push
If you prefer, you can issue the build & push commands manually (see the generated /Makefile) or use a CI/CD pipeline.
To deploy your new project to SAP BTP, Kyma runtime:
cd <projectName>
make helm-deploy
If you prefer, you can issue the helm commands manually (see the generated /Makefile) or use a CI/CD pipeline.
To undeploy your new project from SAP BTP, Kyma runtime:
cd <projectName>
make helm-undeploy
Please pay special attention to messages produced by the generator - especially those regarding setting of API keys & credentials!
- Yeoman has a heart of gold.
- Yeoman is a person with feelings and opinions, but is very easy to work with.
- Yeoman can be too opinionated at times but is easily convinced not to be.
- Feel free to learn more about Yeoman.
Copyright (c) 2022 SAP SE or an SAP affiliate company. All rights reserved. This project is licensed under the Apache Software License, Version 2.0 except as noted otherwise in the LICENSE file.