-
Notifications
You must be signed in to change notification settings - Fork 0
/
penn403.module
123 lines (115 loc) · 3.42 KB
/
penn403.module
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
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
<?php
/**
* @file
* penn403.module
*
* Penn 403 Module v. 7.x-1.x
*
* Custom 403 Access Denied page for the University Of Pennsylvania
*/
/**
* Implementation of hook_menu()
*/
function penn403_menu() {
$items['admin/config/system/penn403'] = array(
'title' => 'Penn 403',
'page callback' => 'drupal_get_form',
'page arguments' => array('penn403_admin_settings'),
'access arguments' => array('administer penn403'),
'description' => 'Change settings for the Penn 403 module.',
'file' => 'penn403.admin.inc',
'type' => MENU_NORMAL_ITEM,
);
$items['penn403_access_denied'] = array(
'title' => 'Access Denied',
'page callback' => 'penn403_access_denied',
'page arguments' => array(),
'access callback' => TRUE,
'weight' => 100,
'type' => MENU_CALLBACK,
);
return $items;
} // function penn403_menu()
/**
* Implements hook_admin_paths().
*/
function penn403_admin_paths() {
return array('admin/config/system/penn403' => TRUE);
}
/**
* Implements hook_permission().
*/
function penn403_permission() {
return array(
'administer penn403' => array(
'title' => t('Administer Penn 403 configuration'),
),
);
}
/**
* function penn403_theme()
*
* implementation of hook_theme()
*/
function penn403_theme() {
return array(
'penn403_login_required' => array(
'arguments' => array(),
),
'penn403_insufficient_privileges' => array(
'arguments' => array(),
),
);
} // function penn403_theme()
/**
* function theme_penn403_login_required()
*/
function theme_penn403_login_required() {
// here we are relying on the simplesamlphp_auth module
$login_path = variable_get('simplesamlphp_auth_login_path', 'saml_login');
drupal_set_title(t('Login Required'));
$output = '';
$output .= '<div class="penn403-login">';
$output .= l(t('Log in using your PennKey.'), $login_path, array('query' => array('destination' => request_path())));
$output .= '</div>';
return $output;
} // function theme_penn403_login_required()
/**
* function theme_penn403_insufficient_privileges()
*/
function theme_penn403_insufficient_privileges() {
$output = '';
$output .= '<div class="penn403-insufficient-privileges">';
$output .= 'You do not have sufficient privileges to access this page. ';
$output .= t('Please') . ' ' . l(t('contact the site administrator'), 'mailto:' . variable_get('site_mail', '[email protected]'), array('attributes' => array('rel' => 'nofollow'))) . ' ' . t('to request access.');
$output .= '</div>';
return $output;
} // function theme_penn403_insufficient_privileges()
/**
* function penn403_access_denied()
*
* custom access denied (403) page
*/
function penn403_access_denied() {
drupal_page_is_cacheable(FALSE);
global $user;
if (user_is_anonymous()) {
if ( variable_get('penn403_auto_redirect', 'yes') == 'yes') {
// here we are relying on the simplesamlphp_auth module
$login_path = variable_get('simplesamlphp_auth_login_path', 'saml_login');
$url = url($login_path, array('query' => array('destination' => request_path())));
header('Location: ' . $url, TRUE, 303);
}
else {
$output = theme('penn403_login_required');
return $output;
}
}
else {
if (!stripos($_GET['q'], 'saml_login')) {
// only display this message if not on a the authorization page, otherwise redirect
$output = theme('penn403_insufficient_privileges');
return $output;
}
}
}