Parse-Services

 view release on metacpan or  search on metacpan

lib/Parse/Services.pm  view on Meta::CPAN

package Parse::Services;

our $DATE = '2019-11-19'; # DATE
our $VERSION = '0.002'; # VERSION

use 5.010001;
use strict;
use warnings;

use Exporter qw(import);
our @EXPORT_OK = qw(parse_services);

our %SPEC;

$SPEC{parse_services} = {
    v => 1.1,
    summary => 'Parse /etc/services',
    args => {
        content => {
            summary => 'Content of /etc/services file',
            description => <<'_',

Optional. Will attempt to read `/etc/services` from filesystem if not specified.

_
            schema => 'str*',
        },
    },
    examples => [
    ],
};
sub parse_services {
    my %args = @_;

    my $content = $args{content};
    unless (defined $content) {
        open my($fh), "<", "/etc/services"
            or return [500, "Can't read /etc/services: $!"];
        local $/;
        $content = <$fh>;
    }

    my @res;
    for my $line (split /^/, $content) {
        $line =~ s/#.*//;
        next unless $line =~ /\S/;
        chomp $line;
        my ($name, $port_proto, @aliases) = split /\s+/, $line;
        my ($port, $proto) = split m!/!, $port_proto;
        push @res, {
            name  => $name,
            port  => $port,
            proto => $proto,
            aliases => \@aliases,
        };
    }
    [200, "OK", \@res];
}

1;
# ABSTRACT: Parse /etc/services

__END__

=pod

=encoding UTF-8

=head1 NAME

Parse::Services - Parse /etc/services

=head1 VERSION

This document describes version 0.002 of Parse::Services (from Perl distribution Parse-Services), released on 2019-11-19.

=head1 SYNOPSIS

 use Parse::Services qw(parse_services);
 my $res = parse_services();

=head1 FUNCTIONS


=head2 parse_services

Usage:

 parse_services(%args) -> [status, msg, payload, meta]

Parse /etc/services.

This function is not exported by default, but exportable.

Arguments ('*' denotes required arguments):

=over 4

=item * B<content> => I<str>

Content of /etc/services file.

Optional. Will attempt to read C</etc/services> from filesystem if not specified.

=back

Returns an enveloped result (an array).

First element (status) is an integer containing HTTP status code



( run in 2.651 seconds using v1.01-cache-2.11-cpan-71847e10f99 )