Encoder and Decoder
Type Map
- How types are mapped between Python and AMF
Python -> AS3
| Python | AS3 | |:-------|:----| | None | null | | True | true | | False | false | | int | int | | long, float | Number | | str, unicode | String | | dict | Object | | list, tuple | Array | | xml.dom.minidom.Document | XML, XMLDocument | | datetime | Date |
AS3 -> Python
| AS3 | Python | |:----|:-------| | null | None | | undefined | None | | true | True | | false | False | | int | int | | Number | float | | String | unicode | | Object, MixedArray | dict | | Array | list | | XML, XMLDocument | xml.dom.minidom.Document | | Date | datetime |
Encoding
- Use the amfast.encoder.Encoder class to encode objects.
Encoder
- amf3 - bool - True to encode as AMF3.
- use_collections - bool - True to encode lists and tuples as ArrayCollections.
- use_proxies - bool - True to encode dicts as ObjectProxies.
- use_references - bool - True to encode multiply occurring objects by reference.
- use_legacy_xml - bool - True to encode XML as XMLDocument instead of e4x.
- include_private - bool - True to encode attributes starting with an underscore.
- class_def_mapper - amfast.class_def.ClassDefMapper - The object that retrieves ClassDef objects.
- buffer - file-like-object - Output buffer. Set to None to output to a string.
``` from amfast.encoder import Encoder
Encode an object to AMF0
encoder = Encoder(amf3=False) encoded = encoder.encode(obj)
Encode an object to AMF3
encoder = Encoder(amf3=True) encoded = encoder.encode(obj)
Encode an AMF Packet
encoded = encoder.encode_packet(packet_obj)
If the 'buffer' attribute
of the encoder is not set,
the return value of 'encode'
method is a string.
#
If the 'buffer' attribute
is set, the return value is
the buffer object.
```
Decoding
- Use the amfast.decoder.Decoder class to decode objects.
Decoder
- amf3 - bool - True to decode as AMF3.
- class_def_mapper - amfast.class_def.ClassDefMapper - The object that retrieves ClassDef objects.
``` from amfast.decoder import Decoder
Decode an object from AMF0
decoder = Decoder(amf3=False) obj = decoder.decode(encoded)
Decode an object from AMF3
decoder = Decoder(amf3=True) obj = decoder.decode(encoded)
Decode an AMF Packet
packet_obj = decoder.decode_packet(encoded) ```
Custom Type Maps
- AmFast supports user-defined object types.
- Use a amfast.class_def.ClassDef object to define how custom objects are serialized/deserialized.
- Use a ClassDefMapper to map amfast.class_def.ClassDef to an object alias.
``` from amfast import class_def
ClassDefMapper objects keep track of ClassDefs
class_mapper = class_def.ClassDefMapper()
Map a custom class with static attributes
class_mapper.mapClass(class_def.ClassDef(MyCustomClass, 'class.alias', ('tuple', 'of', 'static', 'attribute', 'names')))
Object attributes can be automatically converted
to/from a specific type with the
encode_types and decode_types attributes.
#
encode_types and decode_types are dictionaries where
the keys are the names of the attributes to convert,
and the values are functions that will perform the conversion.
mapped_class = class_def.ClassDef(MyCustomClass, 'class.alias'.... mapped_class.encode_types = {'attribute_to_convert_to_int_before_encoding': int} mapped_class.decode_types = {'attribute_to_convert_to_int_after_decoding': int}
Map a custom class with dynamic attributes
class_mapper.mapClass(class_def.DynamicClassDef(MyCustomClass, 'class.alias', ()))
Map a custom class implementing IExternalizable
ExternClassDef must be sub-classed, and the
methods readExternal and writeExternal must be implemented.
class_mapper.mapClass(class_def.ExternClassDef(MyCustomClass,'class.alias'))
Map a custom class that is also mapped with SQLAlchemy.
Attributes mapped with SQLAlchemy will automatically be
added to the list of static attributes.
class_mapper.mapClass(class_def.sa_class_def.SaClassDef(MyCustomClass, 'class.alias')
Attach ClassDefMapper to Encoder and Decoder
objects to use the ClassDefMapper for encoding
and decoding
encoder.class_def_mapper = class_mapper decoder.class_def_mapper = class_mapper
Use custom class mappings with a Channel
channel = channel_set.getChannel('channel_name') channel.endpoint.encoder.class_def_mapper = class_mapper channel.endpoint.decoder.class_def_mapper = class_mapper ```