1 |
dpavlin |
1 |
use strict; |
2 |
|
|
use warnings; |
3 |
|
|
|
4 |
|
|
package Transports::Model::Source::Schema; |
5 |
|
|
use Jifty::DBI::Schema; |
6 |
|
|
|
7 |
|
|
# Your column definitions go here. See L<Jifty::DBI::Schema> for |
8 |
|
|
# documentation about how to write column definitions. |
9 |
|
|
|
10 |
|
|
column name => |
11 |
|
|
type is 'text', |
12 |
|
|
label is 'Source client', |
13 |
|
|
is mandatory, |
14 |
|
|
since '0.0.6'; |
15 |
|
|
|
16 |
|
|
package Transports::Model::Source; |
17 |
|
|
use base qw/Transports::Record/; |
18 |
|
|
|
19 |
|
|
# Your model-specific methods go here. |
20 |
|
|
|
21 |
dpavlin |
22 |
=head1 available_values |
22 |
|
|
|
23 |
|
|
return all names |
24 |
|
|
|
25 |
|
|
=cut |
26 |
|
|
|
27 |
dpavlin |
1 |
sub available_values { |
28 |
|
|
my $self = shift; |
29 |
|
|
return $self->column("name")->valid_values; |
30 |
|
|
} |
31 |
|
|
|
32 |
dpavlin |
22 |
=head2 current_user_can ACTION |
33 |
|
|
|
34 |
|
|
Let everybody create, read and update, but not delete. |
35 |
|
|
|
36 |
|
|
=cut |
37 |
|
|
|
38 |
|
|
sub current_user_can { |
39 |
|
|
my $self = shift; |
40 |
|
|
my $type = shift; |
41 |
|
|
|
42 |
dpavlin |
41 |
return 1 if ($self->current_user->admin); |
43 |
|
|
|
44 |
dpavlin |
44 |
return 1 if ($type eq 'read'); |
45 |
|
|
|
46 |
dpavlin |
22 |
# We probably want something like this eventually: |
47 |
dpavlin |
44 |
if ($type =~ /(?:create|update)/i) { |
48 |
dpavlin |
36 |
|
49 |
|
|
my $uos = Transports::Model::UserOnSource->new(); |
50 |
|
|
$uos->load_by_cols( |
51 |
|
|
user_on => $self->current_user->id, |
52 |
|
|
source => $self->id |
53 |
|
|
); |
54 |
|
|
return undef if ($self->current_user->id && ! $uos->id); |
55 |
|
|
|
56 |
dpavlin |
22 |
return 1; |
57 |
|
|
} else { |
58 |
|
|
return $self->SUPER::current_user_can($type, @_); |
59 |
|
|
} |
60 |
|
|
} |
61 |
|
|
|
62 |
dpavlin |
1 |
1; |
63 |
|
|
|