fly.io-rails 0.1.16-aarch64-linux → 0.1.18-aarch64-linux

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: 36caae6e234016ba11f478ce07edc4dd58ad3ceaf64043f79572d16dac70c79c
4
- data.tar.gz: b07f4612fe20bb3bf6c64d4c3611205971bcaf5087239c85828b23b31de47604
3
+ metadata.gz: 57e5ae6928d84dfd6e9fbce5617ecdccb86c96f08b66efb388ced7acd6d4300e
4
+ data.tar.gz: a960753eba8fc03563e34656331411d060ce2270b697ce90582d77e95d0dec17
5
5
  SHA512:
6
- metadata.gz: e8afd8ae710b130f9f36f48263a41c4772d9dbb1ba69fc8d2d3d5be02407d3452655ad59879c21831d2b4bfe218f2440ba45ad8fca582c0b815a4e3ca3b1ebba
7
- data.tar.gz: 32d3a3b3f03e604993c76a0af0419b2889cd3ee1d5973d3dcfbc2d8d0da6ef9d129a2a0c771a40cf02dd52b3e2bea543ed5e5946c9b14c58d3938fbeda6eedbe
6
+ metadata.gz: 89fbef2f0e6f4849b179d46875ea4396bb5502ffdbaadcfd5bd4bf7d18d4b4cff5bb3f0858c59ef49f539a8352d9bacf3ba62d962136a9b534d9933004596fb2
7
+ data.tar.gz: 1d7533be67de6e5cc72ec96cacaf5cc13a4bb4ae6f64c7da3974cf4e77473729e80f76a1738cf5da1eed27353ba8158cb285523e114d9b145ba2d922b9631b35
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: aarch64-linux
6
6
  authors:
7
7
  - Sam Ruby