A CLI tool to generate, package and upload cloudshell orchestration scripts. This tool is an optional add-on to the shellfoundry shell development cli tool. "Scriptfoundry" has shellfoundry as a dependency, and re-uses the same cli configuration.
pip install cloudshell-scriptfoundry
Configure "Shellfoundry" Credentials (shared by "Scriptfoundry")
shellfoundry config host localhost
shellfoundry config username admin
shellfoundry config password admin
To check configured values:
shellfoundry config
See Shellfoundry Reference for more info.
Generate new project:
scriptfoundry new setup_config_firewall --template setup
Zip and upload to cloudshell:
cd setup_config_firewall
scriptfoundry update setup_config_firewall
Usage: scriptfoundry [OPTIONS] COMMAND [ARGS]...
Options:
--help Show this message and exit.
Commands:
new Create new script from template
pack Create script zip archive
update Create zip archive and update on CloudShell
version Display scriptfoundry version
"New" command generates script template. The templates map to the orchestration script "types" in cloudshell (setup, teardown, default, save, restore, resource).
Usage: scriptfoundry new [OPTIONS] NAME
Create new script from template
Options:
--template [setup|teardown|save|restore|blueprint|resource]
Specify script template 'type'. Defaults to
'blueprint'. [required]
--output TEXT (Optional) - Specify path to output
directory. Defaults to current directory.
--help Show this message and exit.
Online mode will pull cookiecutter templates from github repo
To Setup up Offline mode:
- download templates from github release page
- Unzip templates and copy to designated location on client dev machine
- Set Shellfoundry config "online_mode" to False
- Add custom config key to shellfoundry config, with the templates path as value
Sample Configuration:
shellfoundry config online_mode False
shellfoundry config script_template_location "C:\cloudshell_dev_files\cloudshell-script-templates-0.1.0"
It can be useful to use the api generator helper to get api session without having to add credentials to debug file. With this helper, no need to erase credentials and no accidentally commiting secrets to source control.
from scriptfoundry.utilities.api_generator import AutomationApiGenerator
SANDBOX_ID = "<DEBUG_SANDBOX_ID>"
api = AutomationApiGenerator().create_client()
sb_details = api.GetReservationDetails(SANDBOX_ID, disableCache=True).ReservationDescription
Scriptfoundry is built on top of shellfoundry, and its underlying open-source dependencies
- shellfoundry - cloudshell config management
- Cookiecutter - script template generation
- Click - CLI interface
Free Software: MIT License