1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
|
package VNWeb::Staff::Edit;
use VNWeb::Prelude;
my $FORM = {
id => { required => 0, id => 1 },
aid => { int => 1, range => [ -1000, 1<<40 ] }, # X
alias => { maxlength => 100, sort_keys => 'aid', aoh => {
aid => { int => 1, range => [ -1000, 1<<40 ] }, # X, negative IDs are for new aliases
name => { maxlength => 200 },
original => { maxlength => 200, required => 0, default => '' },
inuse => { anybool => 1, _when => 'out' },
} },
desc => { required => 0, default => '', maxlength => 5000 },
gender => { required => 0, default => 'unknown', enum => [qw[unknown m f]] },
lang => { language => 1 },
l_site => { required => 0, default => '', weburl => 1 },
l_wikidata => { required => 0, id => 1 },
l_twitter => { required => 0, default => '', regex => qr/^\S+$/, maxlength => 16 },
l_anidb => { required => 0, id => 1, default => undef },
l_pixiv => { required => 0, id => 1, default => 0 },
hidden => { anybool => 1 },
locked => { anybool => 1 },
authmod => { _when => 'out', anybool => 1 },
editsum => { _when => 'in out', editsum => 1 },
};
my $FORM_OUT = form_compile out => $FORM;
my $FORM_IN = form_compile in => $FORM;
my $FORM_CMP = form_compile cmp => $FORM;
elm_form StaffEdit => $FORM_OUT, $FORM_IN;
TUWF::get qr{/$RE{srev}/edit} => sub {
my $e = db_entry s => tuwf->capture('id'), tuwf->capture('rev') or return tuwf->resNotFound;
return tuwf->resDenied if !can_edit s => $e;
$e->{authmod} = auth->permDbmod;
$e->{editsum} = $e->{chrev} == $e->{maxrev} ? '' : "Reverted to revision s$e->{id}.$e->{chrev}";
enrich_merge aid => sub {
'SELECT aid, EXISTS(SELECT 1 FROM vn_staff WHERE aid = x.aid UNION ALL SELECT 1 FROM vn_seiyuu WHERE aid = x.aid) AS inuse
FROM unnest(', sql_array(@$_), '::int[]) AS x(aid)'
}, $e->{alias};
my $name = (grep $_->{aid} == $e->{aid}, @{$e->{alias}})[0]{name};
framework_ title => "Edit $name", type => 's', dbobj => $e, tab => 'edit',
sub {
editmsg_ s => $e, "Edit $name";
elm_ 'StaffEdit.Main' => $FORM_OUT, $e;
};
};
TUWF::get qr{/s/new}, sub {
return tuwf->resDenied if !can_edit s => undef;
framework_ title => 'Add staff member',
sub {
editmsg_ s => undef, 'Add staff member';
elm_ 'StaffEdit.New';
};
};
json_api qr{/s/edit\.json}, $FORM_IN, sub {
my $data = shift;
my $new = !$data->{id};
my $e = $new ? { id => 0 } : db_entry s => $data->{id} or return tuwf->resNotFound;
return elm_Unauth if !can_edit s => $e;
if(!auth->permDbmod) {
$data->{hidden} = $e->{hidden}||0;
$data->{locked} = $e->{locked}||0;
}
$data->{l_wp} = $e->{l_wp}||'';
$data->{desc} = bb_subst_links $data->{desc};
# The form validation only checks for duplicate aid's, but the name+original should also be unique.
my %names;
die "Duplicate aliases" if grep $names{"$_->{name}\x00$_->{original}"}++, $data->{alias}->@*;
# For positive alias IDs: Make sure they exist and are owned by this entry.
validate_dbid
sql('SELECT aid FROM staff_alias WHERE id =', \$e->{id}, 'AND aid IN'),
grep $_>=0, map $_->{aid}, $data->{alias}->@*;
# For negative alias IDs: Assign a new ID.
for my $alias (grep $_->{aid} < 0, $data->{alias}->@*) {
my $new = tuwf->dbVali(select => sql_func nextval => \'staff_alias_aid_seq');
$data->{aid} = $new if $alias->{aid} == $data->{aid};
$alias->{aid} = $new;
}
# We rely on Postgres to throw an error if we attempt to delete an alias that is still being referenced.
return elm_Unchanged if !$new && !form_changed $FORM_CMP, $data, $e;
my($id,undef,$rev) = db_edit s => $e->{id}, $data;
elm_Redirect "/s$id.$rev";
};
1;
|