fly.io-rails 0.1.15-arm64-darwin → 0.1.17-arm64-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: 577e6a30efecbac9c58be47ec750643d7ac35341000d773e757d3be8d0e58762
4
- data.tar.gz: 3744d512c71e3472d7bab86f0f12269a8c03e48a144000716029c72a1c340dff
3
+ metadata.gz: 462e418cd9cd1f0232f94c3f861358fc9a4498f7df287dd65af89a2688ffaeb8
4
+ data.tar.gz: 210ed9f107a7a7e29093391920aaa02d6cb9077c774ea0f1a7dfc747329d8f17
5
5
  SHA512:
6
- metadata.gz: 3beeb38dced19c6daea3351bae0f1e9d327220e2904e7c10c21b4d524868ff4523756b86ce0808bc9f49e36d0719c43a20d8eded99c3872b1bdc785dc0006393
7
- data.tar.gz: 8cb914c6124d293aeb45210c0ec178c6fdbcb1eb19cc22376baf511889ceb7815fcf25160ff60d06ac2582db2a9fba567613a8115e966f295d489d395bf460c6
6
+ metadata.gz: 10e957aa0ac8bb64c39cfbe71693c52e597c001a2a73751fe5bcd38bafb9543d2a7ed4a6f86ac4075d9ef4e97e22a156bdc2427e3b838d51e053b445c01ac65a
7
+ data.tar.gz: d1b30c5d80923681386b95e896d1b23aa4a7fd52236e8d21db8ff6b6ee8d3a1c2bce7a3db1b7ac159793faebc4edc63d8a1ecd16461ce9390554f75ecf80e0c3
@@ -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)
@@ -396,7 +398,14 @@ module Fly
396
398
  config[:services] = toml['services'] if toml['services']
397
399
  if toml['mounts']
398
400
  mounts = toml['mounts']
399
- config[:mounts] = [ { volume: mounts['source'], path: mounts['destination'] } ]
401
+ volume = JSON.parse(`flyctl volumes list --json`).
402
+ find {|volume| volume['Name'] == mounts['source'] and volume['Region'] == @region}
403
+ if volume
404
+ config[:mounts] = [ { volume: volume['id'], path: mounts['destination'] } ]
405
+ else
406
+ STDERR.puts "volume #{mounts['source']} not found in region #{@region}"
407
+ exit 1
408
+ end
400
409
  end
401
410
 
402
411
  # start app
@@ -411,6 +420,12 @@ module Fly
411
420
  toml['processes'].each do |name, entrypoint|
412
421
  config[:env]['SERVER_COMMAND'] = entrypoint
413
422
  start = Fly::Machines.create_and_start_machine(app, config: config)
423
+
424
+ if start['error']
425
+ STDERR.puts start.inspect
426
+ exit 1
427
+ end
428
+
414
429
  machines[name] = start[:id]
415
430
 
416
431
  config.delete :mounts
@@ -174,6 +174,7 @@ module Fly
174
174
  host ||= "http://#{fly_api_hostname}"
175
175
  uri = URI.join(host, path)
176
176
  http = Net::HTTP.new(uri.host, uri.port)
177
+ http.set_debug_output $stderr if ENV['TRACE']
177
178
  http.use_ssl = true if uri.instance_of? URI::HTTPS
178
179
 
179
180
  request = make_request.call(uri.request_uri)
@@ -1,3 +1,3 @@
1
1
  module Fly_io
2
- VERSION = '0.1.15'
2
+ VERSION = '0.1.17'
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.15
4
+ version: 0.1.17
5
5
  platform: arm64-darwin
6
6
  authors:
7
7
  - Sam Ruby