/tln-cli

Talan CLI (tln) is an open-source framework for managing third-party components from wide range of ecosystems (Java, Node.js, C++, Golang, Angular etc.). tln helps to create fully isolated development environments, uniformly manage mono- & multi- repo configurations, build smooth onboaring experience, melt borders between local development environments and CI/CT/CD setups, get maximum from Polyglot Programming Polyglot Persistence (4Ps) design.

Primary LanguageJavaScript

Talan CLI - Advanced Component Management System

ccf

Talan CLI (tln) is an open-source framework for managing third-party components from wide range of ecosystems (Java, Node.js, C++, Golang, Angular etc.). tln helps to create fully isolated development environments, uniformly manage mono- & multi- repo configurations, build smooth onboaring experience, melt borders between local development environments and CI/CT/CD setups, get maximum from Polyglot Programming Polyglot Persistence (4Ps) design.

Similar or related projects

Brew, Conan, Meta, Lerna, SDKMAN, jEnv, Chocolatey

Prerequisites

  • Install Nodejs 14.x or higher (https://nodejs.org)
    > curl -sL https://deb.nodesource.com/setup_14.x -o nodesource_setup.sh
    > sudo bash nodesource_setup.sh
    > sudo apt-get install -y nodejs
    
  • Make sure that wget is accessible via command line (Linux/MacOS)
  • Make sure that Powershell script can be executed:
    > set-ExecutionPolicy remotesigned
    or
    > set-ExecutionPolicy unrestricted
    
  • Install tln-cli
    > npm i -g tln-cli
    > tln --version
    

Quick start ~3 min

  • Create folder where all your projects will be located

    • Linux/MacOs
      > cd ~
      
    • Windows (you can use any disk, disk d: is used for demonstration purpose)
      > d:
      > cd /
      
    > mkdir projects
    > cd projects
    > tln config --terse
    
  • Create folder for the hellotalan project (inside projects folder)

    > mkdir hellotalan
    > cd hellotalan
    > tln config --terse
    
  • Edit .tln.conf file to get next configuration (you can just copy-paste it)

    module.exports = {
      options: async (tln, args) => {},
      env: async (tln, env) => {},
      dotenvs: async (tln) => [],
      inherits: async (tln) => [],
      depends: async (tln) => ['mvn-3.6.3', 'openjdk-11.0.2', 'go-1.14.4', 'node-14.4.0', 'angular-9.1.8', 'cordova-9.0.0'],
      steps: async (tln) => [
        {
          id: "versions",
          builder: async (tln, script) => script.set([
            'java -version && mvn -v && go version && node -v && cordova -v && ng version'
          ])
        }
      ],
      components: async (tln) => []
    }
    
  • Install dependencies. mvn-3.6.3, openjdk-11.0.2, go-1.14.4, node-14.4.0, angular-9.1.8, cordova-9.0.0 components will be installed inside projects folder and will not affect any other already installed software.

    > tln install --depends
    
  • Check version of installed components

    > tln versions
    
    openjdk version "11.0.2" 2019-01-15
    OpenJDK Runtime Environment 18.9 (build 11.0.2+9)
    OpenJDK 64-Bit Server VM 18.9 (build 11.0.2+9, mixed mode)
      
    Apache Maven 3.6.3 (cecedd343002696d0abb50b32b541b8a6ba2883f)
    Maven home: D:\projects2\maven\mvn-3.6.3\bin\..
    Java version: 11.0.2, vendor: Oracle Corporation, runtime: D:\projects2\java\openjdk-11.0.2
    Default locale: en_US, platform encoding: Cp1251
    OS name: "windows 10", version: "10.0", arch: "amd64", family: "windows"
      
    go version go1.14.4 windows/amd64
      
    v14.4.0
      
    9.0.0 (cordova-lib@9.0.1)
      
    Angular CLI: 9.1.8    
    

tln architecture & in-depth details

Real life scenario ~15 min

Let's say, you've joined Calbro.com company to head software project development. You will need to build new service as part of multiple already in-production applications. Your first steps are: configure local development environment, checkout existing projects and create initial structure for the new one.

Calbro projects home

  • First step is to configure Calbro components

    • Linux/MacOs
      > cd ~/projects
      
    • Windows
      > d:
      > cd /projects
      
    > mkdir calbro
    > cd calbro
    

    For the next command replace Alice account name and email with your own (for this tutorial, please use your Github account)

    > tln config --terse -e TLN_GIT_USER=Alice -e TLN_GIT_EMAIL=alice@calbro.com --inherit git
    
  • If you check created configuration file .tln.conf, you will see following JSON structure

    module.exports = {
      options: async (tln, args) => {},
      env: async (tln, env) => {
        env.TLN_GIT_USER = 'Alice';
        env.TLN_GIT_EMAIL = 'alice@calbro.com';
      },
      dotenvs: async (tln) => [],
      inherits: async (tln) => ['git'],
      depends: async (tln) => [],
      steps: async (tln) => [],
      components: async (tln) => []
    }
    

    This information will be used by all subsequent git calls.

Checkout, configure & build existing projects

Calbo is a big company and has a lot of teams and ongoing projects. You know that Calbro is using tln to deal with internal complexity, so onboarding should be straightforward.

  • You are part of teamone team and this should be reflected as part of your local dev environment

    > mkdir teamone
    > cd teamone
    
    # for ssh access
    > tln config --repo git@github.com:project-talan/calbro-teamone-tln.git
    # for https access
    # tln config --repo https://github.com/project-talan/tln-calbro-teamone.git
    
    > tln ls
    

    Two last commands will do the magic: get teamone list of projects and display them to you

    Configuration file .tln/.tlf.conf can unhide more details

    module.exports = {
      options: async (tln) => [],
      dotenvs: async (tln) => [],
      inherits: async (tln) => [],
      depends: async (tln) => [],
      env: async (tln, env) => {
        env.TLN_GIT_SSH_PREFIX = 'git@github.com:';
        env.TLN_GIT_HTTPS_PREFIX = 'https://github.com/';  
        env.TLN_GIT_ORIGIN = `${env.TLN_GIT_USER}/${env.TLN_COMPONENT_ID}.git`;
        env.TLN_GIT_UPSTREAM = `project-talan/${env.TLN_COMPONENT_ID}.git`;
      },
      steps: async (tln) => [],
      components: async (tln) => [
        { id: 'calbro-scanner' },
        { id: 'calbro-portal' }
      ]
    }
    
  • At this point, you are ready to get source code of the existing projects, build it and start checking implemented functionality

    # for ssh access
    > tln clone calbro-scanner:calbro-portal
    # for https access
    # tln clone calbro-scanner:calbro-portal -- --https
    
    > tln install calbro-portal:calbro-scanner --depends
    > tln prereq:init -r
    > tln build -r
    
    • First command will use git clone and your credentials were defined early inside .tln.conf
    • Second will install all necessary third-parties components
    • Third one will generate .env file if any, using template, and run initialization commands like npm i
    • The last command will recursivelly build all components

Skeleton for the new project

You project is still at early stage, there are a lot of uncertainty, but you have to push it forward.

It's also not clear will be project based on SOA or Microservices or even N-tier, so you are ok to start with mono repo, but at the same time you want to build structure which can be splitted later if needed.

Calbro software development culture also includes recommendation to reuse wide range of project templates and you will follow this practice too.

  • This is how your initial concept looks like:

    • Admin Frontend - Angular, a couple of developers have joined your team recently with necessary skills, Admin Backend - Nodejs
    • API service - Go, since this is general company strategy and your project should be aligned with it
    • Auth service will utilize Nodejs again, since it will be handled by the developer who will be working on Admin part
    • You need to have two types of persistent storages - SQL & NoSQL, because initial analysis shows that we can't have "shoes for all feets" approach
    • Managment wants to go with mobile-first approach, so you will try satisfy this requirement by using Cordova and reuse our Javascript based frontend
    • Main portal web part will use React, because it's cool
    • We also need Java to build our automated test framework
  • So, here we go (you can copy commands below into create.sh script and execute them in a single run)

    mkdir calbro-reporting && \
    cd calbro-reporting && \
    tln init-repo && \
    tln config --terse && git add . && git commit -m"empty repo" && \
    tln add-subtree -- --prefix static/admin --subtree https://github.com/project-talan/tln-angular.git --ref master && \
    tln add-subtree -- --prefix static/portal --subtree https://github.com/project-talan/tln-react.git --ref master && \
    tln add-subtree -- --prefix services/admin --subtree https://github.com/project-talan/tln-nodejs.git --ref master && \
    tln add-subtree -- --prefix services/api --subtree https://github.com/project-talan/tln-golang.git --ref master && \
    tln add-subtree -- --prefix services/auth --subtree https://github.com/project-talan/tln-nodejs.git --ref master && \
    tln add-subtree -- --prefix dbs/mongo --subtree https://github.com/project-talan/tln-mongodb.git --ref master && \
    tln add-subtree -- --prefix dbs/postgresql --subtree https://github.com/project-talan/tln-postgresql.git --ref master && \
    tln add-subtree -- --prefix mobile/cordova --subtree https://github.com/project-talan/tln-cordova.git --ref master && \
    tln add-subtree -- --prefix qa/api --subtree https://github.com/project-talan/tln-java.git --ref master && \
    tln add-subtree -- --prefix qa/load --subtree https://github.com/project-talan/tln-java.git --ref master && \
    tln add-subtree -- --prefix qa/e2e --subtree https://github.com/project-talan/tln-java.git --ref master && \
    tln config dbs:mobile:qa:services:static --terse && \
    git add . && git commit -m"Initial skeleton" && \
    cd ..
    

    Windows (create.cmd)

    mkdir calbro-reporting && ^
    cd calbro-reporting && ^
    tln init-repo && ^
    tln config --terse && git add . && git commit -m"empty repo" && ^
    tln add-subtree -- --prefix static/admin --subtree https://github.com/project-talan/tln-angular.git --ref master && ^
    tln add-subtree -- --prefix static/portal --subtree https://github.com/project-talan/tln-react.git --ref master && ^
    tln add-subtree -- --prefix services/admin --subtree https://github.com/project-talan/tln-nodejs.git --ref master && ^
    tln add-subtree -- --prefix services/api --subtree https://github.com/project-talan/tln-golang.git --ref master && ^
    tln add-subtree -- --prefix services/auth --subtree https://github.com/project-talan/tln-nodejs.git --ref master && ^
    tln add-subtree -- --prefix dbs/mongo --subtree https://github.com/project-talan/tln-mongodb.git --ref master && ^
    tln add-subtree -- --prefix dbs/postgresql --subtree https://github.com/project-talan/tln-postgresql.git --ref master && ^
    tln add-subtree -- --prefix mobile/cordova --subtree https://github.com/project-talan/tln-cordova.git --ref master && ^
    tln add-subtree -- --prefix qa/api --subtree https://github.com/project-talan/tln-java.git --ref master && ^
    tln add-subtree -- --prefix qa/load --subtree https://github.com/project-talan/tln-java.git --ref master && ^
    tln add-subtree -- --prefix qa/e2e --subtree https://github.com/project-talan/tln-java.git --ref master && ^
    tln config dbs:mobile:qa:services:static --terse && ^
    git add . && git commit -m"Initial skeleton" && ^
    cd ..
    
  • Initial structure is ready and we can verify mounted subtrees

    > tln ls-subtrees calbro-reporting
    
    Prefix Subtree Ref
    static/admin https://github.com/project-talan/tln-angular.git master
    static/portal https://github.com/project-talan/tln-react.git master
    services/admin https://github.com/project-talan/tln-nodejs.git master
    services/api https://github.com/project-talan/tln-golang.git master
    services/auth https://github.com/project-talan/tln-nodejs.git master
    dbs/mongo https://github.com/project-talan/tln-mongodb.git master
    dbs/postgresql https://github.com/project-talan/tln-postgresql.git master
    mobile/cordova https://github.com/project-talan/tln-cordova.git master
    qa/api https://github.com/project-talan/tln-java.git master
    qa/load https://github.com/project-talan/tln-java.git master
    qa/e2e https://github.com/project-talan/tln-java.git master
  • And the final step is to observe ready to use development environment structure with all necessary dependencies

    > tln ls / -d 5 --all --installed-only
    
    /
    ├ angular
    │ ├ angular-9.1.8
    │ └ angular-9.1.7
    ├ calbro
    │ └ teamone
    │   ├ calbro-portal
    │   ├ calbro-reporting
    │   │ ├ dbs
    │   │ │ ├ mongo
    │   │ │ └ postgresql
    │   │ ├ mobile
    │   │ │ └ cordova
    │   │ ├ qa
    │   │ │ ├ api
    │   │ │ ├ e2e
    │   │ │ └ load
    │   │ ├ services
    │   │ │ ├ admin
    │   │ │ ├ api
    │   │ │ └ auth
    │   │ └ static
    │   │   ├ admin
    │   │   └ portal
    │   └ calbro-scanner
    ├ cordova
    │ └ cordova-9.0.0
    ├ golang
    │ └ go-1.14.4
    ├ hellotalan
    ├ java
    │ ├ openjdk-14.0.1
    │ └ openjdk-11.0.2
    ├ maven
    │ └ mvn-3.6.3
    └ nodejs
      └ node-14.4.0