use 5.008;
use strict;
use warnings;
package Data::Semantic::URI::ftp;
our $VERSION = '1.100850';
# ABSTRACT: Semantic data class for ftp URIs
use parent qw(Data::Semantic::URI);
__PACKAGE__
->mk_scalar_accessors(qw(type))
->mk_boolean_accessors(qw(password));
use constant REGEXP_KEYS => qw(URI FTP);
use constant KEEP_KEYS => qw(
URI scheme username password host port abspath_full abspath_full_no_slash
abspath_full_no_slash_no_query type
);
sub flags {
my $self = shift;
my @flags = $self->SUPER::flags(@_);
push @flags => sprintf("-type => '%s'", $self->type) if $self->type;
push @flags => '-password' if $self->password;
@flags;
}
1;
__END__
=pod
=head1 NAME
Data::Semantic::URI::ftp - Semantic data class for ftp URIs
=head1 VERSION
version 1.100850
=head1 SYNOPSIS
my $obj = Data::Semantic::URI::ftp->new;
if ($obj->is_valid('...')) {
# ...
}
=head1 DESCRIPTION
This class can tell whether a value is an FTP URI, as defined by RFCs 1738 and
2396. The C<valid()> method will respect the C<type> and C<password>
attributes and the inherited C<keep> boolean attribute.
See L<Regexp::Common::URI::ftp> for the meaning of C<type> and C<password>.
If C<keep> is set, C<kept()> will return a hash with the following keys/value
pairs:
=over 4
=item URI
The complete URI.
=item C<scheme>
The scheme.
=item C<username>
The userinfo, or if C<password> is used, the username.
=item C<password>
If C<password> is used, the password, else "undef".
=item C<host>
The hostname or IP address.
=item C<port>
The port number
=item C<abspath_full>
The full path and type specification, including the leading slash.
=item C<abspath_full_no_slash>
The full path and type specification, without the leading slash.
=item C<abspath_full_no_slash_no_query>
The full path, without the type specification nor the leading slash.
=item C<type>
The value of the type specification.
=back
=head1 INSTALLATION
See perlmodinstall for information and options on installing Perl modules.
=head1 BUGS AND LIMITATIONS
No bugs have been reported.
Please report any bugs or feature requests through the web interface at
L<http://rt.cpan.org/Public/Dist/Display.html?Name=Data-Semantic-URI>.
=head1 AVAILABILITY
The latest version of this module is available from the Comprehensive Perl
Archive Network (CPAN). Visit L<http://www.perl.com/CPAN/> to find a CPAN
site near you, or see
L<http://search.cpan.org/dist/Data-Semantic-URI/>.
The development version lives at
L<http://github.com/hanekomu/Data-Semantic-URI/>.
Instead of sending patches, please fork this project using the standard git
and github infrastructure.
=head1 AUTHOR
Marcel Gruenauer <marcel@cpan.org>
=head1 COPYRIGHT AND LICENSE
This software is copyright (c) 2007 by Marcel Gruenauer.
This is free software; you can redistribute it and/or modify it under
the same terms as the Perl 5 programming language system itself.
=cut