## This is CLI project related with GAPI graphQL api with typescript Decorators

#### [WIKI](https://github.com/Stradivario/gapi-cli/wiki)

#### [Gapi](https://github.com/Stradivario/gapi) - Advanced graphql server with typescript decorators

#### [Starter](https://github.com/Stradivario/gapi-starter) - Basic starter project

#### [Starter-advanced](https://github.com/Stradivario/gapi-starter-postgres-sequelize-rabbitmq) - Advanced starter project

#### [Gapi-angular-client](https://github.com/Stradivario/gapi-starter-postgres-sequelize-rabbitmq) - Gapi Apollo Angular client

#### To install gapi utility type following command:

```bash
npm i -g @gapi/cli
```

#### To create new basic project from scratch via CLI type:

```bash
gapi new my-project
```

#### To create new advanced project from scratch via CLI type:

```bash
gapi new my-project --advanced
```

#### To create new basic project with microservices from scratch via CLI type:

```bash
gapi new my-project --microservices
```

### Available commands

##### Create new project

```bash
gapi new project-name
```

##### Start created project.

```bash
gapi start
```

###### (Uses internally on every restart to introspect api schema check "gapi schema introspect" command)

###### Can be disabled inside package.json > nodemonConfig > events > restart

###### With this configuration it will make request to localhost:9000 and will take current API schema then will generate graphql.d.ts based on introspection

```json
  "nodemonConfig": {
    "events": {
      "restart": "sleep 1 && gapi schema introspect"
    }
  },
```

##### Start production (it will start pm2 and will use process.yml file inside working directory)

```bash
gapi start --prod --pm2
```

##### Start production inside Docker(it will start pm2-docker and will use process.yml file inside working directory)

```bash
gapi start --prod --docker
```

#### Start testing

##### Run single test iteration

##### Will take config > test > local configuration inside @gapi/cli.conf.yml

```bash
gapi test
```

##### Run tests in watch mode

```bash
gapi test --watch
```

##### Run tests with different environment

###### It will take configuration from @gapi/cli.conf.yml

###### You can extend configurations from APP when you write after environment "extends app/my-environment"

#### Custom testing environments

```yml
config:
  app:
    local:
      API_PORT: 9000
      API_CERT: ./cert.key
      NODE_ENV: development
      AMQP_HOST: 182.10.0.5
      AMQP_PORT: 5672
    prod:
      API_PORT: 9000
      API_CERT: ./cert.key
      NODE_ENV: production
      AMQP_HOST: 182.10.0.5
      AMQP_PORT: 5672
    my-environment:
      API_PORT: 9000
      API_CERT: ./cert.key
      NODE_ENV: development
      AMQP_HOST: 182.10.0.5
      AMQP_PORT: 5672
  test:
    my-environment: extends app/my-environment
    local: extends app/local
    prod: extends app/prod
    worker:
      API_PORT: 9000
      API_CERT: ./cert.key
      NODE_ENV: production
      AMQP_HOST: 182.10.0.5
      AMQP_PORT: 5672
```

##### Running with Testing worker environment

```bash
gapi test --worker
```

#### Running with Production environment

```bash
gapi test --prod
```

##### Running with custom enviroment

```bash
gapi test --my-enviroment
```

#### Schema

##### Schema introspection

###### It will generate graphql.d.ts file based on given address and output folder

###### Uses @gapi/cli.conf.yml file

```yml
config:
  schema:
    introspectionEndpoint: http://localhost:9000/graphql
    introspectionOutputFolder: ./src/app/core/api-introspection
```

```bash
gapi schema introspect
```

##### Available shared commands are:

###### --verbose - Show better logging
