12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- class Integration::PGPController < ApplicationController
- prepend_before_action :authenticate_and_authorize!
- def key_list
- model_index_render(PGPKey, params)
- end
- def key_show
- model_show_render(PGPKey, params)
- end
- def key_download
- key = PGPKey.find(params[:id])
- if %w[1 true].include?(params[:secret])
- raise Exceptions::UnprocessableEntity, __('This is not a private PGP key.') if !key.secret
- return send_data(
- key.key,
- filename: "#{key.fingerprint}.asc",
- type: 'text/plain',
- disposition: 'attachment'
- )
- end
- send_data(
- export(key),
- filename: "#{key.fingerprint}.pub.asc",
- type: 'text/plain',
- disposition: 'attachment'
- )
- end
- def key_add
- PGPKey.params_cleanup! params
- model_create_render(PGPKey, params)
- end
- def key_delete
- model_destroy_render(PGPKey, params)
- end
- def status
- if !SecureMailing::PGP.required_version?
- error = __('gpg (GnuPG) 2.2.0 or newer is required')
- end
- render json: { error: error }.compact
- end
- def search
- security_options = SecureMailing::PGP::SecurityOptions.new(ticket: params[:ticket], article: params[:article]).process
- result = {
- type: 'PGP',
- encryption: map_result(security_options.encryption),
- sign: map_result(security_options.signing),
- }
- render json: result
- end
- private
- def map_result(method_result)
- {
- success: method_result.possible?,
- comment: method_result.message,
- commentPlaceholders: method_result.message_placeholders,
- }
- end
- def export(key)
- SecureMailing::PGP::Tool.new.with_private_keyring do |pgp_tool|
- pgp_tool.import(key.key)
- pgp_tool.export(key.fingerprint).stdout
- end
- end
- end
|