fly.io-rails 0.1.16-x86_64-darwin → 0.1.18-x86_64-darwin

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: c78525528d112fac3d98a906c5b15406c0311c24e57ea90103b1ac8d895fa30d
4
- data.tar.gz: eb9f8e245a321daffa03046d13997e1be01d9c0a9b3c4610b92a13e3e437f92c
3
+ metadata.gz: f2969a2977d1b9760fc0db62764a4a4c0aae3ce2d0d7eef03c68e0a13a238ea3
4
+ data.tar.gz: eac7308934153271be184aa2c8476265df6beca863cf6c50781eb1939a4dc90c
5
5
  SHA512:
6
- metadata.gz: b4b02c14d764bdbfbca4eb5efb8efa3a4547013530a32a6b9e72876b956f69a43616fb39e30bf6dc2ca4452a01251f701617a5e8a6afd0469978e1e63acb7180
7
- data.tar.gz: 91baefc86a455809ed2f4457b76e2e7cde2b754f77babfadc21c15975deadf6d514022912df9a3f12d2074ed567ee43095607349ebe0ed676cee5b92ada208b7
6
+ metadata.gz: ce055b8bd24219ca080af782fe0eb5cab99413338b6755039af9c6bf70cf612563fad12749c99a0b5fd30c5f11b06dc4f775a84a4ceed7ce6d13d933fa657927
7
+ data.tar.gz: 4ae1060171b00617d3240e7da81e0780023d2cc6093c562b05ffb32c37394f73db32e0535357be513ae808437185dd283d387dc44e4124f3d99b8978b33e8715
Binary file
@@ -197,17 +197,19 @@ module Fly
197
197
  end
198
198
 
199
199
  def create_volume(app, region, size)
200
- volume = "#{app.gsub('-', '_')}_volume"
201
- volumes = JSON.parse(`flyctl volumes list --json`).
202
- map {|volume| [volume['Name'], volume['Region']]}
200
+ name = "#{app.gsub('-', '_')}_volume"
201
+ volumes = JSON.parse(`flyctl volumes list --json`)
203
202
 
204
- unless volumes.include? [volume, region]
205
- cmd = "flyctl volumes create #{volume} --app #{app} --region #{region} --size #{size}"
203
+ volume = volumes.find {|volume| volume['Name'] == name and volume['Region'] == region}
204
+ unless volume
205
+ cmd = "flyctl volumes create #{name} --app #{app} --region #{region} --size #{size}"
206
206
  say_status :run, cmd
207
207
  system cmd
208
+ volumes = JSON.parse(`flyctl volumes list --json`)
209
+ volume = volumes.find {|volume| volume['Name'] == name and volume['Region'] == region}
208
210
  end
209
211
 
210
- volume
212
+ volume && volume['id']
211
213
  end
212
214
 
213
215
  def create_postgres(app, org, region, vm_size, volume_size, cluster_size)
@@ -235,8 +237,8 @@ module Fly
235
237
  output[%r{redis://\S+}]
236
238
  end
237
239
 
238
- def release(app, config)
239
- start = Fly::Machines.create_and_start_machine(app, config: config)
240
+ def release(app, options)
241
+ start = Fly::Machines.create_and_start_machine(app, options)
240
242
  machine = start[:id]
241
243
 
242
244
  if not machine
@@ -320,9 +322,6 @@ module Fly
320
322
 
321
323
  # default config
322
324
  config = {
323
- region: @region,
324
- app: app,
325
- name: "#{app}-machine",
326
325
  image: image,
327
326
  guest: {
328
327
  cpus: @config.machine.cpus,
@@ -351,7 +350,7 @@ module Fly
351
350
 
352
351
  # perform release
353
352
  say_status :fly, release_config[:env]['SERVER_COMMAND']
354
- event, exit_code, machine = release(app, release_config)
353
+ event, exit_code, machine = release(app, region: @region, config: release_config)
355
354
 
356
355
  if exit_code != 0
357
356
  STDERR.puts 'Error performing release'
@@ -396,21 +395,37 @@ module Fly
396
395
  config[:services] = toml['services'] if toml['services']
397
396
  if toml['mounts']
398
397
  mounts = toml['mounts']
399
- config[:mounts] = [ { volume: mounts['source'], path: mounts['destination'] } ]
398
+ volume = JSON.parse(`flyctl volumes list --json`).
399
+ find {|volume| volume['Name'] == mounts['source'] and volume['Region'] == @region}
400
+ if volume
401
+ config[:mounts] = [ { volume: volume['id'], path: mounts['destination'] } ]
402
+ else
403
+ STDERR.puts "volume #{mounts['source']} not found in region #{@region}"
404
+ exit 1
405
+ end
400
406
  end
401
407
 
402
408
  # start app
403
409
  machines = {}
410
+ options = {region: @region, config: config}
404
411
  say_status :fly, "start #{app}"
405
412
  if not toml['processes'] or toml['processes'].empty?
406
- start = Fly::Machines.create_and_start_machine(app, config: config)
413
+ options[:name] = "#{app}-machine",
414
+ start = Fly::Machines.create_and_start_machine(app, options)
407
415
  machines['app'] = start[:id]
408
416
  else
409
417
  config[:env] ||= {}
410
418
  config[:env]['NATS_SERVER'] = 'localhost'
411
419
  toml['processes'].each do |name, entrypoint|
420
+ options[:name] = "#{app}-machine-#{name}"
412
421
  config[:env]['SERVER_COMMAND'] = entrypoint
413
- start = Fly::Machines.create_and_start_machine(app, config: config)
422
+ start = Fly::Machines.create_and_start_machine(app, options)
423
+
424
+ if start['error']
425
+ STDERR.puts "ERROR: #{start.error}"
426
+ exit 1
427
+ end
428
+
414
429
  machines[name] = start[:id]
415
430
 
416
431
  config.delete :mounts
@@ -484,7 +499,7 @@ module Fly
484
499
  # perform release, if necessary
485
500
  if (IO.read('lib/tasks/fly.rake') rescue '') =~ /^\s*task[ \t]*+:?release"?[ \t]*\S/
486
501
  say_status :fly, config[:env]['SERVER_COMMAND']
487
- event, exit_code, machine = release(app, config)
502
+ event, exit_code, machine = release(app, region: @region, config: config)
488
503
  else
489
504
  exit_code = 0
490
505
  end
@@ -1,3 +1,3 @@
1
1
  module Fly_io
2
- VERSION = '0.1.16'
2
+ VERSION = '0.1.18'
3
3
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: fly.io-rails
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.16
4
+ version: 0.1.18
5
5
  platform: x86_64-darwin
6
6
  authors:
7
7
  - Sam Ruby