bifrost-env-manager

command module
v0.5.0-beta.6 Latest Latest
Warning

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

Go to latest
Published: Aug 26, 2023 License: Apache-2.0 Imports: 2 Imported by: 0

README ΒΆ

πŸŒ‰ Bifrost-env-manager

πŸ“š Overview

Bifrost-env-manager is a tool for managing environment variables with flexibility. It distinguishes between static, random, and custom variables, allowing you to maintain a coherent environment setup.

🧠 Logic

Environment variables are classified into three categories: static, random, and custom. This classification determines how variables are treated over time.

  • Static variables: These are straightforward key-value pairs that remain unchanged.
  • Random value variables: These variables are generated once and stored securely.
  • Custom value variables: These variables are (re)constructed using predefined rules and can include references to other variables.

πŸ”‘ Key Value Definitions

High-level Configuration
  • version (optional): Specifies the version of the configuration (default: 1.0.0).
  • software_target (optional): Indicates the target software for the environment setup.
  • filename (optional): Specifies the name of the environment file (default: .env).
Static Variables

Key-value pairs that remain constant.

Random Value Variables

These variables are generated and stored securely.

Required:

  • key
  • length

Optional:

  • as_upper_case (default: true)
  • as_lower_case (default: true)
  • as_digit (default: true)
  • as_special_character (default: true)
  • available_characters (default: specific to the chosen options)
Custom Value Variables

Variables with dynamic values constructed from predefined rules.

Required:

  • key
  • line
  • values (array)

If a value enclosed in {{ }} is not defined here, the tool will search in random values, static values, and environment variables. An error will be raised if the value is not found.

πŸš€ Getting Started

Usage
❯ bifrost-env-manager
Software environement files manager

Usage:
  bifrost-env-manager [command]

Available Commands:
  generate    Generate a new version of the env file
  help        Help about any command

Flags:
      --config string          config file for this software environement (default "config.json")
      --disable-update-check   Disable auto update checking before execution
  -h, --help                   help for Bifrost-env-manager
      --path string            Path for the new file folder, ex: /home/ubuntu/code/
      --read-only-env string   Path for read-only environement config, ex: ".api.env;.redis.env"
  -t, --toggle                 Help message for toggle
  -v, --version                version for Bifrost-env-manager
  -y, --yes                    Auto accept manual question y/n

Use "bifrost-env-manager [command] --help" for more information about a command.
Command
Basic
❯ bifrost-env-manager generate
Using config file: config.json
.example.env file generated successfully!
Specific config
❯ bifrost-env-manager generate --config config.json
Using config file: config.json
.example.env file generated successfully!
Specific file path
❯ bifrost-env-manager generate --path /somewhere/else/
Using config file: config.json
/somewhere/else/.example.env file generated successfully!
Existing env

If you have previously defined variables, such as a password for a database or any other data, you can provide these variables to the manager. The manager can then read the existing data and use it to create new custom variables.

Additionally, you have the option to include multiple files in this process. To do so, ensure you separate each file by using a ';' as a delimiter.

❯ bifrost-env-manager generate --read-only-env .postgresql.env;.redis.env
Using config file: config.json
.example.env file generated successfully!
Skip update
❯ bifrost-env-manager generate --disable-update-check
Auto accept

Use with caution, can override config or version

❯ bifrost-env-manager generate --yes
Config

Config example:

{
  "version": "1.0.0",
  "software_target": "example",
  "filename": ".example.env",
  "static_variables": [
    {
      "smpt": "x.e.f.x"
    },
    {
      "s3Secret": "dhsd;asdkas;dkasdasda"
    },
    {
      "somethingElse": "wead"
    }
  ],
  "random_value_variables": [
    {
      "key": "password_psql",
      "lenght": 128,
      "as_upper_case": true,
      "as_lower_case": false,
      "as_diggit": true,
      "as_special_character": true,
      "available_character": "qwertyuiopasfdghjkl;zxcvbnm123234567890.,?!"
    }
  ],
  "custom_value_variables": [
    {
      "key": "postgresql_url",
      "line": "postgres://{{ db_user_name }}:{{ password_psql }}@{{ host }}/{{ db_name }}",
      "values": [
        {
          "db_user_name": "xxx"
        },
        {
          "db_name": "xxx"
        }
      ]
    }
  ]
}

Or can be

{
  "static_variables": [
    {
      "smpt": "x.e.f.x"
    },
    {
      "s3Secret": "dhsd;asdkas;dkasdasda"
    },
    {
      "somethingElse": "wead"
    }
  ],
  "random_value_variables": [
    {
      "key": "password_psql",
    }
  ],
  "custom_value_variables": [
    {
      "key": "postgresql_url",
      "line": "postgres://{{ db_user_name }}:{{ password_psql }}@{{ host }}/{{ db_name }}",
      "values": [
        {
          "db_user_name": "xxx"
        },
        {
          "db_name": "xxx"
        }
      ]
    }
  ]
}

🀝 Contributing

πŸŽ‰ We welcome contributions from everyone! Here's how you can contribute:

  • Fork the repository.
  • Create a new branch for your feature/fix.
  • Make your changes and commit them.
  • Push your changes to your forked repository.
  • Create a pull request to the 'develop' branch of the main repository.

See the CONTRIBUTING file for more details.

πŸ“ License

Bifrost-env-manager is licensed under the Apache License, Version 2.0. See the LICENSE file for more details.

Documentation ΒΆ

The Go Gopher

There is no documentation for this package.

Directories ΒΆ

Path Synopsis
pkg

Jump to

Keyboard shortcuts

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