App-URIUtils
view release on metacpan or search on metacpan
lib/App/URIUtils.pm view on Meta::CPAN
package App::URIUtils;
our $AUTHORITY = 'cpan:PERLANCAR'; # AUTHORITY
our $DATE = '2021-06-30'; # DATE
our $DIST = 'App-URIUtils'; # DIST
our $VERSION = '0.003'; # VERSION
use 5.010001;
use strict;
use warnings;
our %SPEC;
$SPEC{':package'} = {
v => 1.1,
summary => 'Utilities related to URI/URL',
};
$SPEC{parse_url} = {
v => 1.1,
summary => 'Parse URL string into a hash of information',
args => {
url => {schema => 'str*', req=>1, pos=>0},
base => {schema => 'str*', pos=>1},
parse_type => {
schema => ['str*', in=>['url', 'query-params']],
default => 'url',
cmdline_aliases => {
t=>{},
p=>{is_flag=>1, summary=>'Shortcut for --parse-type=query-params', code=>sub { $_[0]{parse_type} = 'query-params' }},
},
},
},
result_naked => 1,
examples => [
{
args=>{url=>'https://www.tokopedia.com/search?st=product&q=soundmagic%20e10'},
},
{
summary => 'Just parse the query parameters into hash',
argv=>['-p', 'https://www.tokopedia.com/search?st=product&q=soundmagic%20e10'],
},
],
};
sub parse_url {
require URI::URL;
require URI::QueryParam;
my %args = @_;
my $url = URI::URL->new($args{url}, $args{base});
if ($args{parse_type} eq 'url') {
return +{
orig => $args{url},
base => $args{base},
scheme => $url->scheme,
has_recognized_scheme => $url->has_recognized_scheme,
opaque => $url->opaque,
path => $url->path, # unescaped string
fragment => $url->fragment,
canonical => $url->canonical . "",
authority => $url->authority,
query => $url->query, # escaped
# server/host methods
host => $url->host,
port => $url->port,
default_port => $url->default_port,
#abs_path => $url->abs_path,
full_path => $url->full_path, # abs_path || "/"
};
} elsif ($args{parse_type} eq 'query-params') {
return $url->query_form_hash;
} else {
die "Unknown parse type: $args{parse_type}";
}
}
1;
# ABSTRACT: Utilities related to URI/URL
__END__
=pod
=encoding UTF-8
=head1 NAME
App::URIUtils - Utilities related to URI/URL
=head1 VERSION
This document describes version 0.003 of App::URIUtils (from Perl distribution App-URIUtils), released on 2021-06-30.
=head1 DESCRIPTION
This distributions provides the following command-line utilities:
=over
=item * L<parse-url>
=back
=head1 FUNCTIONS
=head2 parse_url
Usage:
parse_url(%args) -> any
Parse URL string into a hash of information.
Examples:
=over
=item * Example #1:
( run in 2.610 seconds using v1.01-cache-2.11-cpan-2398b32b56e )