texts

package
v0.2.4 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Dec 10, 2021 License: MIT Imports: 3 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

View Source
var Aws = Command{
	Short: "AWS subcommand",
}
View Source
var AwsInstall = Command{
	Short: "Installs Mantil node into AWS account",
	Long: `Installs Mantil node into AWS account

Command will install node into AWS account. Node consists of few Lambda function, API Gateway and S3 bucket.
You must provide credentials for Mantil to access your AWS account.

There is --dry-run option which will show you what credentials will be used
and what account will be managed by command.`,
	Arguments: `
  [node-name]  Mantil node name.
               If not provided default name dev will be used for the first node.`,
	NextSteps: `
* Run 'mantil new' to start a project from scratch or choose from an existing template.
Check documentation at https://github.com/mantil-io/docs for additional inspiration.
`,
	Examples: setupExamples("install"),
}
View Source
var AwsNodes = Command{
	Short: "Shows Mantil AWS nodes",
}
View Source
var AwsResources = Command{
	Short: "Shows AWS resources created by Mantil",
	Long: `Shows AWS resources created by Mantil

When executed inside Mantil project command will show resources created
for current project stage and node of that stage.
To show resources for other, non current, stage use --stage option.

When executed outside of Mantil project command will show resources of
the all nodes in the workspace.
Use --nodes options to get this behavior when inside of Mantil project.
`,
}
View Source
var AwsUninstall = Command{
	Short: "Uninstalls Mantil node from AWS account",
	Long: `Uninstalls Mantil node from AWS account

Command will remove node from AWS account.
You must provide credentials for Mantil to access your AWS account.

There is --dry-run option which will show you what credentials will be used
and what account will be managed by command.

By default you will be asked to confirm the destruction.
This behaviour can be disabled using the --yes option.`,
	Arguments: `
  [node-name]  Mantil node name.
               If not provided default name dev will be used for destruction.`,
	Examples: setupExamples("uninstall"),
}
View Source
var AwsUpgrade = Command{
	Short: "Upgrades Mantil node on AWS account",
	Long: `Upgrades Mantil node on AWS account

Command will upgrade node on your AWS account to reflect the current version of the CLI.
You must provide credentials for Mantil to access your AWS account.

There is --dry-run option which will show you what credentials will be used
and what account will be managed by command.`,
	Arguments: `
  [node-name]  Mantil node name.
               If not provided default name dev will be used for upgrade.`,
	NextSteps: `
* You can now continue using Mantil with the brand new version!
`,
	Examples: setupExamples("upgrade"),
}
View Source
var Deploy = Command{
	Short: "Deploys project updates to a stage",
	Long: `Deploys project updates to a stage

This command checks if any assets, code or configuration have changed since the last deployment
and applies the necessary updates.

The --stage option accepts any existing stage and defaults to the default stage if omitted.`,
	NextSteps: `
* Use 'mantil logs' to see those directly in terminal in an instant.
`,
}
View Source
var Env = Command{
	Short: "Exports project environment variables",
	Long: `Exports project environment variables

Then you can use that variables in other shell comands.

Mantil project is determined by the current shell folder.
You can be anywhere in the project tree.

If not specified (--stage option) default project stage is used.`,
	Examples: `
  ==> Set environment variables in terminal
  $ eval $(mantil env)

  ==> Use current stage api url in other shell commands
  $ curl -X POST $(mantil env -url)/ping`,
}
View Source
var Generate = Command{
	Short: "Automatically generates code in the project",
}
View Source
var GenerateApi = Command{
	Short: "Generates Go code for a new API",
	Long: `Generates Go code for new API

This command generates all the boilerplate code necessary to get started writing a new API.
An API is a lambda function with at least one (default) request/response method.

Optionally, you can define additional methods using the --methods option. Each method will have a separate
entrypoint and request/response structures.

After being deployed the can then be invoked using mantil invoke, for example:

mantil invoke ping
mantil invoke ping/hello`,
	Arguments: `
  <name>      Name of the API to generate.`,
}
View Source
var Invoke = Command{
	Short: "Invokes API method on the project stage",
	Long: `Invokes API method on the project stage

Makes HTTP request to the gateway endpoint of the project stage. That invokes
Lambda function of that project api. If API method is not specified default
(named Default in Go code) is assumed.

Mantil project is determined by the current shell folder.
You can be anywhere in the project tree.
If not specified (--stage option) default project stage is used.

During lambda function execution their logs are shown in terminal. Each lambda
function log line is preffixed with λ symbol. You can hide that logs with the
--no-log option.

This is a convenience method and provides similar output to calling:
$ curl -X POST https://<stage_endpoint_url>/<api>[/method] [-d '<data>'] [-i]`,
	Examples: `
  ==> invoke Default method in Ping api
  $ mantil invoke ping
  200 OK
  pong

  ==> invoke Hello method in Ping api with 'Mantil' data
  $ mantil invoke ping/hello -d 'Mantil'
  200 OK
  Hello, Mantil

  ==> invoke ReqRsp method in Ping api with json data payload
  $ mantil invoke ping/reqrsp -d '{"name":"Mantil"}'
  200 OK
  {
     "Response": "Hello, Mantil"
  }`,
	Arguments: `
  <api>      Name of the API. Your APIs are in /api folder.
  [/method]  Method name in Go source code.
            Default method will called if not spedified.`,
}
View Source
var Logs = Command{
	Short: "Fetches logs for a specific API",
	Long: `Fetches logs for a specific API

Logs can be filtered using Cloudwatch filter patterns.
For more information see:
https://docs.aws.amazon.com/AmazonCloudWatch/latest/logs/FilterAndPatternSyntax.html

If the --tail option is set the process will keep running and polling for new logs every second.`,
	Arguments: `
  <api>      Name of the API. Your APIs are in /api folder.`,
}
View Source
var New = Command{
	Short: "Creates a new Mantil project",
	Long: `Creates a new Mantil project

Creates a new Mantil project from the source provided with the --from option.
The source can either be an existing git repository or one of the predefined templates:
ping    - https://github.com/mantil-io/template-ping
excuses - https://github.com/mantil-io/template-excuses
chat    - https://github.com/mantil-io/template-chat
todo    - https://github.com/mantil-io/template-todo

If no source is provided it will default to the template "ping".

By default, the Go module name of the initialized project will be the project name.
This can be changed by setting the --module-name option.`,
	NextSteps: `
* It's time to start developing in the cloud. Run 'mantil stage new' to
create your first development environment or check the documentation at
https://github.com/mantil-io/docs for more details.
`,
	Arguments: `
  <project>  Name of the new project.`,
	Examples: `
  ==> new project with default structure:
  $ mantil new my-project

  ==> new project from built-in template:
  $ mantil new my-project --from excuses

  ==> new project from any available template:
  $ mantil new my-project --from https://github.com/mantil-io/template-excuses
`,
}
View Source
var Report = Command{
	Short: "Makes a bug report",
	Long: fmt.Sprintf(`Make a bug report

Mantil logs are located at %s.

This command sends us those log files so we can analyze them and help you with
the issue you're having.

By default last 3 days of logs are included, you can change that with --days option.`, logsDir()),
}
View Source
var Stage = Command{
	Short: "Manages project stages",
	Long: `Manages project stages

A stage represents a named deployment of the project. A project can have
multiple stages. A stage for each developer, integration stage, production...
Stage is placed on a node. Different stages in the same project can be placed on
different nodes.`,
}
View Source
var StageDestroy = Command{
	Short: "Destroys a stage",
	Long: `Destroys a stage

This command will destroy all resources belonging to a stage.
Optionally, you can set the --all option to destroy all stages of a project.

By default you will be asked to confirm the destruction.
This behavior can be disabled using the --yes option.`,
	Arguments: `
  <name>  Name for the stage to destroy.`,
}
View Source
var StageList = Command{
	Short: "Lists stages in project",
}
View Source
var StageNew = Command{
	Short: "Creates a new stage",
	Long: `Creates a new stage

This command will create a new stage with the given name.
If the name is left empty it will default to "dev".

If only one node is set up, the stage will be deployed to that node by default.
Otherwise, you will be asked to pick a node. The node can also be specified via the --node option.`,
	NextSteps: `
* Try 'mantil invoke' to see your fully functional Mantil serverless application in action.
`,
	Arguments: `
  <name>  Name for the new stage.`,
}
View Source
var StageUse = Command{
	Short: "Sets default project stage",
	Arguments: `
  <stage>  Name of the stage which will be default.`,
}
View Source
var Test = Command{
	Short: "Runs project tests",
	Long: `Runs project tests

Project end to end tests are pure Go test in [project-root]/test folder.
Mantil sets MANTIL_API_URL environment variable to point to the current
project api url and runs tests with 'go test -v'.
`,
}
View Source
var Watch = Command{
	Short: "Watches for file changes and automatically deploy them",
	Long: `Watches for file changes and automatically deploy them

This command will start a watcher process that listens to changes in any *.go files
in the project directory and automatically deploys changes to the stage.

You can set a method to invoke after every deploy using the --method and --data options.
Or run tests after every deploy with --test options.`,
}

Functions

This section is empty.

Types

type Command

type Command struct {
	Short     string
	Long      string
	Arguments string
	NextSteps string
	Examples  string
}

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL