The example files contained here work with the project:create
command and its options. The Platform.sh CLI is the official command-line interface for Platform.sh more information, including installation instructions can be found here: https://github.com/platformsh/platformsh-cli.
Aliases: create
Description: Create a new project
Usage:
platform create [--title TITLE] [--catalog_url CATALOG_URL] [--region REGION] [--plan PLAN] [--environments ENVIRONMENTS] [--storage STORAGE] [--initialized INITIALIZED] [--check-timeout CHECK-TIMEOUT] [--timeout TIMEOUT] [--template TEMPLATE] [--catalog] [--initialize] [--current-repo]
Options:
--title=TITLE The initial project title
[default: "Untitled Project"]
--catalog_url=CATALOG_URL The template from which to create your
project or your own blank project.
--region=REGION The region where the project will be
hosted ('eu-2.platform.sh',
'us-2.platform.sh', 'au.platform.sh',
'ca-1.platform.sh')
--plan=PLAN The subscription plan (e.g. 'development',
'standard', 'medium', 'large')
[default: "development"]
--environments=ENVIRONMENTS The number of environments
[default: 3]
--storage=STORAGE The amount of storage per environment, in
GiB [default: 5]
--initialized=INITIALIZED Initialize this environment?
[default: true]
--check-timeout=CHECK-TIMEOUT The API timeout while checking the project
status [default: 30]
--timeout=TIMEOUT The total timeout for all API checks (0 to
disable the timeout) [default:
900]
--template=TEMPLATE Choose a starting template or provide a
url of one.
--catalog An option that adds additional form fields
which allow for the choice a template from
the catalog
--initialize An option that will automatically initialize
the project and skip the form field.
--current-repo Automatically set-remote after project
creation.
-h, --help Display this help message
-q, --quiet Do not output any message
-V, --version Display this application version
-y, --yes Answer "yes" to all prompts; disable
interaction
-n, --no Answer "no" to all prompts
-v|vv|vvv, --verbose Increase the verbosity of messages
Help:
Use this command to create a new project.
An interactive form will be presented with the available options. But if the
command is run non-interactively (with --yes), the form will not be displayed,
and the --region option will be required.
A project subscription will be requested, and then checked periodically (every 3
seconds) until the project has been activated, or until the process times out
(after 15 minutes by default).
If known, the project ID will be output to STDOUT. All other output will be sent
to STDERR.
A catalog is a list of template objects. Template objects are composed of an info
and a template
key. The info key is used to render the template for selection:
info:
description: WordPress is the world's most widely used lightweight CMS and blogging
tool.
id: platformsh/wordpress
image: 
name: Wordpress
notes:
- content: PHP 7.2<br/>MySQL 10.2
heading: Apps & Services
tags:
- PHP
- WordPress
- CMS
template: https://github.com/platformsh/template-builder/blob/master/templates/wordpress/files/.platform.template.yaml
The info key contains the title
, a list of content blocks for rendering in the template description, and a set of tags used to present a filtering interface.
The template key is the URL to the actual template file, which is a different format of file described below.
A template file contains a list of keys that Platform.sh uses during the initial settings and creation process of a project. The contents of the template file controls the project's intital setup behavior and sets restrictions on the resources a given project can consume.
info:
# Unique machine name, prefaced by a vendor or organization identifier
id: platformsh/drupal7
# The human-readable name of the template.
name: Drupal 7
# Human-readable descriptive text for the template. Supports limited HTML.
description: |
<p>This template builds a Drupal 7 site using Drush make.</p>
<p>Drupal is a flexible and extensible PHP-based CMS framework. Version 7 is the legacy support version.</p>
# A list of tags associated with the template.
tags:
- PHP
- Drupal
- CMS
# An image URI (either base64-encoded or a URL) representing the template.
image: 
# Additional notes displayed in the template's detail view.
# Each note object is displayed as a small section heading with content below. Supports limited HTML.
notes:
- heading: "Apps & Services"
content: "PHP 7.2<br/>MySQL 10.2"
# This key describes the initialization call made to the master environment at
# project creation time. This is part of the full v2 UI operation mode, which
# places project schema/options selection early in the creation process, rather
# than later as it exitss now. To allow this schema to be backwards-compatible,
# this key also gets mapped to the appropriate location in project.settings so
# that the current UI can have its own workflow overridden as well.
initialize:
repository: git://github.com/platformsh/template-drupal7.git@master
config: null
files: []
profile: Drupal 7
# The default key allows the `YAML` file to make additional changes to the project after
# it has been provisioned but before the subscrition is marked as active.
defaults:
# Here the `variables` key allows default project-level variables to be set.
variables:
- name: env:COMPOSER_AUTH
value: ""
is_json: false
visible_build: true
visible_runtime: false
- name: drupal7:site_name
value: "Hello, world!"
is_json: false
visible_build: false
visible_runtime: true
# A list of UUIDs and access levels for the project
access:
- user: [UUID HERE]
role: admin
- user: [UUID HERE]
role: viewer
- email: [EMAIL HERE]
role: admin
- user: [UUID HERE]
#This key allows the list of available regions to be expanded or restricted for a particular project.
regions:
# This adds regions not in the default list, making them
# accessible to the user for this project/checkout.
additional:
- bc.platform.sh
# This key overrides the list provided by the defaults + the additional key,
# but does not permit access to any excluded regions. For this key, the last
# implementation of this key will "win".
only:
- us.platform.sh
- eu.platform.sh
# Removes regions from the list and blocks them from being used for
# this project.
exclude:
- us-2.platform.sh
- au.platform.sh
- eu-2.platform.sh
- nl-1.platform.sh
## Sets the available plans in the same way:
plans:
# Removes plans from the list and bloceks them from being used for this
# project.
exclude:
- development
- small
# This adds regions not in the default list, making them
# accessible to the user for this project/checkout.
additional:
- 2xlarge
- xlarge
# This key overrides the list provided by the defaults + the additional key,
# but does not permit access to any excluded plans. For this key, the last
# implementation of this key will "win" (i.e. the project level will supersede
# the vendor level if this key is present.)
only:
- development
- standard
- medium
- large
This should match the info
key present in the catalog item. This isn't required, but it's helpful to think of the catalog as being constructed by taking the info
key out of each template file.
info:
# Unique machine name, prefaced by a vendor or organization identifier
id: platformsh/drupal7
# The human-readable name of the template.
name: Drupal 7
# Human-readable descriptive text for the template. Supports limited HTML.
description: |
<p>This template builds a Drupal 7 site using Drush make.</p>
<p>Drupal is a flexible and extensible PHP-based CMS framework. Version 7 is the legacy support version.</p>
# A list of tags associated with the template.
tags:
- PHP
- Drupal
- CMS
# An image URI (either base64-encoded or a URL) representing the template.
image: 
# Additional notes displayed in the template's detail view.
# Each note object is displayed as a small section heading with content below. Supports limited HTML.
notes:
- heading: "Apps & Services"
content: "PHP 7.2<br/>MySQL 10.2"
This key contains the arguments to the environment initialization call. If this isn't included the project will not be initializable from the CLI.
initialize:
repository: git://github.com/platformsh/template-drupal7.git@master
config: null
files: []
profile: Drupal 7
repository
is the HTTP Git URL to the repository to be cloned.
config
currently not available, please use null for its value.
files
can be a list of file objects that are added to the repository from the template. The spec of a member of files
is:
{
"mode": 436, # The decimal of the file mode
"path": "auth.json", # The path of the file in the repository
"contents": "XXXXXXXX" # The base64-encoded contents of the file
}
profile
is the name used when the environment is initialized (i.e. built for the first time).
The default key allows the YAML
file to make additional changes to the project after it has been provisioned but before the subscrition is marked as active. Currently, only two default options are available variables
and access
, examples of both can be found below and in the example file above.
defaults:
# Here the `variables` key allows default project-level variables to be set.
variables:
- name: env:COMPOSER_AUTH
value: ""
is_json: false
visible_build: true
visible_runtime: false
- name: drupal7:site_name
value: "Hello, world!"
is_json: false
visible_build: false
visible_runtime: true
# A list of UUIDs and access levels for the project
access:
- user: [UUID HERE]
role: admin
- user: [UUID HERE]
role: viewer
- email: [EMAIL HERE]
role: admin
- user: [UUID HERE]
regions
allows the list of available regions to be expanded or restricted for a particular project. It accepts three different options:
additional
: This adds regions not in the default list, making them accessible to the user for this project/checkout.
only
: This key overrides the list provided by the defaults + the additional key, but does not permit access to any excluded regions. For this key, the last implementation of this key will "win".
exclude
: Removes regions from the list and blocks them from being used for this project.
regions:
additional:
- bc.platform.sh
only:
- us.platform.sh
- eu.platform.sh
exclude:
- us-2.platform.sh
- au.platform.sh
- eu-2.platform.sh
- nl-1.platform.sh
plans
is the same as the behavior of regions
above, allowing the list of plans to be expanded or reduced. This is useful for ensuring that certain templates can only be provisioned as development projects or that templates with specific resource requirements get a minimum plan size at creation time. It accepts three different options:
additional
: This adds regions not in the default list, making them accessible to the user for this project/checkout.
only
: This key overrides the list provided by the defaults + the additional key. For this key, the last implementation of this key will "win" (i.e. the project level will supersede the vendor level if this key is present.)
exclude
: Removes plans from the list and bloceks them from being used for this project.
plans:
exclude:
- development
- small
additional:
- 2xlarge
- xlarge
only:
- development
- standard
- medium
- large