forked from SuprDewd/simpletracker
-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathsite.php
More file actions
125 lines (111 loc) · 4.55 KB
/
site.php
File metadata and controls
125 lines (111 loc) · 4.55 KB
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
124
125
<?php
require_once 'config.php';
require_once 'db.php';
$db = $CONFIG['db']['type'] == 'mysql' ? new MySqlDatabase()
: new PostgreSqlDatabase();
function html_escape($s) {
return htmlspecialchars($s, ENT_QUOTES, 'UTF-8');
}
function random_hash() {
$s = openssl_random_pseudo_bytes(30);
if ($s === null) {
die('no source of randomness');
}
return md5($s);
}
function require_auth() {
global $CONFIG;
if (!array_key_exists('user', $_SESSION)) {
header(sprintf('Location: %s/login.php', $CONFIG['base_url']));
die;
}
}
function check_csrf() {
if (!array_key_exists('csrf', $_POST) || $_POST['csrf'] !== $_SESSION['csrf']) {
die;
}
}
function csrf_html() {
printf('<input type="hidden", name="csrf" value="%s" />', html_escape($_SESSION['csrf']));
}
function gen_csrf($replace = false) {
if ($replace || !array_key_exists('csrf', $_SESSION)) {
$_SESSION['csrf'] = random_hash();
}
}
function format_size($b) {
if ($b < 1024) return round($b,2) . 'B';
$b /= 1024.0;
if ($b < 1024) return round($b,2) . 'KiB';
$b /= 1024.0;
if ($b < 1024) return round($b,2) . 'MiB';
$b /= 1024.0;
if ($b < 1024) return round($b,2) . 'GiB';
$b /= 1024.0;
return round($b,2) . 'TiB';
}
function site_header() {
global $CONFIG;
printf('<!DOCTYPE html>');
printf('<html>');
printf('<head>');
printf('<meta name="viewport" content="width=device-width, initial-scale=1">');
printf('<meta name="format-detection" content="telephone=no">');
printf('<link rel="shortcut icon" href="img/favicon.ico" type="image/x-icon">');
printf('<link rel="icon" href="/img/favicon.ico" type="image/x-icon">');
printf('<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.4.1/css/bootstrap.min.css" integrity="sha384-Vkoo8x4CGsO3+Hhxv8T/Q5PaXtkKtu6ug5TOeNV6gBiFeWPGFN9MuhOf23Q9Ifjh" crossorigin="anonymous">');
printf('<script src="https://code.jquery.com/jquery-3.4.1.slim.min.js" integrity="sha384-J6qa4849blE2+poT4WnyKhv5vZF5SrPo0iEjwBvKU7imGFAV0wwj1yYfoRSJoZ+n" crossorigin="anonymous"></script>');
printf('<script src="https://cdn.jsdelivr.net/npm/popper.js@1.16.0/dist/umd/popper.min.js" integrity="sha384-Q6E9RHvbIyZFJoft+2mJbHaEWldlvI9IOYy5n3zV9zzTtmI3UksdQRVvoxMfooAo" crossorigin="anonymous"></script>');
printf('<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.4.1/js/bootstrap.min.js" integrity="sha384-wfSDF2E50Y2D1uUdj0O3uMBJnjuUD4Ih7YwaYd1iqfktj0Uod8GCExl3Og8ifwB6" crossorigin="anonymous"></script>');
printf('<title>%s</title>', html_escape($CONFIG['site_title']));
printf('</head>');
printf('<body>');
if (array_key_exists('user', $_SESSION)) {
?>
<nav class="navbar navbar-expand-lg navbar-light bg-light">
<a class="navbar-brand" href="#"><?php echo $CONFIG['site_title']; ?></a>
<button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarSupportedContent" aria-controls="navbarSupportedContent" aria-expanded="false" aria-label="Toggle navigation">
<span class="navbar-toggler-icon"></span>
</button>
<div class="collapse navbar-collapse" id="navbarSupportedContent">
<ul class="navbar-nav mr-auto">
<li class="nav-item active">
<a class="nav-link" href="index.php">Home <span class="sr-only">(current)</span></a>
</li>
<li class="nav-item">
<a class="nav-link" href="upload.php">Upload</a>
</li>
<li class="nav-item">
<a class="nav-link" href="invitations.php">Invite</a>
</li>
<li class="nav-item dropdown">
<a class="nav-link dropdown-toggle" href="#" id="navbarDropdown" role="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
<?php echo $_SESSION['user']['username']; ?>
</a>
<div class="dropdown-menu" aria-labelledby="navbarDropdown">
<a class="dropdown-item disabled" href="#">Account</a>
<div class="dropdown-divider"></div>
<a href="logout.php" class="dropdown-item">Log Out</a>
</div>
</li>
</ul>
<!--
<form class="form-inline my-2 my-lg-0">
<input class="form-control mr-sm-2" type="search" placeholder="Search" aria-label="Search" disabled>
<button class="btn btn-outline-success my-2 my-sm-0" type="submit" disabled>Search (Coming Soon)</button>
</form>-->
</div>
</nav>
<div class="container">
<?php
}
}
function site_footer() {
?>
</div>
</body>
<?php
}
// session setup
session_start();
gen_csrf();