Group
Extension

WWW-Mechanize-Script/bin/wtscript2json.pl

#! perl

use strict;
use warnings;

# PODNAME: wtscript2json
# ABSTRACT: convert read configuration into JSON

use v5.10.1;

use File::Slurp qw(write_file);
use Getopt::Long;
use JSON ();
use List::MoreUtils qw(zip);
use Params::Util qw(_ARRAY);
use Pod::Usage;

use WWW::Mechanize::Script::Util qw(:ALL);
use WWW::Mechanize::Script;

our $VERSION = '0.100';
my %opts = (
             "input-files"    => [],
             "output-files"   => [],
             "output-pattern" => []
           );
my @options = (
                "input-files=s@"      => $opts{"input-files"},
                "output-files=s@"     => $opts{"output-files"},
                "output-pattern=s{2}" => $opts{"output-pattern"},
                "help|h", "usage|?"
              );

GetOptions( \%opts, @options ) or pod2usage(2);

# clean-up defaults
@{ $opts{"input-files"} }    or delete $opts{"input-files"};
@{ $opts{"output-files"} }   or delete $opts{"output-files"};
@{ $opts{"output-pattern"} } or delete $opts{"output-pattern"};

# check ...
defined( $opts{help} )
  and $opts{help}
  and pod2usage(
                 {
                   -verbose => 2,
                   -exitval => 0
                 }
               );
defined( $opts{usage} ) and $opts{usage} and pod2usage(1);
opt_required_all( \%opts, qw(input-files) );
opt_exclusive( \%opts, qw(output-files output-pattern) );
opt_required_one( \%opts, qw(output-files output-pattern) );

_ARRAY( $opts{"input-files"} )
  and $opts{"input-files"} = [ split( ",", join( ",", @{ $opts{"input-files"} } ) ) ];
_ARRAY( $opts{"output-files"} )
  and $opts{"output-files"} = [ split( ",", join( ",", @{ $opts{"output-files"} } ) ) ];

_ARRAY( $opts{"input-files"} )
  and _ARRAY( $opts{"output-files"} )
  and scalar( @{ $opts{"input-files"} } ) != scalar( @{ $opts{"output-files"} } )
  and pod2usage(
                 {
                   -message => "Count of --input-files and --output-files doesn't match",
                   -exitval => 1
                 }
               );

my %in2out =
    _ARRAY( $opts{"output-files"} )
  ? zip( @{ $opts{"input-files"} }, @{ $opts{"output-files"} } )
  : ();
my %cfg = load_config();

my $coder = JSON->new();
_ARRAY( $cfg{wtscript_extensions} )
  and Config::Any::WTScript->extensions( @{ $cfg{wtscript_extensions} } );
foreach my $filename ( @{ $opts{"input-files"} } )
{
    my @script_files = find_scripts( \%cfg, $filename );
    my $scripts = Config::Any->load_files(
                                           {
                                             files           => [@script_files],
                                             use_ext         => 1,
                                             flatten_to_hash => 1,
                                           }
                                         );
    if ( $opts{"output-files"} )
    {
        @script_files = keys %{$scripts};
        scalar(@script_files) > 1
          and pod2usage(
                   {
                     -message => "filename $filename is ambigious: " . join( ", ", @script_files ),
                     -exitval => 1
                   }
          );
        scalar(@script_files) < 1
          and next;    # file not found or not parsable ...
                       # merge into default and previous loaded config ...
        my $json = $coder->pretty->encode( $scripts->{ $script_files[0] } );
        write_file( $in2out{$filename}, $json );
    }
    else
    {
        while ( my ( $script_file, $script ) = each(%$scripts) )
        {
            my $json = $coder->pretty->encode($script);
            ( my $target = $script_file ) =~
              s/$opts{"output-pattern"}->[0]/$opts{"output-pattern"}->[1]/;
            write_file( $target, $json );
        }
    }
}

__END__

=pod

=head1 NAME

wtscript2json - convert read configuration into JSON

=head1 VERSION

version 0.101

=head1 SYNOPSIS

  # search in $config->{script_dirs} for any loadable script config
  $ wtscript2json --input-files service1/script1,service1/script2,service2/cool_script \
      --output-files /opt/new_checks/service1/script1.json \
      --output-files /opt/new_checks/service1/script2.json \
      --output-files /opt/new_checks/service2/cool_script.json

  # in-location conversion ...
  $ find . -name "*splunk*"
  ./check_web_config/log/test_splunk_1.txt
  ./check_web_config/log/test_splunk_2.txt
  ./check_web_config/log/test_splunk_3.txt
  ./check_web_config/log/test_splunk_4.txt
  $ wtscript2json --input-files log/test_splunk[1-4] --output-pattern .txt .json
  $ find . -name "*splunk*"
  $ find . -name "*splunk*"
  ./check_web_config/log/test_splunk_1.txt
  ./check_web_config/log/test_splunk_2.txt
  ./check_web_config/log/test_splunk_3.txt
  ./check_web_config/log/test_splunk_4.txt
  ./check_web_config/log/test_splunk_4.json
  ./check_web_config/log/test_splunk_3.json
  ./check_web_config/log/test_splunk_2.json
  ./check_web_config/log/test_splunk_1.json

=head1 DESCRIPTION

wtscript2json is a helper to convert WebTest Script files into a modern
format. Currently the format is hard-coded to JSON.

To avoid conflicts or duplicates running check_web(2), it's recommended to
use different C<script_dirs> in special configuration files for check_web(2)
and wtscript2json (check-web2.json vs. wtscript2json.json vs. check_web.json
as common configuration file for both). See
L<WWW::Mechanize::Script::Util/load_config> for further information.

=head1 BUGS

Please report any bugs or feature requests on the bugtracker website
http://rt.cpan.org/NoAuth/Bugs.html?Dist=WWW-Mechanize-Script or by email
to bug-www-mechanize-script@rt.cpan.org.

When submitting a bug or request, please include a test-file or a
patch to an existing test-file that illustrates the bug or desired
feature.

=head1 AUTHOR

Jens Rehsack <rehsack@cpan.org>

=head1 COPYRIGHT AND LICENSE

This software is copyright (c) 2014 by Jens Rehsack.

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


Powered by Groonga
Maintained by Kenichi Ishigaki <ishigaki@cpan.org>. If you find anything, submit it on GitHub.