use strict; use warnings; package SVN::Hooks::AllowPropChange; { $SVN::Hooks::AllowPropChange::VERSION = '1.19'; } # ABSTRACT: Allow changes in revision properties. use Carp; use Data::Util qw(:check); use SVN::Hooks; use Exporter qw/import/; my $HOOK = 'ALLOW_PROP_CHANGE'; our @EXPORT = ($HOOK); my @Specs; sub ALLOW_PROP_CHANGE { my @args = @_; my @whos; foreach my $arg (@args) { if (is_string($arg) || is_rx($arg)) { push @whos, $arg; } else { croak "$HOOK: invalid argument '$arg'\n"; } } @whos != 0 or croak "$HOOK: you must specify at least the first argument\n"; my $prop = shift @whos; push @Specs, [$prop => \@whos]; PRE_REVPROP_CHANGE(\&pre_revprop_change); return 1; } sub pre_revprop_change { my ($svnlook, $rev, $author, $propname, $action) = @_; $propname =~ /^svn:(?:author|date|log)$/ or croak "$HOOK: the revision property $propname cannot be changed.\n"; $action eq 'M' or croak "$HOOK: revision properties can only be modified, not added or deleted.\n"; foreach my $spec (@Specs) { my ($prop, $whos) = @$spec; if (is_string($prop)) { next if $propname ne $prop; } else { next if $propname !~ $prop; } for my $who (@$whos) { if (is_string($who)) { return if $author eq $who; } else { return if $author =~ $who; } } } croak "$HOOK: you are not allowed to change property $propname.\n"; } 1; # End of SVN::Hooks::AllowPropChange __END__ =pod =head1 NAME SVN::Hooks::AllowPropChange - Allow changes in revision properties. =head1 VERSION version 1.19 =head1 SYNOPSIS This SVN::Hooks plugin is used to allow revision (or non-versioned) properties (C, C, and C) to be changed by a group of users. It's active in the C hook. It's configured by the following directive. =head2 ALLOW_PROP_CHANGE(PROP => WHO, ...) This directive enables the change of revision properties. By default any change is denied unless explicitly allowed by the directive. You can use the directive more than once. The PROP argument specifies the propertie(s) that are to be configured depending on its type. If no argument is given, no user can change any property. =over =item STRING Specify a single property by name (C, C, or C). =item REGEXP Specify all properties that match the Regexp. =back The optional WHO arguments specify the users that are allowed to make those changes. If absent, no user can change a log message. Otherwise, it specifies the allowed users depending on its type. =over =item STRING Specify a single user by name. =item REGEXP Specify the class of users whose names are matched by the Regexp. =back ALLOW_PROP_CHANGE('svn:log' => 'jsilva'); # jsilva can change svn:log ALLOW_PROP_CHANGE(qr/./ => qr/silva$/); # any *silva can change any property =for Pod::Coverage pre_revprop_change =head1 AUTHOR Gustavo L. de M. Chaves =head1 COPYRIGHT AND LICENSE This software is copyright (c) 2012 by CPqD. 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