Skip to content
This repository has been archived by the owner on Jun 4, 2021. It is now read-only.

Commit

Permalink
Add support for Scaleway
Browse files Browse the repository at this point in the history
  • Loading branch information
remyleone committed May 2, 2019
1 parent 9ef81d2 commit 645ffef
Show file tree
Hide file tree
Showing 7 changed files with 173 additions and 2 deletions.
1 change: 1 addition & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,7 @@ See also:
* Google Compute Engine (GCE)
* Linode
* Rackspace
* Scaleway


#### Other providers
Expand Down
4 changes: 2 additions & 2 deletions deploy/streisand-new-cloud-server.sh
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@
#
# Usage:
# streisand-new-cloud-server \
# --provider [amazon|azure|digitalocean|google|linode|rackspace] \
# --provider [amazon|azure|digitalocean|google|linode|rackspace|scaleway] \
# --site-config path/to/digitalocean-site.yml
#

Expand All @@ -19,7 +19,7 @@ set -o nounset
DIR="$( cd "$( dirname "$0" )" && pwd)"
PROJECT_DIR="${DIR}/.."

VALID_PROVIDERS="amazon|azure|digitalocean|google|linode|rackspace"
VALID_PROVIDERS="amazon|azure|digitalocean|google|linode|rackspace|scaleway"
export DEFAULT_SITE_VARS="${PROJECT_DIR}/global_vars/default-site.yml"
export GLOBAL_VARS="${PROJECT_DIR}/global_vars/globals.yml"

Expand Down
53 changes: 53 additions & 0 deletions global_vars/noninteractive/scaleway-site.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
---
# Example site specific configuration for a noninteractive Scaleway
# deployment.
#
# Copy this and edit it as needed before running streisand-new-cloud-server.
#

streisand_noninteractive: true
confirmation: true

# The SSH private key that Ansible will use to connect to the Streisand node.
#
# The corresponding public key must be added to the Scaleway console
# and the name given to it referenced below in the scaleway_ssh_name variable.
# The corresponding public key must be uploaded to Scaleway and the name
# given to it referenced below in the scaleway_ssh_name variable.
streisand_ssh_private_key: "~/.ssh/id_rsa"

vpn_clients: 5

streisand_openconnect_enabled: yes
streisand_openvpn_enabled: yes
streisand_shadowsocks_enabled: yes
streisand_ssh_forward_enabled: yes
# By default sshuttle is disabled because it creates a `sshuttle` user that has
# full shell privileges on the Streisand host
streisand_sshuttle_enabled: no
streisand_stunnel_enabled: yes
streisand_tinyproxy_enabled: yes
streisand_tor_enabled: no
streisand_wireguard_enabled: yes

# Scaleway region.
#
# - fr-par1 (Paris)
# - nl-ams1 (Amsterdam)
#
scaleway_region: "nl-ams1"

scaleway_server_name: streisand

# Add the Scaleway token here.
scaleway_token: ""

# Definitions needed for Let's Encrypt HTTPS (or TLS) certificate setup.
#
# If these are both left as empty strings, Let's Encrypt will not be set up and
# a self-signed certificate will be used instead.
#
# The domain to use for Let's Encrypt certificate.
streisand_domain_var: ""
# The admin email address for Let's Encrypt certificate registration.
streisand_admin_email_var: ""
1 change: 1 addition & 0 deletions playbooks/roles/genesis-scaleway/defaults/main.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
scaleway_commercial_type: DEV1-S
61 changes: 61 additions & 0 deletions playbooks/roles/genesis-scaleway/tasks/main.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,61 @@
---
- set_fact:
streisand_genesis_role: "genesis-scaleway"

- name: "Get the {{ streisand_ssh_private_key }}.pub contents"
command: "cat {{ streisand_ssh_private_key }}.pub"
register: ssh_key
changed_when: False

- name: Set the Scaleway Token fact to the value that was entered, or attempt to retrieve it from the environment if the entry is blank
set_fact:
scaleway_token: "{{ scaleway_token | default( lookup('env', 'SCW_TOKEN') ) }}"

- block:
- name: Add the SSH key to Scaleway if it does not already exist
scaleway_sshkey:
ssh_pub_key: "{{ ssh_key.stdout }}"
state: present
register: scaleway_ssh_key
rescue:
- fail:
msg: "* The SSH key may already exist in the Scaleway console under a different name."

- block:
- name: "Fetch image id for Ubuntu Bionic"
scaleway_image_facts:
region: "{{ regions[scaleway_region] }}"
name: Ubuntu Bionic
register: image

- name: Create a Scaleway instance
scaleway_compute:
name: "{{ scaleway_server_name }}"
commercial_type: "{{ scaleway_commercial_type }}"
region: "{{ regions[scaleway_region] }}"
image: "{{ image[0].id }}"
wait: yes
register: streisand_server
rescue:
- fail:
msg: "Unable to create the Scaleway server."

- name: Wait until the server has finished booting and OpenSSH is accepting connections
wait_for:
host: "{{ streisand_server.ip_address }}"
port: 22
search_regex: OpenSSH
timeout: 600

- name: Create the in-memory inventory group
add_host:
name: "{{ streisand_server.ip_address }}"
groups: streisand-host

- name: Set the streisand_ipv4_address variable
set_fact:
streisand_ipv4_address: "{{ streisand_server.ip_address }}"

- name: Set the streisand_server_name variable
set_fact:
streisand_server_name: "{{ scaleway_server_name | regex_replace('\\s', '_') }}"
53 changes: 53 additions & 0 deletions playbooks/scaleway.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
---
- name: Provision the Scaleway Server
# ===================================
hosts: localhost
connection: local
gather_facts: yes

vars:
regions:
"1": "fr-par-1"
"2": "nl-ams-1"

vars_prompt:
- name: "scaleway_region"
prompt: >
What region should the server be located in?
1. fr-par-1 (Paris)
2. nl-ams-1 (Amsterdam)
Please choose the number of your region. Press enter for default (#1) region.
default: "1"
private: no

- name: "scaleway_server_name"
prompt: "\nWhat should the server be named? Press enter for default (streisand).\n"
default: "streisand"
private: no

- name: "scaleway_token"
prompt: |
Tokens allow Streisand to create a Scaleway instance for you.
New Personal Access Tokens can be generated in the Scaleway console.
To generate a new token please do the following:
* Go to https://console.scaleway.com/account/credentials
* Click 'Generate New Token'
* Give the token a purpose (it is arbitrary)
* Copy the long string that is generated and paste it below.
* Click 'Generate Token'
If this field is left blank, the environment variable SCW_TOKEN will be used.
What is your Scaleway Token?
private: no

- name: "confirmation"
prompt: "\nStreisand will now set up your server. This process usually takes around ten minutes. Press Enter to begin setup...\n"

roles:
- genesis-scaleway

- import_playbook: ssh-setup.yml
- import_playbook: cloud-status.yml
- import_playbook: streisand.yml
...
2 changes: 2 additions & 0 deletions streisand
Original file line number Diff line number Diff line change
Expand Up @@ -199,6 +199,7 @@ read -r -p "Which provider are you using?
6. Rackspace
7. localhost (Advanced)
8. Existing Server (Advanced)
9. Scaleway
: " reply

case "$reply" in
Expand All @@ -210,5 +211,6 @@ case "$reply" in
6) run_genesis rackspace.yml;;
7) local_provision;;
8) existing_server;;
9) run_genesis scaleway.yml;;
*) echo; echo "Invalid provider selected."; exit 1;;
esac

0 comments on commit 645ffef

Please sign in to comment.