Image-Magick-Safer

 view release on metacpan or  search on metacpan

t/005_safer.t  view on Meta::CPAN

#!perl

# mocking Image::Magick dependency here for testing as it may not be installed
# and it's an absolute swine to install so that's not going to work on
# cpantesters et al
BEGIN {
    $INC{'Image/Magick.pm'} ||= "mocked";
};

package Image::Magick;

sub new { bless( {},shift ); };

1;

use strict;
use warnings;

use Test::More;
use FindBin qw/ $Bin /;
use File::Spec::Functions qw/ catdir /;
use File::Basename;
use Config;

use Image::Magick::Safer;

if (
	$^O =~ /BSD/i
	&& $Config{osvers} =~ /(10\.1|7\.0\.1)/
) {
	plan skip_all => "Issues with BSD $1, see GH #2";
}

my $magick = Image::Magick::Safer->new;

# Image::Magick::Read could fail for other reasons, so we monkey patch it here
# to make sure it returns "success" (which in Image::Magick terms is void)
no warnings 'redefine';
no warnings 'once';
*Image::Magick::Read = sub ($;@) {};

# add SVG check to the defaults
$Image::Magick::Safer::Unsafe->{'image/svg+xml'} = 1;

note( "magic byte check" );

foreach my $file ( glob catdir( $Bin,"exploit","*" ) ) {

	foreach my $method ( qw/ Read ReadImage read readimage / ) {
		my $e = $magick->$method( $file );
		like(
			$e,
			qr/potentially unsafe|unable to establish/,
			"$method exception with exploitable @{[ basename $file ]}"
		);
	}
}

foreach my $file ( glob catdir( $Bin,"genuine","*" ) ) {

	foreach my $method ( qw/ Read ReadImage read readimage / ) {
		ok(
			! $magick->$method( $file ),
			"No $method exception with safe @{[ basename $file ]}"
		);
	}
}

note( "disallow leading pipe" );

foreach my $file (
	'|echo Hello > hello.txt;',
	' |echo Hello > hello.txt;',
	'  |echo Hello > hello.txt;',
	'	|echo Hello > hello.txt;',
	'i do not exist',
) {

	foreach my $method ( qw/ Read ReadImage read readimage / ) {
		my $e = eval { $magick->$method( $file ) };
		$e = $@ if ! $e;
		like(
			$e,
			qr/cannot open/,
			"$method exception with exploitable @{[ basename $file ]}"
		);
	}
}

done_testing();



( run in 0.922 second using v1.01-cache-2.11-cpan-5a3173703d6 )