renuo-cli 4.18.1 → 4.19.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: bae3114f37cfe01f2826e83aab108fe1c9b33a29da840214d768e9f18f418a1b
4
- data.tar.gz: 83d9d199de7af9049419c2784c226a87eb1c749727982bdb31a4c237eb65355b
3
+ metadata.gz: 67d1a1aabbf0a54a5f93018178724eef959d87e61b6b5e7819c72c826646b925
4
+ data.tar.gz: 8b584d301b391e7bab989af846092bffd7635ba84862d31621fc45b76969b580
5
5
  SHA512:
6
- metadata.gz: da97bacdee6165fb3f3702d41229cb00609a09a5fff479213bb3d8d31a21ceeaf9460454bb57385cc7f6d60d8d61a0e427fddb3c3fbe31fb8245bddd96e18a77
7
- data.tar.gz: 2d8a90db015c046e86e4f0f1937d45d02c69b1e9d3d6829deb8128e65114bb5055af3778a4e441f7f75f0b7b0794f1aea7a6a9663a1607b5a7d15bbcf339716a
6
+ metadata.gz: 6c94a81ccf21115e5bdd9149ea408d31686c0f7b018a292f633bfae5b9da0e2dde58ecb3cd32d88f7ebb2a63207ecffd38c526ba342aa2d552bd07554256cf14
7
+ data.tar.gz: 7bb4bb3454243794e9efed8becd728a7d976f972618b8d29af226072c602c2c49d069e7a01ed8500faaf9645556bdcf9f490040e3ada0d2e3609e6a64e65944a
@@ -160,13 +160,18 @@ class Renuo::Cli::Commands::CreateDeploioApp # rubocop:disable Metrics/ClassLeng
160
160
  nctl create postgres #{environment} \\
161
161
  --project=#{@project_name_with_org_prefix} \\
162
162
  --postgres-version=#{@postgres_version} \\
163
- --machine-type=nine-db-xs
163
+ --machine-type=nine-db-xs \\
164
+ --allowed-cidrs=0.0.0.0/0 \\
165
+ --location=nine-es34
164
166
  OUTPUT
165
167
  else
166
168
  say <<~OUTPUT
167
169
  nctl create postgresdatabase #{environment} \\
168
170
  --project=#{@project_name_with_org_prefix} \\
169
- --postgres-database-version=#{@postgres_version}
171
+ --postgres-database-version=#{@postgres_version} \\
172
+ --location=nine-es34 \\
173
+ --backup-schedule=daily
174
+ --collation=C.UTF-8
170
175
  OUTPUT
171
176
  end
172
177
  end
@@ -107,7 +107,7 @@ class Renuo::Cli::Commands::CreateDeploioObjectStorage
107
107
  --project #{@project_name} \\
108
108
  --env="DEPLOIO_ACCESS_KEY={ACCESS_KEY}" \\
109
109
  --env="DEPLOIO_SECRET_KEY={SECRET_KEY}" \\
110
- --env="DEPLOIO_ENDPOINT=https://#{@location}.objects.nineapis.ch" \\
110
+ --env="DEPLOIO_ENDPOINT=https://#{@location.gsub("nine-", "")}.objects.nineapis.ch" \\
111
111
  --env="DEPLOIO_BUCKET=#{bucket_name}"
112
112
  OUTPUT
113
113
  end
@@ -55,15 +55,16 @@ class Renuo::Cli::Commands::Debug
55
55
 
56
56
  open_cmds = []
57
57
 
58
+ # rubocop:disable Layout/LineLength
58
59
  if should_scan_deploio && Cache.stored_at("deploio_apps")
59
60
  select_deploio_targets(query).each do |app|
60
- bash_cmd = "nctl exec app #{app[:name]} bash --project #{app[:namespace]}"
61
+ bash_cmd = "nctl #{bold("exec")} app #{bold(app[:name])} bash --project #{bold(app[:namespace])}"
61
62
  menu.choice(bash_cmd) { exec bash_cmd.squish }
62
63
 
63
- rails_console_cmd = "nctl exec app #{app[:name]} bundle exec rails console --project #{app[:namespace]}"
64
+ rails_console_cmd = "nctl #{bold("exec")} app #{bold(app[:name])} bundle #{bold("exec")} rails console --project #{bold(app[:namespace])}"
64
65
  menu.choice(rails_console_cmd) { exec rails_console_cmd.squish }
65
66
 
66
- log_cmd = "nctl logs app #{app[:name]} -f --project #{app[:namespace]}"
67
+ log_cmd = "nctl #{bold("logs")} app #{bold(app[:name])} -f --project #{bold(app[:namespace])}"
67
68
  menu.choice(log_cmd) { exec log_cmd.squish }
68
69
 
69
70
  app[:hosts].each do |host|
@@ -71,16 +72,17 @@ class Renuo::Cli::Commands::Debug
71
72
  end
72
73
  end
73
74
  end
75
+ # rubocop:enable Layout/LineLength
74
76
 
75
77
  if should_scan_heroku && Cache.stored_at("heroku_apps")
76
78
  select_heroku_targets(query).each do |app|
77
- exec_cmd = "heroku run bash --app #{app[:name]}"
79
+ exec_cmd = "heroku #{bold("run")} bash --app #{bold(app[:name])}"
78
80
  menu.choice(exec_cmd) { exec exec_cmd.squish }
79
81
 
80
- rails_console_cmd = "heroku run bundle exec rails console --app #{app[:name]}"
82
+ rails_console_cmd = "heroku #{bold("run")} bundle exec rails console --app #{bold(app[:name])}"
81
83
  menu.choice(rails_console_cmd) { exec rails_console_cmd.squish }
82
84
 
83
- log_cmd = "heroku logs -t --app #{app[:name]}"
85
+ log_cmd = "heroku #{bold("logs")} -t --app #{bold(app[:name])}"
84
86
  menu.choice(log_cmd) { exec log_cmd.squish }
85
87
 
86
88
  app[:domains].each do |host|
@@ -111,4 +113,11 @@ class Renuo::Cli::Commands::Debug
111
113
  app[:name].include?(query) || app[:domains].any? { |domain| domain.include?(query) }
112
114
  end
113
115
  end
116
+
117
+ BOLD_START = "\033[1m"
118
+ BOLD_END = "\033[0m"
119
+
120
+ def bold(text)
121
+ "#{BOLD_START}#{text}#{BOLD_END}"
122
+ end
114
123
  end
@@ -12,7 +12,7 @@ spec:
12
12
  notify:
13
13
  slack:
14
14
  endpoint: <%= slack_endpoint %>
15
- channels: ["#project-<%= project_name %>"]
15
+ channels: ["#project-<%= project_name %>-notifications"]
16
16
  - name: build notifications
17
17
  filter:
18
18
  projects: [<%= project_name %>]
@@ -22,4 +22,4 @@ spec:
22
22
  notify:
23
23
  slack:
24
24
  endpoint: <%= slack_endpoint %>
25
- channels: ["#project-<%= project_name %>"]
25
+ channels: ["#project-<%= project_name %>-notifications"]
@@ -1,31 +1,26 @@
1
1
  version: v1.0
2
2
  name: <%= environment %>-deploy
3
+
3
4
  agent:
4
5
  machine:
5
6
  type: f1-standard-4
6
7
  os_image: ubuntu2204
7
8
 
8
9
  blocks:
9
- - name: <%= environment %>-deploy
10
+ - name: cd
10
11
  execution_time_limit:
11
12
  minutes: 10
12
13
  task:
13
14
  secrets:
14
15
  - name: <%= project_name %>
15
16
  - name: nctl
16
- env_vars:
17
- - name: DEPLOIO_PROJECT
18
- value: renuo-<%= project_name %>
19
- - name: DEPLOIO_APP_NAME
20
- value: <%= environment %>
21
17
  jobs:
22
- - name: <%= environment %>-deploy
18
+ - name: deploying
23
19
  commands:
24
- - checkout --use-cache
25
20
  - echo 'deb [trusted=yes] https://repo.nine.ch/deb/ /' | sudo tee /etc/apt/sources.list.d/repo.nine.ch.list
26
- - sudo apt-get -qq update
27
- - sudo apt-get -qq install -y nctl
21
+ - sudo apt-get update -qqo Dir::Etc::sourcelist=/etc/apt/sources.list.d/repo.nine.ch.list
22
+ - sudo apt-get install -qq nctl
28
23
  - nctl auth login --api-client-id=$NCTL_API_CLIENT_ID --api-client-secret=$NCTL_API_CLIENT_SECRET --organization=$NCTL_ORGANIZATION
29
- - nctl update app $DEPLOIO_APP_NAME -p $DEPLOIO_PROJECT --build-env="RUBY_VERSION=$(cat .ruby-version)" --git-revision=$(git rev-parse HEAD) --skip-repo-access-check
30
- - gem i renuo-cli
31
- - renuo check-deploio-status
24
+ - nctl update app <%= environment %> -p <%= project_name %> --build-env="RUBY_VERSION=$(cat .ruby-version)" --git-revision=$SEMAPHORE_GIT_SHA --skip-repo-access-check
25
+ - gem i -q renuo-cli
26
+ - renuo check-deploio-status -a <%= environment %> -p <%= project_name %> -g $SEMAPHORE_GIT_SHA
@@ -49,7 +49,7 @@ blocks:
49
49
  value: test
50
50
  prologue:
51
51
  commands:
52
- - sem-service start postgres 16
52
+ - sem-service start postgres 17
53
53
  - cp .env.example .env
54
54
  - bundle exec rails db:create db:schema:load
55
55
  jobs:
@@ -3,7 +3,7 @@
3
3
  # :nocov:
4
4
  module Renuo
5
5
  class Cli
6
- VERSION = "4.18.1"
6
+ VERSION = "4.19.0"
7
7
  NAME = "renuo-cli"
8
8
  end
9
9
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: renuo-cli
3
3
  version: !ruby/object:Gem::Version
4
- version: 4.18.1
4
+ version: 4.19.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Renuo AG
@@ -122,7 +122,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
122
122
  - !ruby/object:Gem::Version
123
123
  version: '0'
124
124
  requirements: []
125
- rubygems_version: 4.0.2
125
+ rubygems_version: 4.0.8
126
126
  specification_version: 4
127
127
  summary: The Renuo CLI automates some common workflows.
128
128
  test_files: []