NAME

Dancer2::Serializer::JSON - Serializer for handling JSON data

VERSION

version 1.0.0

DESCRIPTION

This is a serializer engine that allows you to turn Perl data structures into JSON output and vice-versa.

ATTRIBUTES

content_type

Returns 'application/json'

METHODS

serialize($content)

Serializes a Perl data structure into a JSON string.

deserialize($content)

Deserializes a JSON string into a Perl data structure.

FUNCTIONS

from_json($content, \%options)

This is an helper available to transform a JSON data structure to a Perl data structures.

to_json($content, \%options)

This is an helper available to transform a Perl data structure to JSON.

Calling this function will not trigger the serialization's hooks.

Configuring the JSON Serializer using set engines

The JSON serializer options can be configured via set engines. The most common settings are:

allow_nonref

Ignore non-ref scalars returned from handlers. With this set the "Hello, World!" handler returning a string will be dealt with properly.

Set engines should be called prior to setting JSON as the serializer:

set engines =>
{
    serializer =>
    {
        JSON =>
        {
           allow_nonref => 1
        },
    }
};

set serializer      => 'JSON';
set content_type    => 'application/json';

Returning non-JSON data.

Handlers can return non-JSON via send_as, which overrides the default serializer:

get '/' =>
sub
{
    send_as html =>
    q{Welcome to the root of all evil...<br>step into my office.}
};

Any other non-JSON returned format supported by 'send_as' can be used.

AUTHOR

Dancer Core Developers

COPYRIGHT AND LICENSE

This software is copyright (c) 2023 by Alexis Sukrieh.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.