copy current state of medienstaatsvertrag.org, to be verified
This commit is contained in:
486
website/agenda/planung/users.cgi
Executable file
486
website/agenda/planung/users.cgi
Executable file
@@ -0,0 +1,486 @@
|
||||
#! /usr/bin/perl -w
|
||||
|
||||
use warnings "all";
|
||||
use strict;
|
||||
use Data::Dumper;
|
||||
|
||||
use config;
|
||||
use log;
|
||||
use template;
|
||||
use auth;
|
||||
use uac;
|
||||
use roles;
|
||||
use studios;
|
||||
use params;
|
||||
use localization;
|
||||
|
||||
my $r=shift;
|
||||
(my $cgi, my $params, my $error)=params::get($r);
|
||||
|
||||
my $config =config::get('../config/config.cgi');
|
||||
my $debug =$config->{system}->{debug};
|
||||
my ($user,$expires) = auth::get_user($cgi, $config);
|
||||
return if ((!defined $user) || ($user eq ''));
|
||||
|
||||
my $user_presets=uac::get_user_presets($config, {
|
||||
user => $user,
|
||||
project_id => $params->{project_id},
|
||||
studio_id => $params->{studio_id}
|
||||
});
|
||||
$params->{default_studio_id} = $user_presets->{studio_id};
|
||||
$params->{studio_id} = $params->{default_studio_id} if ((!(defined $params->{action}))||($params->{action}eq'')||($params->{action}eq'login'));
|
||||
$params->{project_id} = $user_presets->{project_id} if ((!(defined $params->{action}))||($params->{action}eq'')||($params->{action}eq'login'));
|
||||
|
||||
my $request={
|
||||
url => $ENV{QUERY_STRING}||'',
|
||||
params => {
|
||||
original => $params,
|
||||
checked => check_params($params),
|
||||
},
|
||||
};
|
||||
$request = uac::prepare_request($request, $user_presets);
|
||||
log::init($request);
|
||||
|
||||
$params=$request->{params}->{checked};
|
||||
|
||||
#process header
|
||||
my $headerParams=uac::set_template_permissions($request->{permissions}, $params);
|
||||
$headerParams->{loc} = localization::get($config, {user=>$user, file=>'menu'});
|
||||
template::process('print', template::check('default.html'), $headerParams);
|
||||
return unless uac::check($config, $params, $user_presets)==1;
|
||||
|
||||
our $errors=[];
|
||||
|
||||
if (defined $params->{action}){
|
||||
update_user_roles($config, $request) if ($params->{action}eq 'assign');
|
||||
update_user($config,$request) if ($params->{action}eq 'save');
|
||||
delete_user($config,$request) if ($params->{action}eq 'delete');
|
||||
if ($params->{action}eq 'change_password'){
|
||||
change_password($config, $request, $user);
|
||||
$config->{access}->{write}=0;
|
||||
return;
|
||||
}
|
||||
}
|
||||
$config->{access}->{write}=0;
|
||||
show_users($config,$request);
|
||||
|
||||
sub show_users{
|
||||
my $config=shift;
|
||||
my $request=shift;
|
||||
|
||||
my $params=$request->{params}->{checked};
|
||||
|
||||
my $permissions=$request->{permissions};
|
||||
|
||||
unless ((defined $permissions->{read_user}) && ($permissions->{read_user}==1)){
|
||||
uac::permissions_denied('read_user');
|
||||
return;
|
||||
}
|
||||
|
||||
my $max_level = $permissions->{level};
|
||||
my $project_id = $params->{project_id};
|
||||
my $studio_id = $params->{studio_id};
|
||||
#TODO: get from presets
|
||||
my $studios = studios::get($config, {project_id=>$project_id});
|
||||
my $users = uac::get_users($config);
|
||||
my $roles = uac::get_roles(
|
||||
$config, {
|
||||
project_id => $project_id,
|
||||
studio_id => $studio_id
|
||||
}
|
||||
);
|
||||
|
||||
# print "max level:$max_level<br>";
|
||||
|
||||
#user roles
|
||||
for my $user (@$users){
|
||||
$user->{disabled_checked}='selected="selected"' if ($user->{disabled}eq'1');
|
||||
#print Dumper($user);
|
||||
my $user_roles=uac::get_user_roles(
|
||||
$config, {
|
||||
user => $user->{name},
|
||||
project_id => $project_id,
|
||||
studio_id => $studio_id
|
||||
}
|
||||
);
|
||||
my @user_roles=(map { {role => $_->{role}} } @$user_roles);
|
||||
#print Dumper(\@user_roles);
|
||||
#@user_roles[-1]->{__last__}=1 unless(@user_roles==0);
|
||||
$user->{user_roles}=\@user_roles;
|
||||
|
||||
#mark all roles assigned to user
|
||||
my $has_roles=0;
|
||||
my @assignable_roles=();
|
||||
for my $role (reverse sort {$a->{level} <=> $b->{level}} @$roles){
|
||||
#next if ($role->{level}>$max_level);
|
||||
$role->{assigned}=0;
|
||||
my %role=%$role;
|
||||
for my $user_role (@user_roles){
|
||||
if ($role->{role} eq $user_role->{role}){
|
||||
$role{assigned}=1;
|
||||
# print "if ($role->{role} eq $user_role->{role}<br>";
|
||||
$has_roles=1;
|
||||
last;
|
||||
}
|
||||
}
|
||||
push @assignable_roles,\%role;
|
||||
}
|
||||
$user->{has_roles} = $has_roles;
|
||||
$user->{roles} = \@assignable_roles;
|
||||
$user->{studio_id} = $studio_id;
|
||||
$user->{project_id} = $project_id;
|
||||
uac::set_template_permissions($permissions,$user);
|
||||
}
|
||||
|
||||
my $sort_by='name';
|
||||
my @users=sort {lc($a->{$sort_by}) cmp lc($b->{$sort_by})} @$users;
|
||||
|
||||
my @users_with_roles=();
|
||||
my @users_without_roles=();
|
||||
for my $user (@users){
|
||||
if ($user->{has_roles}==1){
|
||||
push @users_with_roles,$user;
|
||||
}else{
|
||||
push @users_without_roles,$user;
|
||||
}
|
||||
}
|
||||
|
||||
if($permissions->{update_user_role}==1){
|
||||
@users=(@users_with_roles,@users_without_roles);
|
||||
}else{
|
||||
@users=(@users_with_roles);
|
||||
}
|
||||
|
||||
|
||||
$params->{users} = \@users;
|
||||
$params->{studios} = $studios;
|
||||
$params->{permissions} = $permissions;
|
||||
$params->{errors} = $errors;
|
||||
$params->{loc} = localization::get($config, {user=>$params->{presets}->{user}, file=>'users'});
|
||||
uac::set_template_permissions($permissions, $params);
|
||||
#print Dumper($permissions);
|
||||
template::process('print', $params->{template}, $params);
|
||||
# template::process('print', template::check('users'), $params);
|
||||
|
||||
}
|
||||
|
||||
sub update_user{
|
||||
my $config=shift;
|
||||
my $request=shift;
|
||||
|
||||
my $params=$request->{params}->{checked};
|
||||
my $permissions=$request->{permissions};
|
||||
|
||||
my $user={
|
||||
full_name => $params->{user_full_name},
|
||||
email => $params->{user_email},
|
||||
id => $params->{user_id}
|
||||
};
|
||||
$user->{name}= $params->{user_name} if ( (defined $params->{user_name}) && ($params->{user_name} ne '') );
|
||||
|
||||
if ($permissions->{disable_user}==1){
|
||||
$user->{disabled}= $params->{disabled}||0;
|
||||
}
|
||||
|
||||
if ( (!defined $user->{id}) || ($user->{id}eq'') ){
|
||||
unless ($permissions->{create_user}==1){
|
||||
uac::permissions_denied('create_user');
|
||||
return;
|
||||
}
|
||||
|
||||
return unless(check_password($params->{user_password}));
|
||||
|
||||
if ($params->{user_password} ne $params->{user_password2}){
|
||||
error('password mismatch');
|
||||
return;
|
||||
}
|
||||
my $crypt=auth::crypt_password($params->{user_password});
|
||||
$user->{salt} = $crypt->{salt};
|
||||
$user->{pass} = $crypt->{crypt};
|
||||
#print '<pre>'.Dumper($user).'</pre>';
|
||||
$user->{created_at} = time::time_to_datetime(time());
|
||||
$user->{modified_at} = time::time_to_datetime(time());
|
||||
$user->{created_by} = $params->{presets}->{user};
|
||||
|
||||
$config->{access}->{write}=1;
|
||||
uac::insert_user($config, $user);
|
||||
}else{
|
||||
unless ($permissions->{update_user}==1){
|
||||
uac::permissions_denied('update_user');
|
||||
return;
|
||||
}
|
||||
$user->{modified_at} = time::time_to_datetime(time());
|
||||
$config->{access}->{write}=1;
|
||||
uac::update_user($config, $user);
|
||||
}
|
||||
}
|
||||
|
||||
sub change_password{
|
||||
my $config=shift;
|
||||
my $request=shift;
|
||||
my $userName=shift;
|
||||
|
||||
my $params=$request->{params}->{checked};
|
||||
my $permissions=$request->{permissions};
|
||||
|
||||
unless ( (defined $userName) || ($userName eq '') ){
|
||||
uac::print_error('user not found');
|
||||
return;
|
||||
}
|
||||
|
||||
my $user=uac::get_user($config, $userName);
|
||||
|
||||
unless ( (defined $user) && (defined $user->{id}) && ($user->{id}ne'') ){
|
||||
uac::print_error('user id not found');
|
||||
return;
|
||||
}
|
||||
|
||||
unless(check_password($params->{user_password})){
|
||||
error('password does not meet requirements');
|
||||
}
|
||||
|
||||
if ($params->{user_password} ne $params->{user_password2}){
|
||||
error('entered passwords do not match');
|
||||
}
|
||||
|
||||
print STDERR "error at changing password:".Dumper($errors);
|
||||
|
||||
if(@$errors==0){
|
||||
my $crypt=auth::crypt_password($params->{user_password});
|
||||
$user={
|
||||
id => $user->{id}
|
||||
};
|
||||
$user->{salt}=$crypt->{salt};
|
||||
$user->{pass}=$crypt->{crypt};
|
||||
#print '<pre>'.Dumper($user).'</pre>';
|
||||
$config->{access}->{write}=1;
|
||||
uac::update_user($config, $user);
|
||||
$config->{access}->{write}=0;
|
||||
print STDERR "password changed for $params->{presets}->{user}\n";
|
||||
}
|
||||
$params->{errors}= $errors; #join("<br>", (map {$_>{error}} (@$errors)) );
|
||||
$params->{loc} = localization::get($config, {user=>$params->{presets}->{user}, file=>'users'});
|
||||
uac::set_template_permissions($permissions, $params);
|
||||
#print Dumper($permissions);
|
||||
template::process('print', template::check('change_password'), $params);
|
||||
}
|
||||
|
||||
sub check_password{
|
||||
my $password=shift;
|
||||
unless(defined $password || $password eq ''){
|
||||
error("password is empty");
|
||||
return;
|
||||
}
|
||||
if(length($password)<8){
|
||||
error("password to short");
|
||||
return 0;
|
||||
}
|
||||
unless($password=~/[a-z]/){
|
||||
error("password should contains at least one small character");
|
||||
return 0;
|
||||
}
|
||||
unless($password=~/[A-Z]/){
|
||||
error("password should contains at least one big character");
|
||||
return 0;
|
||||
}
|
||||
unless($password=~/[0-9]/){
|
||||
error("password should contains at least one number");
|
||||
return 0;
|
||||
}
|
||||
unless($password=~/[^a-zA-Z0-9]/){
|
||||
error("password should contains at least one special character");
|
||||
return 0;
|
||||
}
|
||||
return 1;
|
||||
}
|
||||
|
||||
sub delete_user{
|
||||
my $config=shift;
|
||||
my $request=shift;
|
||||
|
||||
my $permissions=$request->{permissions};
|
||||
unless ($permissions->{delete_user}==1){
|
||||
uac::permissions_denied('delete_user');
|
||||
return;
|
||||
}
|
||||
|
||||
$config->{access}->{write}=1;
|
||||
my $params=$request->{params}->{checked};
|
||||
uac::delete_user($config,$params->{user_id});
|
||||
}
|
||||
|
||||
# add or remove user from role for given studio_id
|
||||
# todo: assign/unassign role oly if max(change user rank) is < max(users rank)
|
||||
sub update_user_roles{
|
||||
my $config=shift;
|
||||
my $request=shift;
|
||||
|
||||
# print Dumper($params).'<br>';
|
||||
# print Dumper($request->{params}->{checked});
|
||||
|
||||
my $permissions=$request->{permissions};
|
||||
unless ($permissions->{update_user_role}==1){
|
||||
uac::permissions_denied('update_user_role');
|
||||
return;
|
||||
}
|
||||
my $params = $request->{params}->{checked};
|
||||
my $project_id = $params->{project_id};
|
||||
my $studio_id = $params->{studio_id};
|
||||
my $user_id = $params->{user_id}||'';
|
||||
# return undef if ($user_id eq '');
|
||||
|
||||
#get all roles
|
||||
my $roles = uac::get_roles(
|
||||
$config, {
|
||||
project_id => $project_id,
|
||||
studio_id => $studio_id
|
||||
}
|
||||
);
|
||||
#get roles for the selected user
|
||||
my $user_roles = uac::get_user_roles(
|
||||
$config, {
|
||||
project_id => $project_id,
|
||||
studio_id => $studio_id,
|
||||
user_id => $user_id
|
||||
}
|
||||
);
|
||||
|
||||
#maximum level of the user who wants to perform the update (given by $permissions)
|
||||
my $max_level = $permissions->{level};
|
||||
|
||||
#maximum level of the user to be changed (given by $user_id)
|
||||
my $max_user_level=0;
|
||||
|
||||
#get all roles by id
|
||||
my $role_by_id={};
|
||||
for my $role (@$roles){
|
||||
$role_by_id->{$role->{id}}=$role;
|
||||
}
|
||||
|
||||
#get user role by id
|
||||
my $user_role_by_id={};
|
||||
for my $role (@$user_roles){
|
||||
$user_role_by_id->{$role->{id}}=$role;
|
||||
$max_user_level=$role->{level} if $max_user_level<$role->{level};
|
||||
}
|
||||
|
||||
$config->{access}->{write}=1;
|
||||
#remove unchecked user roles
|
||||
for my $user_role_id (keys %$user_role_by_id){
|
||||
my $user_role = $user_role_by_id->{$user_role_id};
|
||||
my $role = $role_by_id->{$user_role_id};
|
||||
# print "$user_role_id - $params->{role_ids}->{$user_role_id} ($studio_id)<br>";
|
||||
unless (defined $params->{role_ids}->{$user_role_id}){
|
||||
my $message="remove role '$role->{role}' (level $role->{level}) from user $user_id (level $max_user_level) for studio_id=$studio_id, project_id=$project_id. Your level is $max_level";
|
||||
my $update=0;
|
||||
$update = 1 if (defined $permissions->{is_admin});
|
||||
$update = 1 if (
|
||||
($role_by_id->{$user_role->{role_id}}->{level}<$max_level)
|
||||
&& ($max_user_level<$max_level)
|
||||
);
|
||||
if($update==0){
|
||||
uac::permissions_denied($message);
|
||||
next;
|
||||
}
|
||||
my $result=uac::remove_user_role(
|
||||
$config, {
|
||||
project_id => $project_id,
|
||||
studio_id => $studio_id,
|
||||
user_id => $user_id,
|
||||
role_id => $user_role_id
|
||||
}
|
||||
);
|
||||
unless(defined $result){
|
||||
uac::print_error("missing parameter on remove user role");
|
||||
return;
|
||||
}
|
||||
if ($result==0){
|
||||
uac::print_error("no changes");
|
||||
return;
|
||||
}
|
||||
uac::print_info($message);
|
||||
}
|
||||
}
|
||||
|
||||
#insert/update user roles
|
||||
for my $role_id (keys %{$params->{role_ids}}){
|
||||
my $role=$role_by_id->{$role_id};
|
||||
unless(defined $user_role_by_id->{$role_id}){
|
||||
my $message="assign role $role->{role} (level $role->{level}) to user (level $max_user_level). Your level is $max_level";
|
||||
# print "user role id: $role->{id}<br>\n";
|
||||
my $update=0;
|
||||
$update = 1 if (defined $permissions->{is_admin});
|
||||
$update = 1 if (
|
||||
($role_by_id->{$role->{id}}->{level}<$max_level)
|
||||
&& ($max_user_level<$max_level)
|
||||
);
|
||||
if ($update == 0){
|
||||
uac::permissions_denied($message);
|
||||
next;
|
||||
}
|
||||
uac::assign_user_role(
|
||||
$config, {
|
||||
project_id => $project_id,
|
||||
studio_id => $studio_id,
|
||||
user_id => $user_id,
|
||||
role_id => $role_id
|
||||
}
|
||||
);
|
||||
uac::print_info($message);
|
||||
}
|
||||
}
|
||||
$config->{access}->{write}=0;
|
||||
}
|
||||
|
||||
sub check_params{
|
||||
my $params=shift;
|
||||
|
||||
my $checked={};
|
||||
|
||||
#template
|
||||
my $template='';
|
||||
$template=template::check($params->{template},'users');
|
||||
$checked->{template}=$template;
|
||||
|
||||
#numeric values
|
||||
for my $param ('project_id', 'user_id', 'default_studio_id', 'studio_id', 'disabled'){
|
||||
if ((defined $params->{$param})&&($params->{$param}=~/^\d+$/)){
|
||||
$checked->{$param}=$params->{$param};
|
||||
}
|
||||
}
|
||||
if (defined $checked->{studio_id}){
|
||||
$checked->{default_studio_id}=$checked->{studio_id};
|
||||
}else{
|
||||
$checked->{studio_id}=-1;
|
||||
}
|
||||
|
||||
|
||||
for my $param ('user_name', 'user_full_name', 'user_email', 'user_password', 'user_password2'){
|
||||
if (defined $params->{$param}){
|
||||
$checked->{$param}=$params->{$param};
|
||||
}
|
||||
}
|
||||
|
||||
#actions and roles
|
||||
if (defined $params->{action}){
|
||||
if ($params->{action}=~/^(save|assign|delete|change_password)$/){
|
||||
$checked->{action}=$params->{action};
|
||||
}
|
||||
|
||||
if ($params->{action} eq 'assign'){
|
||||
$checked->{action}=$params->{action};
|
||||
for my $param (keys %$params){
|
||||
$checked->{role_ids}->{$1}=1 if ($param=~/^role_(\d+)$/);
|
||||
}
|
||||
}
|
||||
}
|
||||
#print Dumper($params);
|
||||
#print '<pre>'.Dumper($checked).'</pre>';
|
||||
return $checked;
|
||||
}
|
||||
|
||||
sub error{
|
||||
push @$errors,{error=>$_[0]};
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user