my $res;
+ # test regex for validity
+ eval { "" =~ m|$self->{field_value}|; };
+ if (my $err = $@) {
+ warn "invalid regex: $err\n";
+ return $res;
+ }
# match subtypes? We currently do exact matches only.
if (my $id = $entity->head->mime_attr ('x-proxmox-tmp-aid')) {
my $res;
+ # test regex for validity
+ eval { "" =~ m|$self->{field_value}|; };
+ if (my $err = $@) {
+ warn "invalid regex: $err\n";
+ return $res;
+ }
+
# match subtypes? We currently do exact matches only.
if (my $id = $entity->head->mime_attr ('x-proxmox-tmp-aid')) {
my $res;
+ # test regex for validity
+ eval { "" =~ m|^$self->{fname}$|i; };
+ if (my $err = $@) {
+ warn "invalid regex: $err\n";
+ return $res;
+ }
+
if (my $id = $entity->head->mime_attr('x-proxmox-tmp-aid')) {
chomp $id;
my $regex = $self->{field_value};
- # test regex for validity
- eval { "" =~ /$regex/i; };
- die "invalid regex: $@\n" if $@;
+ PMG::Utils::test_regex($regex);
my $new_value = "$self->{field}:$regex";
$new_value =~ s/\\/\\\\/g;
defined($self->{ogroup}) || die "undefined ogroup: ERROR";
my $new_value = $self->{fname};
+
+ PMG::Utils::test_regex("^${new_value}\$");
+
$new_value =~ s/\\/\\\\/g;
$new_value = encode('UTF-8', $new_value);
chomp $id;
if (my $value = PMG::Utils::extract_filename($entity->head)) {
- if ($value =~ m|^$self->{fname}$|i) {
- push @$res, $id;
- }
+ eval {
+ if ($value =~ m|^$self->{fname}$|i) {
+ push @$res, $id;
+ }
+ };
+ warn "invalid regex: $@\n" if $@;
}
}
defined($self->{address}) || die "undefined address: ERROR";
my $adr = $self->{address};
+
+ PMG::Utils::test_regex("^${adr}\$");
+
$adr =~ s/\\/\\\\/g;
$adr = encode('UTF-8', $adr);
my $t = $self->address;
- return $addr =~ m/^$t$/i;
+ my $res;
+ eval {
+ $res = $addr =~ m/^$t$/i;
+ };
+ warn "invalid regex: $@\n" if $@;
+ return $res;
}
sub address {
return eval { decode('UTF-8', $data, 1) } // $data;
}
+sub test_regex {
+ my ($regex) = @_;
+
+ # some errors in regex only create warnings e.g. m/^*foo/ others actually cause a
+ # die e.g. m/*foo/ - treat a warn die here
+ local $SIG{__WARN__} = sub { die @_ };
+ eval { "" =~ m/$regex/i; };
+ die "invalid regex: $@\n" if $@;
+
+ return undef;
+}
+
1;