Security Advisories (9)
CPANSA-Mojolicious-2022-03 (2022-12-10)

Mojo::DOM did not correctly parse <script> tags.

CPANSA-Mojolicious-2021-02 (2021-06-01)

Small sessions could be used as part of a brute-force attack to decode the session secret.

CVE-2021-47208 (2021-03-16)

A bug in format detection can potentially be exploited for a DoS attack.

CVE-2018-25100 (2018-02-13)

Mojo::UserAgent::CookieJar leaks old cookies because of the missing host_only flag on empty domain.

CPANSA-Mojolicious-2015-01 (2015-02-02)

Directory traversal on Windows

CPANSA-Mojolicious-2018-03 (2018-05-19)

Mojo::UserAgent was not checking peer SSL certificates by default.

CPANSA-Mojolicious-2018-02 (2018-05-11)

GET requests with embedded backslashes can be used to access local files on Windows hosts

CPANSA-Mojolicious-2014-01 (2014-10-07)

Context sensitivity of method param could lead to parameter injection attacks.

CVE-2024-58134 (2025-05-03)

Mojolicious versions from 0.999922 for Perl uses a hard coded string, or the application's class name, as an HMAC session cookie secret by default. These predictable default secrets can be exploited by an attacker to forge session cookies.  An attacker who knows or guesses the secret could compute valid HMAC signatures for the session cookie, allowing them to tamper with or hijack another user’s session.

NAME

Mojolicious::Plugin::JsonConfig - JSON Configuration Plugin

SYNOPSIS

# myapp.json
{
  "foo"       : "bar",
  "music_dir" : "<%= app->home->rel_dir('music') %>"
}

# Mojolicious
my $config = $self->plugin('json_config');

# Mojolicious::Lite
my $config = plugin 'json_config';

# Reads myapp.json by default and puts the parsed version into the stash
my $config = $self->stash('config');

# Everything can be customized with options
my $config = plugin json_config => {
  file      => '/etc/myapp.conf',
  stash_key => 'conf'
};

DESCRIPTION

Mojolicious::Plugin::JsonConfig is a JSON configuration plugin that preprocesses it's input with Mojo::Template. The application object can be accessed via $app or the app helper. You can extend the normal config file myapp.json with mode specific ones like myapp.$mode.json.

OPTIONS

Mojolicious::Plugin::JsonConfig accepts the same options as Mojolicious::Plugin::Config and the following new ones.

template

# Mojolicious::Lite
plugin json_config => {template => {line_start => '.'}};

Template options.

HELPERS

Mojolicious::Plugin::JsonConfig defines the same helpers as Mojolicious::Plugin::Config.

METHODS

Mojolicious::Plugin::JsonConfig inherits all methods from Mojolicious::Plugin::Config and implements the following new ones.

parse

$plugin->parse($content, $file, $conf, $app);

Process content with render and parse it with Mojo::JSON.

sub parse {
  my ($self, $content, $file, $conf, $app) = @_;
  ...
  $content = $self->render($content, $file, $conf, $app);
  ...
  return $hash;
}

register

$plugin->register;

Register plugin in Mojolicious application.

render

$plugin->render($content, $file, $conf, $app);

Process configuration file with Mojo::Template.

sub render {
  my ($self, $content, $file, $conf, $app) = @_;
  ...
  return $content;
}

SEE ALSO

Mojolicious, Mojolicious::Guides, http://mojolicio.us.