allow to pass signature as base64

pull/217/head
Pete Matsyburka 2 years ago
parent 49f14c7929
commit 0f2889904a

@ -115,12 +115,12 @@ module Submitters
blob = blob =
if value.match?(%r{\Ahttps?://}) if value.match?(%r{\Ahttps?://})
find_or_create_blob_from_url(account, value) find_or_create_blob_from_url(account, value)
elsif type.in?(%w[signature initials]) elsif type.in?(%w[signature initials]) && value.length < 50
raise InvalidDefaultValue, "Text value can't be more than 50 characters: #{value}" unless value.length < 50
find_or_create_blob_from_text(account, value, type) find_or_create_blob_from_text(account, value, type)
elsif (data = Base64.decode64(value)) && Marcel::MimeType.for(data).include?('image')
find_or_create_blob_from_base64(account, data, type)
else else
raise InvalidDefaultValue, "Invalid default value, url is expected: #{value}" raise InvalidDefaultValue, "Invalid value, url, base64 or text < 50 chars is expected: #{value.first(50)}..."
end end
attachment = for_submitter.attachments.find_by(blob_id: blob.id) if for_submitter attachment = for_submitter.attachments.find_by(blob_id: blob.id) if for_submitter
@ -133,6 +133,17 @@ module Submitters
attachment attachment
end end
def find_or_create_blob_from_base64(account, data, type)
checksum = Digest::MD5.base64digest(data)
blob = find_blob_by_checksum(checksum, account)
blob || ActiveStorage::Blob.create_and_upload!(
io: StringIO.new(data),
filename: "#{type}.png"
)
end
def find_or_create_blob_from_text(account, text, type) def find_or_create_blob_from_text(account, text, type)
data = Submitters::GenerateFontImage.call(text, font: type) data = Submitters::GenerateFontImage.call(text, font: type)

Loading…
Cancel
Save