This package is part of the Axinom Mosaic development platform. More information can be found at https://docs.axinom.com.
This mono-repo and all packages contained within it are licensed under the MIT License. Check the LICENSE file for more details.
This repository contains the customizable parts of an Axinom Mosaic solution. The code included in that repository can be either used as is or customized to your specific requirements. The Mosaic libraries and services used by that solution will be provided, updated and maintained by Axinom.
To get started with developing your own customized solution based on the Mosaic Media Template, run the following command:
npx -p @axinom/mosaic-cli@latest mosaic create
This process will guide you through the creation of a new Mosaic project based
on the Mosaic Media Template.
See
the CLI documentation
for more details.
Before using the customizable solution make sure that you have the following software installed:
- node.js of version 18.* needs to be installed.
- Version 18.15.0 is confirmed to work, where other versions may work as well, but would need to be tested
- To install node.js via a package manager, see node.js documentation.
- Yarn
- Docker
This solution comes with a 'dockerized' infrastructure for local development. It
consists of PostgreSQL and pgAdmin. To start/stop the infrastructure run
yarn infra:up
and yarn infra:down
accordingly. See
Prepare the solution section below for additional info
on how to start the development infrastructure.
You need to configure Docker for Windows to use Linux containers, see Docker documentation.
For a better development experience i.e. being able to run docker
commands
without sudo
, please see
Docker post-installation steps for Linux.
⚠️ This section is describing the steps on how to setup the solution for development purpose. If you're interested in how to prepare the services for production use please continue reading here.
-
Run
yarn
to install all package dependencies for the workspace. -
Run
yarn apply-templates
to create local copies of all*.template
files in the solution. -
Run
yarn infra:up
to start the development infrastructure. -
Run
yarn db:reset
to create the databases for all services in the solution. -
Set the following parameters in the root
.env
that are specific to your development environment:TENANT_ID
ENVIRONMENT_ID
RABBITMQ_VHOST
RABBITMQ_USER
RABBITMQ_PASSWORD
DEV_SERVICE_ACCOUNT_CLIENT_ID
DEV_SERVICE_ACCOUNT_CLIENT_SECRET
You will get these values from the 'Environment Connection' station on the Environment Administration Portal. For a description of how to create a new environment and getting the required connection values, please follow the steps described here.
-
Run
yarn setup
to initialize all the services in the solution.
⚠️ This section is describing the steps on how to run the solution for development purpose. If you're interested in how to prepare the services for production use please continue reading here.
Start the following commands in parallel (in separate terminals):
- Run
yarn dev:libs
to start the compilation for themedia-messages
package in watch mode. Wait until this finishes before proceeding to avoid concurrency issues. - Run
yarn dev:services
to start themedia-service
,catalog-service
, andentitlement-service
in watch mode.` - Run
yarn dev:workflows
to start themedia-workflows
in watch mode. - Open http://localhost:10053/ in your browser. You should see a grid with different workflow options (Movies, Videos, Images, TV shows, Seasons, Episodes).
Alternatively, use the "...:all" scripts to include also the channel-service
and the vod-to-live-service
.
Note that these steps take several minutes to complete.
- Run
yarn test:reset:dbs
to initialize the testing databases. - Run
yarn test
to run the unit tests of the solution.
Before running the solution you need to create a Mosaic development environment. In order to do this, go over to https://admin.service.eu.axinom.com and login using the tenant id, username and password provided to you by Axinom.
After successful login, please select the "Environments" tile and then click the '+'-Icon to create a new environment.
Provide a user name and select the "Development" template.
The template will automatically create a management user on environment creation. You can adjust the email and password for that user in the text boxes below the template selection. By default it will match the email address of your Environment Administration user.
The 'Management System Subdomain' is the subdomain under which the management system will be publicly available. For development the management system will primarily be used from 'localhost', so this value is not too important for now and is also possible to be changed later still.
After hitting 'Proceed', the environment will be created and the 'Environment Connection' screen will show up. You can use this screen to retrieve all the information you need for connecting the media-template solution to the created environment.
The steps described above define how to setup and run the services on a local development machine. In order to run the services on a server the following procedure should be used.
The solution comes with a ready-to-use Dockerfile
at its root. It requires two
ARG
s getting passed in:
PACKAGE_ROOT
- needs to be set to the relative path of the service that should be build. This is usuallyservices/{serviceName}/service
(e.g.services/media/service
)PACKAGE_BUILD_COMMAND
- needs to be set to the npm command that should be used to build the service. THis command needs to be defined on the rootpackage.json
. It is usuallybuild:{serviceName}-service:prod
(e.g.build:media-service:prod
)
The process will then use the service's build
script to create a production
build of the service and the start
script to spin up the server, once the
Docker container starts up.
When running the Docker image, please make sure that you provide the expected
environment variables to the container, as on a production build it will not use
the .env
files.
To generate a production build of a workflow package run the following command:
yarn build:{serviceName}-workflows:prod
This script will create a .tgz
file on the repository root containing the
packaged workflows.
To deploy the workflows into an environment run a command like:
yarn run pilet publish --no-fresh --url "https://frontends.service.eu.axinom.net/v1/pilets/{tenantId}/{environmentId}" --api-key "{serviceAccountCredentials}" {packageFile}
You need a Client ID and Client Secret of a service account to run this command.
This service account must contain the Pilets: Publish
permission under the "Micro Frontend Service" in order to be authorized to perform
the action of publishing the workflows. Client ID and Client Secret will be shown
to you alongside with the other secrets when creating a service account or when
generating new secrets for an existing account.
Please note, that you need to provide the 'Base64 Encoded Credentials' of a
service account
as the value of api-key
.
If you have the plaintext Client ID & the Client Secret of the service account,
you can generate the base64($clientid:$clientSecret)
to be used as the api-key
using a BASE64 generator tool, such as:: https://portal.axinom.com/mosaic/tools/base64.
Also make sure that you define all values the pilet expects to receive inside
the app.meta.custom
by providing them as additional parameters on this command
like:
--fields.{key} {value}
You can find these keys and values usually in the .env.template
file of the
workflow.
If you want to unpublish a previously published workflow package from the Mosaic
Micro Frontend Service, the following CLI command provided by the Mosaic CLI can
be used. The Service Account used to create the api-key
must have
Pilets: Delete
permission assigned.
yarn mosaic unpublish-pilet -t {tenantId} -e {environmentId} -a {api-key} -n {pilet-name} -m {micro-frontend-service-base-url}
If you're looking for a quick way to deploy a service in the Axinom Cloud, we
offer a Quick Deploy
interactive script in the root package.
If you're looking to deploy your customized service in the Axinom Cloud using
your CI/CD pipelines, we recommend the Advanced Deploy
option that uses the
Mosaic CLI
where you can control the deployment steps with more precision via
the supplied arguments.
A detailed guide on how to deploy services via Mosaic Hosting Service can be found at https://docs.axinom.com/platform/hosting/deploy-a-customized-service
- Ensure you've configured the
Container Registry
for your environment in the Admin Portal underHosting Service
. - Ensure you've run
yarn setup:hosting
from the root of the mosaic-media-template. This will setup the required service-account for the quick-deploy script. - From the root of the mosaic-media-template, run
yarn quick-deploy
and follow the on-screen instructions.
The following sections list the individual steps needed to Build
& Deploy
the customizable services from your CI/CD pipelines.
Note that the following pre-requisites are assumed:
-
You've configured the
Container Registry
for your environment in the Admin Portal underHosting Service
. -
For each service you wish to host in the Axinom Cloud, you've created a
Customized Service
entity via the Admin Portal, and that the correct repository name has been set as expected. -
You've run
yarn setup:hosting
from the root of the mosaic-media-template. This will setup the required service-account for using the Mosaic CLI commands shown below with the correct permissions.NOTE:
yarn util:load-vars
is used in the below commands to load values for certain CLI arguments from the.env
file. If required, the CLI arguments can also be directly provided as necessary.NOTE: The final deployment step (i.e. the
mosaic hosting service deploy
step) can also be performed via the Admin Portal under Hosting Service.
- Build the service using the provided Dockerfile
- CLI Command
docker build -t <username>/<repository_name>:<tag> --build-arg PACKAGE_ROOT=services/media/service --build-arg PACKAGE_BUILD_COMMAND=build:media-service:prod .
- i.e.
docker build -t my-user/media-service:20230927.1 --build-arg PACKAGE_ROOT=services/media/service --build-arg PACKAGE_BUILD_COMMAND=build:media-service:prod .
- Ensure to use the same
<repository_name>
you decide on here, also in theCustomized Service
details station of the Admin Portal.
- CLI Command
- Push the container image to Docker Hub
- CLI Command
docker push <dockerhub_username>/<repository_name>:<tag>
- i.e.
docker push my-user/media-service:20230927.1
- CLI Command
- Build the workflows of the media-service
- CLI Command
yarn build:media-workflows:prod
- This will produce a
.tgz
pilet artifact on the project root
- CLI Command
- Register the pilet artifact on the Mosaic Hosting Service
- CLI Command
yarn util:load-vars mosaic hosting pilet register -i <custom-service-id> -p <path-to-workflow-build-artifact>
- i.e.
yarn util:load-vars mosaic hosting pilet register -i media-service -p ./
- CLI Command
- Upload the deployment manifest to the Mosaic Hosting Service
- CLI Command
yarn util:load-vars mosaic hosting manifest upload -i <custom-service-id> -p <path-to-deployment-manifest-yaml> -n <manifest-name>
- i.e.
yarn util:load-vars mosaic hosting manifest upload -i media-service -p ./services/media/service/mosaic-hosting-deployment-manifest.yaml -n media-service-manifest-20230927
- Ensure you provide a unique value for the
<manifest-name>
- CLI Command
- Deploy the service with the specific artifacts (i.e. container image tag,
pilet artifact, deployment manifest)
- CLI Command
yarn util:load-vars mosaic hosting service deploy -i <custom-service-id> -t <tag> -p <workflow-package@version> -m <manifest-name> -n <deployment-name>
- i.e.
yarn util:load-vars mosaic hosting service deploy -i media-service -t 20230927.1 -p [email protected] -m media-service-manifest-20230927 -n media-service-deployment-20230927.1
- Ensure you provide a unique value for the
<deployment-name>
- CLI Command
- Build the service using the provided Dockerfile
- CLI Command
docker build -t <username>/<repository_name>:<tag> --build-arg PACKAGE_ROOT=services/catalog/service --build-arg PACKAGE_BUILD_COMMAND=build:catalog-service:prod .
- i.e.
docker build -t my-user/catalog-service:20230927.1 --build-arg PACKAGE_ROOT=services/catalog/service --build-arg PACKAGE_BUILD_COMMAND=build:catalog-service:prod .
- Ensure to use the same
<repository_name>
you decide on here, also in theCustomized Service
details station of the Admin Portal.
- CLI Command
- Push the container image to Docker Hub
- CLI Command
docker push <dockerhub_username>/<repository_name>:<tag>
- i.e.
docker push my-user/catalog-service:20230927.1
- CLI Command
- Since this service has no workflows, we do not need to build them nor register them
- Upload the deployment manifest to the Mosaic Hosting Service
- CLI Command
yarn util:load-vars mosaic hosting manifest upload -i <custom-service-id> -p <path-to-deployment-manifest-yaml> -n <manifest-name>
- i.e.
yarn util:load-vars mosaic hosting manifest upload -i catalog-service -p ./services/catalog/service/mosaic-hosting-deployment-manifest.yaml -n catalog-service-manifest-20230927
- Ensure you provide a unique value for the
<manifest-name>
- CLI Command
- Deploy the service with the specific artifacts (i.e. container image tag,
deployment manifest)
- CLI Command
yarn util:load-vars mosaic hosting service deploy -i <custom-service-id> -t <tag> -m <manifest-name> -n <deployment-name>
- i.e.
yarn util:load-vars mosaic hosting service deploy -i catalog-service -t 20230927.1 -m catalog-service-manifest-20230927 -n catalog-service-deployment-20230927.1
- Ensure you provide a unique value for the
<deployment-name>
- CLI Command
- Build the service using the provided Dockerfile
- CLI Command
docker build -t <username>/<repository_name>:<tag> --build-arg PACKAGE_ROOT=services/entitlement/service --build-arg PACKAGE_BUILD_COMMAND=build:entitlement-service:prod .
- i.e.
docker build -t my-user/entitlement-service:20230927.1 --build-arg PACKAGE_ROOT=services/entitlement/service --build-arg PACKAGE_BUILD_COMMAND=build:entitlement-service:prod .
- Ensure to use the same
<repository_name>
you decide on here, also in theCustomized Service
details station of the Admin Portal.
- CLI Command
- Push the container image to Docker Hub
- CLI Command
docker push <dockerhub_username>/<repository_name>:<tag>
- i.e.
docker push my-user/entitlement-service:20230927.1
- CLI Command
- Since this service has no workflows, we do not need to build them nor register them
- Upload the deployment manifest to the Mosaic Hosting Service
- CLI Command
yarn util:load-vars mosaic hosting manifest upload -i <custom-service-id> -p <path-to-deployment-manifest-yaml> -n <manifest-name>
- i.e.
yarn util:load-vars mosaic hosting manifest upload -i entitlement-service -p ./services/entitlement/service/mosaic-hosting-deployment-manifest.yaml -n entitlement-service-manifest-20230927
- Ensure you provide a unique value for the
<manifest-name>
- IMPORTANT: The entitlement-service requires certain environment
variables to be configured that are user specific (i.e.
GEOLITE
&DRM Keys
). Therefore ensure that you've followed the necessary steps to retrieve these values and have updated the deployment manifest YAML with the correct values.
- CLI Command
- Deploy the service with the specific artifacts (i.e. container image tag,
deployment manifest)
- CLI Command
yarn util:load-vars mosaic hosting service deploy -i <custom-service-id> -t <tag> -m <manifest-name> -n <deployment-name>
- i.e.
yarn util:load-vars mosaic hosting service deploy -i entitlement-service -t 20230927.1 -m entitlement-service-manifest-20230927 -n entitlement-service-deployment-20230927.1
- Ensure you provide a unique value for the
<deployment-name>
- CLI Command
- Build the service using the provided Dockerfile
- CLI Command
docker build -t <username>/<repository_name>:<tag> --build-arg PACKAGE_ROOT=services/channel/service --build-arg PACKAGE_BUILD_COMMAND=build:channel-service:prod .
- i.e.
docker build -t my-user/channel-service:20230927.1 --build-arg PACKAGE_ROOT=services/channel/service --build-arg PACKAGE_BUILD_COMMAND=build:channel-service:prod .
- Ensure to use the same
<repository_name>
you decide on here, also in theCustomized Service
details station of the Admin Portal.
- CLI Command
- Push the container image to Docker Hub
- CLI Command
docker push <dockerhub_username>/<repository_name>:<tag>
- i.e.
docker push my-user/channel-service:20230927.1
- CLI Command
- Build the workflows of the channel-service
- CLI Command
yarn build:channel-workflows:prod
- This will produce a
.tgz
pilet artifact on the project root
- CLI Command
- Register the pilet artifact on the Mosaic Hosting Service
- CLI Command
yarn util:load-vars mosaic hosting pilet register -i <custom-service-id> -p <path-to-workflow-build-artifact>
- i.e.
yarn util:load-vars mosaic hosting pilet register -i channel-service -p ./
- CLI Command
- Upload the deployment manifest to the Mosaic Hosting Service
- CLI Command
yarn util:load-vars mosaic hosting manifest upload -i <custom-service-id> -p <path-to-deployment-manifest-yaml> -n <manifest-name>
- i.e.
yarn util:load-vars mosaic hosting manifest upload -i channel-service -p ./services/channel/service/mosaic-hosting-deployment-manifest.yaml -n channel-service-manifest-20230927
- Ensure you provide a unique value for the
<manifest-name>
- CLI Command
- Deploy the service with the specific artifacts (i.e. container image tag,
pilet artifact, deployment manifest)
- CLI Command
yarn util:load-vars mosaic hosting service deploy -i <custom-service-id> -t <tag> -p <workflow-package@version> -m <manifest-name> -n <deployment-name>
- i.e.
yarn util:load-vars mosaic hosting service deploy -i channel-service -t 20230927.1 -p [email protected] -m channel-service-manifest-20230927 -n channel-service-deployment-20230927.1
- Ensure you provide a unique value for the
<deployment-name>
- CLI Command
zapatos
models will be generated afteryarn db:commit
but you can trigger the generator manually viayarn internal:zapatos
.- Run
yarn test:reset:dbs
before runningyarn test
in case new test files were created or existing ones renamed or moved. - To obtain a development-time auth token for a service, run
yarn util:token
in that service's workspace. There should also be a corresponding permissions file under that service'sscripts/resources
. For a working example seepackage.json
in the Media Service.