NAME
Crypt::OpenToken::Serializer - Serialize payloads for OpenTokens
SYNOPSIS
use Crypt::OpenToken::Serializer;
# data to serialize
my $data = {
foo => 'bar',
bar => 'baz',
};
# freeze/serialize the data
my $payload = Crypt::OpenToken::Serializer::freeze(%{$data});
# thaw/deserialize the data
my %thawed = Crypt::OpenToken::Serializer::thaw($payload);
DESCRIPTION
This module implements the serialization routine described in the OpenToken specification for generating the payload format.
Highlights:
A line-based format in the form of "key = value".
Within quoted-strings, both double and single quotes must be escaped by a preceding backslash.
Encoded with UTF-8 and is guaranteed to support the transport of multi-byte characters.
Key names might not be unique. OpenToken supports multiple values for a key name by simply adding another key-value pair.
Key names are case-sensitive. It is RECOMMENDED that all key names be lowercase and use hyphens to separate "words".
METHODS
- Crypt::OpenToken::Serializer::thaw($string)
-
Thaws the given serialized data, returning a hash of data back to the caller.
If the data contained any repeating keys, those are represented in the hash as having an ARRAYREF as a value.
- Crypt::OpenToken::Serializer::freeze(%data)
-
Freezes the given data, returning a serialized string back to the caller.
AUTHOR
Graham TerMarsch (cpan@howlingfrog.com)
COPYRIGHT & LICENSE
Crypt::OpenToken
is Copyright (C) 2010, Socialtext, and is released under the Artistic-2.0 license.