1 contributor
package Mojo::Cookie::Request;
use Mojo::Base 'Mojo::Cookie';
use Mojo::Util 'quote';
sub parse {
my ($self, $string) = @_;
my @cookies;
for my $token (map {@$_} $self->_tokenize($string)) {
my ($name, $value) = @$token;
next if $name =~ /^\$/;
push @cookies,
Mojo::Cookie::Request->new(name => $name, value => defined $value ? $value : '');
}
return \@cookies;
}
sub to_string {
my $self = shift;
return '' unless my $name = $self->name;
my $value = defined $self->value ? $self->value : '';
$value = $value =~ /[,;"]/ ? quote($value) : $value;
return "$name=$value";
}
1;
=head1 NAME
Mojo::Cookie::Request - HTTP request cookie
=head1 SYNOPSIS
use Mojo::Cookie::Request;
my $cookie = Mojo::Cookie::Request->new;
$cookie->name('foo');
$cookie->value('bar');
say "$cookie";
=head1 DESCRIPTION
L<Mojo::Cookie::Request> is a container for HTTP request cookies.
=head1 ATTRIBUTES
L<Mojo::Cookie::Request> inherits all attributes from L<Mojo::Cookie>.
=head1 METHODS
L<Mojo::Cookie::Request> inherits all methods from L<Mojo::Cookie> and
implements the following new ones.
=head2 parse
my $cookies = $cookie->parse('f=b; g=a');
Parse cookies.
=head2 to_string
my $string = $cookie->to_string;
Render cookie.
=head1 SEE ALSO
L<Mojolicious>, L<Mojolicious::Guides>, L<http://mojolicio.us>.
=cut