Skip to content

Commit

Permalink
Merge pull request #5 from mrsool/fix/tlv-conversion
Browse files Browse the repository at this point in the history
  • Loading branch information
obahareth authored Nov 12, 2021
2 parents 769eaf1 + 09c0cf3 commit 19c71c1
Show file tree
Hide file tree
Showing 4 changed files with 16 additions and 6 deletions.
9 changes: 6 additions & 3 deletions lib/zatca/tag.rb
Original file line number Diff line number Diff line change
Expand Up @@ -22,10 +22,13 @@ def to_h

def to_tlv
# TLV should be concatenated together without any separator in the following
# format: hex_value_of_id hex_value_of_length value_itself
# where hex_values should be padded with a 0 if containing only a single digit.
# format: character_value_of_id character_value_of_value_length value_itself
# All of this should be in 8-bit ASCII.
tlv = @id.chr + @value.length.chr + value

sprintf("%02X%02X%s", @id, @value.length, @value)
# We need to use force_encoding because encode will raise errors when
# trying to encode a string with utf-8 characters.
tlv.force_encoding("ASCII-8BIT")
end
end
end
2 changes: 1 addition & 1 deletion spec/lib/zatca/qr_code_generator_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@

describe "#render" do
it "returns a base64 data_url" do
expect(generator.render).to eq("")
expect(generator.render).to eq("")
end
end
end
9 changes: 8 additions & 1 deletion spec/lib/zatca/tag_spec.rb
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
describe ZATCA::Tag do
let(:tag) { ZATCA::Tag.new(key: :seller_name, value: "Mrsool") }
let(:unicode_tag) { ZATCA::Tag.new(key: :seller_name, value: "مرسول") }

describe "#id" do
it "gets mapped from seller_name to 1" do
Expand Down Expand Up @@ -31,7 +32,13 @@

describe "#to_tlv" do
it "generates a valid TLV" do
expect(tag.to_tlv).to eq("0106Mrsool")
expect(tag.to_tlv).to eq("\x01\x06Mrsool")
end

it "generates a valid TLV when passed unicode input" do
expected_output = "\x01\x05\xD9\x85\xD8\xB1\xD8\xB3\xD9\x88\xD9\x84".force_encoding("ASCII-8BIT")

expect(unicode_tag.to_tlv).to eq(expected_output)
end
end
end
2 changes: 1 addition & 1 deletion spec/lib/zatca/tags_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@

describe "#to_base64" do
it "generates valid Base64" do
expect(tags.to_base64).to eq("MDEwNk1yc29vbDAyMEYzMTAyMjg4MzM0MDAwMDMwMzE5MjAyMS0xMC0yMFQxOToyOTozMiswMzowMDA0MDMxMTUwNTAyMTU=")
expect(tags.to_base64).to eq("AQZNcnNvb2wCDzMxMDIyODgzMzQwMDAwMwMZMjAyMS0xMC0yMFQxOToyOTozMiswMzowMAQDMTE1BQIxNQ==")
end
end
end

0 comments on commit 19c71c1

Please sign in to comment.