Project

General

Profile

1 5 stefan
<?php
2
3 11 ryan
// $Id$
4
5 5 stefan
/*
6
7
 Website Baker Project <http://www.websitebaker.org/>
8
 Copyright (C) 2004-2005, Ryan Djurovich
9
10
 Website Baker is free software; you can redistribute it and/or modify
11
 it under the terms of the GNU General Public License as published by
12
 the Free Software Foundation; either version 2 of the License, or
13
 (at your option) any later version.
14
15
 Website Baker is distributed in the hope that it will be useful,
16
 but WITHOUT ANY WARRANTY; without even the implied warranty of
17
 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18
 GNU General Public License for more details.
19
20
 You should have received a copy of the GNU General Public License
21
 along with Website Baker; if not, write to the Free Software
22
 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
23
24
*/
25
26
/*
27
28
wb class
29
30
This class is the basis for admin and frontend classes.
31
32
*/
33 19 stefan
if(!defined('WB_URL')) {
34
	header('Location: ../index.php');
35
}
36 5 stefan
37
38
class wb
39
{
40
	function wb() {
41
	}
42
43
	// Check whether we should show a page or not (for front-end)
44
	function show_page($page) {
45
		// First check if the page is set to private
46
		if($page['visibility'] == 'private' OR $page['visibility'] == 'registered') {
47
			// Check if the user is logged in
48
			if($this->is_authenticated() == true) {
49
				// Now check if the user has perms to view it
50
				$viewing_groups = explode(',', $page['viewing_groups']);
51
				$viewing_users = explode(',', $page['viewing_users']);
52
				if(is_numeric(array_search($this->get_group_id(), $viewing_groups)) OR is_numeric(array_search($this->get_user_id(), $viewing_users))) {
53
					return true;
54
				} else {
55
					return false;
56
				}
57
			} else {
58
				return false;
59
			}
60
		} elseif($page['visibility'] == 'public') {
61
			return true;
62
		} else {
63
			return false;
64
		}
65
	}
66
67
	// Check if the user is already authenticated or not
68
	function is_authenticated() {
69
		if(isset($_SESSION['USER_ID']) AND $_SESSION['USER_ID'] != "" AND is_numeric($_SESSION['USER_ID'])) {
70
			return true;
71
		} else {
72
			return false;
73
		}
74
	}
75
76
	// Get POST data
77
	function get_post($field) {
78
		if(isset($_POST[$field])) {
79
			return $_POST[$field];
80
		} else {
81
			return null;
82
		}
83
	}
84
85
	// Get GET data
86
	function get_get($field) {
87
		if(isset($_GET[$field])) {
88
			return $_GET[$field];
89
		} else {
90
			return null;
91
		}
92
	}
93
94
	// Get SESSION data
95
	function get_session($field) {
96
		if(isset($_SESSION[$field])) {
97
			return $_SESSION[$field];
98
		} else {
99
			return null;
100
		}
101
	}
102
103
	// Get SERVER data
104
	function get_server($field) {
105
		if(isset($_SERVER[$field])) {
106
			return $_SERVER[$field];
107
		} else {
108
			return null;
109
		}
110
	}
111
112
	// Get the current users id
113
	function get_user_id() {
114
		return $_SESSION['USER_ID'];
115
	}
116
117
	// Get the current users group id
118
	function get_group_id() {
119
		return $_SESSION['GROUP_ID'];
120
	}
121
122
	// Get the current users group name
123
	function get_group_name() {
124
		return $_SESSION['GROUP_NAME'];
125
	}
126
127
	// Get the current users username
128
	function get_username() {
129
		return $_SESSION['USERNAME'];
130
	}
131
132
	// Get the current users display name
133
	function get_display_name() {
134
		return stripslashes($_SESSION['DISPLAY_NAME']);
135
	}
136
137
	// Get the current users email address
138
	function get_email() {
139
		return $_SESSION['EMAIL'];
140
	}
141
142
	// Get the current users home folder
143
	function get_home_folder() {
144
		return $_SESSION['HOME_FOLDER'];
145
	}
146
147
	// Get the current users timezone
148
	function get_timezone() {
149
		if(!isset($_SESSION['USE_DEFAULT_TIMEZONE'])) {
150
			return $_SESSION['TIMEZONE'];
151
		} else {
152
			return '-72000';
153
		}
154
	}
155
156
	// Validate supplied email address
157
	function validate_email($email) {
158
		if(eregi("^[_a-z0-9-]+(\.[_a-z0-9-]+)*@[a-z0-9-]+(\.[a-z0-9-]+)*(\.[a-z]{2,3})$", $email)) {
159
			return true;
160
		} else {
161
			return false;
162
		}
163
	}
164
165
166
}
167
?>