Skip to content

ruevaughn/EasyManager

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

28 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

EasyManager

Simple ruby library to manage cloud servers

Available provider :

  • Scaleway

Scaleway available images:

  • debian-buster
  • ubuntu-jammy

Scaleway available instances:

  • DEV1-S
  • DEV1-M
  • DEV1-L
  • DEV1-XL

Installation

In your Gemfile

gem 'easy_manager', '~> 0.9.4'

Or

gem install easy_manager

Usage example

require 'easy_manager'

options = {
  zone: 'fr-par-1',
  project: 'YOUR-PROJECT-ID',
  secret_token: 'YOUR-SECRET-TOKEN'
}

# It is possible to pass the following arguments :
#  { username: 'root', ssh_key: '/root/.ssh/id_rsa' }
ssh = EasyManager::SSH.new
manager = EasyManager::Scaleway.new(options)

# Displays all instances
servers = manager.list
puts servers

# Create a new instance
# It is possible to pass the following arguments :
#  { srv_type: 'DEV1-S', image: 'ubuntu-jammy', name_pattern: 'scw-easymanager-__RANDOM__', cloud_init: false }
srv = manager.create({ cloud_init: "#{__dir__}/cloud-init.yml" })

# Sleep unitil the server is ready, the default timeout value is 600
timeout = 60
ready = manager.wait_until_ready!(srv, ssh, timeout)
return unless ready

# It is also possible to check independently if the server is ready
manager.srv_ready?(srv, ssh)

# Executes multiple commands and stores the results
cmds = %w[id hostname]
cmd_results = EasyManager::SSH.cmd_exec(ssh, srv, cmds)

cmd_results.each do |cmd, result|
  p "Executed cmd : '#{cmd}' and get : '#{result}'"
  # > "Executed cmd : 'id' and get : 'uid=0(root) gid=0(root) groups=0(root)'"
  # > "Executed cmd : 'hostname' and get : 'scw-easymanager-uklyyuqi'"
end

# Transfer a file and a folder in recursive mode on the server
files = {
  '/tmp/file1.txt' => {
    remote: '/tmp'
  },
  '/tmp/folder' => {
    remote: '/tmp/another',
    recursive: true
  }
}
EasyManager::SSH.scp(ssh, srv, files)

# Delete the server
manager.delete(srv)
manager.delete_by_id('xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx')

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Ruby 100.0%