forked from lix-project/hydra
Allow public dashboards
Dashboards can now be marked as publically visible in the user preferences. The dashboard URL has changed from /user/<name>/dashboard to /dashboard/<name> because /user/<name> requires being logged in as <name> or as an admin.
This commit is contained in:
parent
f3a3f8de46
commit
f70946efca
5 changed files with 43 additions and 6 deletions
|
@ -229,6 +229,7 @@ sub updatePreferences {
|
||||||
$user->update(
|
$user->update(
|
||||||
{ fullname => $fullName
|
{ fullname => $fullName
|
||||||
, emailonerror => $c->stash->{params}->{"emailonerror"} ? 1 : 0
|
, emailonerror => $c->stash->{params}->{"emailonerror"} ? 1 : 0
|
||||||
|
, publicdashboard => $c->stash->{params}->{"publicdashboard"} ? 1 : 0
|
||||||
});
|
});
|
||||||
|
|
||||||
if (isAdmin($c)) {
|
if (isAdmin($c)) {
|
||||||
|
@ -336,7 +337,25 @@ sub reset_password :Chained('user') :PathPart('reset-password') :Args(0) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
sub dashboard :Chained('user') :Args(0) {
|
sub dashboard_old :Chained('user') :PathPart('dashboard') :Args(0) {
|
||||||
|
my ($self, $c) = @_;
|
||||||
|
$c->res->redirect($c->uri_for($self->action_for("dashboard"), $c->req->captures));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
sub dashboard_base :Chained('/') PathPart('dashboard') CaptureArgs(1) {
|
||||||
|
my ($self, $c, $userName) = @_;
|
||||||
|
|
||||||
|
$c->stash->{user} = $c->model('DB::Users')->find($userName)
|
||||||
|
or notFound($c, "User $userName doesn't exist.");
|
||||||
|
|
||||||
|
accessDenied($c, "You do not have permission to view this dashboard.")
|
||||||
|
unless $c->stash->{user}->publicdashboard ||
|
||||||
|
(defined $c->user && ($userName eq $c->user->username || !isAdmin($c)));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
sub dashboard :Chained('dashboard_base') :PathPart('') :Args(0) {
|
||||||
my ($self, $c) = @_;
|
my ($self, $c) = @_;
|
||||||
$c->stash->{template} = 'dashboard.tt';
|
$c->stash->{template} = 'dashboard.tt';
|
||||||
|
|
||||||
|
@ -351,7 +370,7 @@ sub dashboard :Chained('user') :Args(0) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
sub my_jobs_tab :Chained('user') :PathPart('my-jobs-tab') :Args(0) {
|
sub my_jobs_tab :Chained('dashboard_base') :PathPart('my-jobs-tab') :Args(0) {
|
||||||
my ($self, $c) = @_;
|
my ($self, $c) = @_;
|
||||||
$c->stash->{template} = 'dashboard-my-jobs-tab.tt';
|
$c->stash->{template} = 'dashboard-my-jobs-tab.tt';
|
||||||
|
|
||||||
|
@ -370,7 +389,7 @@ sub my_jobs_tab :Chained('user') :PathPart('my-jobs-tab') :Args(0) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
sub my_jobsets_tab :Chained('user') :PathPart('my-jobsets-tab') :Args(0) {
|
sub my_jobsets_tab :Chained('dashboard_base') :PathPart('my-jobsets-tab') :Args(0) {
|
||||||
my ($self, $c) = @_;
|
my ($self, $c) = @_;
|
||||||
$c->stash->{template} = 'dashboard-my-jobsets-tab.tt';
|
$c->stash->{template} = 'dashboard-my-jobsets-tab.tt';
|
||||||
|
|
||||||
|
|
|
@ -67,6 +67,12 @@ __PACKAGE__->table("Users");
|
||||||
default_value: 'hydra'
|
default_value: 'hydra'
|
||||||
is_nullable: 0
|
is_nullable: 0
|
||||||
|
|
||||||
|
=head2 publicdashboard
|
||||||
|
|
||||||
|
data_type: 'boolean'
|
||||||
|
default_value: false
|
||||||
|
is_nullable: 0
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
||||||
__PACKAGE__->add_columns(
|
__PACKAGE__->add_columns(
|
||||||
|
@ -82,6 +88,8 @@ __PACKAGE__->add_columns(
|
||||||
{ data_type => "integer", default_value => 0, is_nullable => 0 },
|
{ data_type => "integer", default_value => 0, is_nullable => 0 },
|
||||||
"type",
|
"type",
|
||||||
{ data_type => "text", default_value => "hydra", is_nullable => 0 },
|
{ data_type => "text", default_value => "hydra", is_nullable => 0 },
|
||||||
|
"publicdashboard",
|
||||||
|
{ data_type => "boolean", default_value => \"false", is_nullable => 0 },
|
||||||
);
|
);
|
||||||
|
|
||||||
=head1 PRIMARY KEY
|
=head1 PRIMARY KEY
|
||||||
|
@ -184,8 +192,8 @@ Composing rels: L</projectmembers> -> project
|
||||||
__PACKAGE__->many_to_many("projects", "projectmembers", "project");
|
__PACKAGE__->many_to_many("projects", "projectmembers", "project");
|
||||||
|
|
||||||
|
|
||||||
# Created by DBIx::Class::Schema::Loader v0.07033 @ 2013-11-05 10:22:03
|
# Created by DBIx::Class::Schema::Loader v0.07043 @ 2016-05-27 11:32:14
|
||||||
# DO NOT MODIFY THIS OR ANYTHING ABOVE! md5sum:Gd8KwFcnVShZ/WihvwfgQw
|
# DO NOT MODIFY THIS OR ANYTHING ABOVE! md5sum:Az1+V+ztJoWUt50NLQR3xg
|
||||||
|
|
||||||
my %hint = (
|
my %hint = (
|
||||||
columns => [
|
columns => [
|
||||||
|
|
|
@ -65,6 +65,14 @@
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div class="control-group">
|
||||||
|
<div class="controls">
|
||||||
|
<label class="checkbox">
|
||||||
|
<input type="checkbox" name="publicdashboard" [% IF !create && user.publicdashboard; 'checked="checked"'; END %]/>Public dashboard
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
[% IF !create || c.check_user_roles('admin') %]
|
[% IF !create || c.check_user_roles('admin') %]
|
||||||
<div class="control-group">
|
<div class="control-group">
|
||||||
<label class="control-label">Roles</label>
|
<label class="control-label">Roles</label>
|
||||||
|
|
|
@ -10,7 +10,8 @@ create table Users (
|
||||||
emailAddress text not null,
|
emailAddress text not null,
|
||||||
password text not null, -- sha256 hash
|
password text not null, -- sha256 hash
|
||||||
emailOnError integer not null default 0,
|
emailOnError integer not null default 0,
|
||||||
type text not null default 'hydra' -- either "hydra" or "persona"
|
type text not null default 'hydra', -- either "hydra" or "persona"
|
||||||
|
publicDashboard boolean not null default false
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
||||||
|
|
1
src/sql/upgrade-49.sql
Normal file
1
src/sql/upgrade-49.sql
Normal file
|
@ -0,0 +1 @@
|
||||||
|
alter table Users add column publicDashboard boolean not null default false;
|
Loading…
Reference in a new issue