105 lines
3.3 KiB
Ruby
105 lines
3.3 KiB
Ruby
|
# frozen_string_literal: true
|
||
|
|
||
|
# rubocop:disable Rails/Output
|
||
|
module Gitlab
|
||
|
class EncryptedLdapCommand
|
||
|
class << self
|
||
|
def write(contents)
|
||
|
encrypted = Gitlab::Auth::Ldap::Config.encrypted_secrets
|
||
|
return unless validate_config(encrypted)
|
||
|
|
||
|
validate_contents(contents)
|
||
|
encrypted.write(contents)
|
||
|
|
||
|
puts "File encrypted and saved."
|
||
|
rescue Interrupt
|
||
|
puts "Aborted changing file: nothing saved."
|
||
|
rescue ActiveSupport::MessageEncryptor::InvalidMessage
|
||
|
puts "Couldn't decrypt #{encrypted.content_path}. Perhaps you passed the wrong key?"
|
||
|
end
|
||
|
|
||
|
def edit
|
||
|
encrypted = Gitlab::Auth::Ldap::Config.encrypted_secrets
|
||
|
return unless validate_config(encrypted)
|
||
|
|
||
|
if ENV["EDITOR"].blank?
|
||
|
puts 'No $EDITOR specified to open file. Please provide one when running the command:'
|
||
|
puts 'gitlab-rake gitlab:ldap:secret:edit EDITOR=vim'
|
||
|
return
|
||
|
end
|
||
|
|
||
|
temp_file = Tempfile.new(File.basename(encrypted.content_path), File.dirname(encrypted.content_path))
|
||
|
contents_changed = false
|
||
|
|
||
|
encrypted.change do |contents|
|
||
|
contents = encrypted_file_template unless File.exist?(encrypted.content_path)
|
||
|
File.write(temp_file.path, contents)
|
||
|
system(ENV['EDITOR'], temp_file.path)
|
||
|
changes = File.read(temp_file.path)
|
||
|
contents_changed = contents != changes
|
||
|
validate_contents(changes)
|
||
|
changes
|
||
|
end
|
||
|
|
||
|
puts "Contents were unchanged." unless contents_changed
|
||
|
puts "File encrypted and saved."
|
||
|
rescue Interrupt
|
||
|
puts "Aborted changing file: nothing saved."
|
||
|
rescue ActiveSupport::MessageEncryptor::InvalidMessage
|
||
|
puts "Couldn't decrypt #{encrypted.content_path}. Perhaps you passed the wrong key?"
|
||
|
ensure
|
||
|
temp_file&.unlink
|
||
|
end
|
||
|
|
||
|
def show
|
||
|
encrypted = Gitlab::Auth::Ldap::Config.encrypted_secrets
|
||
|
return unless validate_config(encrypted)
|
||
|
|
||
|
puts encrypted.read.presence || "File '#{encrypted.content_path}' does not exist. Use `gitlab-rake gitlab:ldap:secret:edit` to change that."
|
||
|
rescue ActiveSupport::MessageEncryptor::InvalidMessage
|
||
|
puts "Couldn't decrypt #{encrypted.content_path}. Perhaps you passed the wrong key?"
|
||
|
end
|
||
|
|
||
|
private
|
||
|
|
||
|
def validate_config(encrypted)
|
||
|
dir_path = File.dirname(encrypted.content_path)
|
||
|
|
||
|
unless File.exist?(dir_path)
|
||
|
puts "Directory #{dir_path} does not exist. Create the directory and try again."
|
||
|
return false
|
||
|
end
|
||
|
|
||
|
if encrypted.key.nil?
|
||
|
puts "Missing encryption key encrypted_settings_key_base."
|
||
|
return false
|
||
|
end
|
||
|
|
||
|
true
|
||
|
end
|
||
|
|
||
|
def validate_contents(contents)
|
||
|
begin
|
||
|
config = YAML.safe_load(contents, permitted_classes: [Symbol])
|
||
|
error_contents = "Did not include any key-value pairs" unless config.is_a?(Hash)
|
||
|
rescue Psych::Exception => e
|
||
|
error_contents = e.message
|
||
|
end
|
||
|
|
||
|
puts "WARNING: Content was not a valid LDAP secret yml file. #{error_contents}" if error_contents
|
||
|
|
||
|
contents
|
||
|
end
|
||
|
|
||
|
def encrypted_file_template
|
||
|
<<~YAML
|
||
|
# main:
|
||
|
# password: '123'
|
||
|
# user_dn: 'gitlab-adm'
|
||
|
YAML
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
# rubocop:enable Rails/Output
|