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 a HMAC session secret by default. These predictable default secrets can be exploited 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

Mojo::IOWatcher - Async IO Watcher

SYNOPSIS

use Mojo::IOWatcher;

# Watch if io handles become readable or writable
my $watcher = Mojo::IOWatcher->new;
$watcher->add($handle, on_readable => sub {
  my ($watcher, $handle) = @_;
  ...
});

# Use timers
$watcher->timer(15 => sub {
  my $watcher = shift;
  $watcher->remove($handle);
  print "Timeout!\n";
});

# And loop!
$watcher->one_tick('0.25') while 1;

DESCRIPTION

Mojo::IOWatcher is a minimalistic async io watcher and the foundation of Mojo::IOLoop. Mojo::IOWatcher::KQueue and Mojo::IOWatcher::Epoll are good examples for its extensibility. Note that this module is EXPERIMENTAL and might change without warning!

METHODS

Mojo::IOWatcher inherits all methods from Mojo::Base and implements the following new ones.

add

$watcher = $watcher->add($handle, on_readable => sub {...});

Add handles and watch for io events.

These options are currently available:

on_readable

Callback to be invoked once the handle becomes readable.

on_writable

Callback to be invoked once the handle becomes writable.

cancel

my $success = $watcher->cancel($id);

Cancel timer.

is_readable

my $readable = $watcher->is_readable($handle);

Quick check if a handle is readable, useful for identifying tainted sockets.

not_writing

$watcher = $watcher->not_writing($handle);

Only watch handle for readable events.

one_tick

$watcher->one_tick('0.25');

Run for exactly one tick and watch for io and timer events.

recurring

my $id = $watcher->recurring(3 => sub {...});

Create a new recurring timer, invoking the callback repeatedly after a given amount of seconds.

remove

$watcher = $watcher->remove($handle);

Remove handle.

timer

my $id = $watcher->timer(3 => sub {...});

Create a new timer, invoking the callback after a given amount of seconds.

watch

$watcher->watch('0.25');

Run for exactly one tick and watch only for io events.

writing

$watcher = $watcher->writing($handle);

Watch handle for readable and writable events.

DEBUGGING

You can set the MOJO_IOWATCHER_DEBUG environment variable to get some advanced diagnostics information printed to STDERR.

MOJO_IOWATCHER_DEBUG=1

SEE ALSO

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