forked from puppetlabs/puppetlabs-peadm
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrbac_token.rb
executable file
·36 lines (30 loc) · 920 Bytes
/
rbac_token.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
#!/opt/puppetlabs/puppet/bin/ruby
# frozen_string_literal: true
#
# rubocop:disable Style/GlobalVars
require 'net/https'
require 'uri'
require 'json'
require 'fileutils'
# Parameters expected:
# Hash
# String password
$params = JSON.parse(STDIN.read)
uri = URI.parse('https://localhost:4433/rbac-api/v1/auth/token')
body = {
'login' => 'admin',
'password' => $params['password'],
'lifetime' => '1y',
'label' => 'provision-time token',
}.to_json
http = Net::HTTP.new(uri.host, uri.port)
http.use_ssl = true
http.verify_mode = OpenSSL::SSL::VERIFY_NONE
request = Net::HTTP::Post.new(uri.request_uri)
request['Content-Type'] = 'application/json'
request.body = body
response = http.request(request)
raise unless response.is_a? Net::HTTPSuccess
token = JSON.parse(response.body)['token']
FileUtils.mkdir_p('/root/.puppetlabs')
File.open('/root/.puppetlabs/token', 'w') { |file| file.write(token) }