php-gallery/app/app.php

406 lines
12 KiB
PHP
Raw Normal View History

2022-09-12 14:15:16 +00:00
<?php
namespace App;
2022-09-24 16:47:34 +00:00
use Exception;
use Throwable;
2022-09-24 16:47:34 +00:00
2022-09-12 14:15:16 +00:00
class Make {
/*
|-------------------------------------------------------------
| Create Thumbnails
|-------------------------------------------------------------
| Default resolution for a preview image is 300px (max-width)
| ** Not yet implemented **
|-------------------------------------------------------------
*/
function thumbnail($image_path, $thumbnail_path, $resolution) {
try {
$thumbnail = new \Imagick($image_path);
2022-09-12 14:15:16 +00:00
$thumbnail->resizeImage($resolution,null,null,1,null);
$thumbnail->writeImage($thumbnail_path);
return "success";
} catch (\Exception $e) {
2022-09-12 14:15:16 +00:00
return $e;
}
}
/*
2022-09-14 14:08:50 +00:00
Clean up long text input and turn into an array for tags
2022-09-12 14:15:16 +00:00
2022-09-14 14:08:50 +00:00
Returns clean string of words with equal white space between it
2022-09-12 14:15:16 +00:00
*/
function tags($string) {
$string = str_replace('-', '_', $string);
$string = preg_replace('/[^A-Za-z0-9\_ ]/', '', $string);
2022-09-25 12:14:59 +00:00
2022-09-12 14:15:16 +00:00
$string = strtolower($string);
2022-09-25 12:14:59 +00:00
2022-09-12 14:15:16 +00:00
$string = preg_replace('/ +/', ' ', $string);
2022-09-25 12:14:59 +00:00
2022-09-25 15:49:11 +00:00
$string = explode(' ', $string);
2022-09-25 12:14:59 +00:00
$string_list = array();
foreach ($string as $i) {
if (!in_array($i, $string_list)) {
$string_list[] = $i;
}
}
2022-09-25 15:49:11 +00:00
$string = implode(' ', $string_list);
2022-09-25 12:14:59 +00:00
2022-09-25 15:49:11 +00:00
return trim($string);
2022-09-12 14:15:16 +00:00
}
function get_image_colour($img) {
$img_type = pathinfo($img, PATHINFO_EXTENSION);
if ($img_type == "png") {
$img = imagecreatefrompng($img);
} elseif ($img_type == "jpg" || $img_type == "jpeg") {
$img = imagecreatefromjpeg($img);
} elseif ($img_type == "webp") {
$img = imagecreatefromwebp($img);
} else {
return null;
}
try {
$w = imagesx($img);
$h = imagesy($img);
$r = $g = $b = 0;
for($y = 0; $y < $h; $y++) {
for($x = 0; $x < $w; $x++) {
$rgb = imagecolorat($img, $x, $y);
$r += $rgb >> 16;
$g += $rgb >> 8 & 255;
$b += $rgb & 255;
}
}
$pxls = $w * $h;
$r = dechex(round($r / $pxls));
$g = dechex(round($g / $pxls));
$b = dechex(round($b / $pxls));
if(strlen($r) < 2) {
$r = 0 . $r;
}
if(strlen($g) < 2) {
$g = 0 . $g;
}
if(strlen($b) < 2) {
$b = 0 . $b;
}
return "#" . $r . $g . $b;
} catch (Throwable $e) {
return null;
}
}
2022-09-12 14:15:16 +00:00
}
class Account {
/*
2022-09-14 14:08:50 +00:00
Check if user is loggedin
2022-09-12 14:15:16 +00:00
2022-09-14 14:08:50 +00:00
Returns True if user is
Returns False if user is NOT
2022-09-12 14:15:16 +00:00
*/
function is_loggedin() {
if (isset($_SESSION["loggedin"]) && $_SESSION["loggedin"] === true) {
return True;
} else {
return False;
}
}
/*
2022-09-14 14:08:50 +00:00
Get full user info from database
2022-09-12 14:15:16 +00:00
2022-09-14 14:08:50 +00:00
Returns array with user info
2022-09-12 14:15:16 +00:00
*/
function get_user_info($conn, $id) {
2022-09-22 15:51:22 +00:00
$sql = "SELECT id, username, created_at, pfp_path FROM users WHERE id = ?";
2022-09-22 12:43:22 +00:00
if ($stmt = mysqli_prepare($conn, $sql)) {
// Bind variables to the prepared statement as parameters
mysqli_stmt_bind_param($stmt, "i", $param_user_id);
$param_user_id = $id;
$stmt->execute();
$query = $stmt->get_result();
// Fetching associated info
$user_array = mysqli_fetch_assoc($query);
}
2022-09-12 14:15:16 +00:00
return($user_array);
}
/*
2022-09-14 14:08:50 +00:00
Check if user is admin
2022-09-12 14:15:16 +00:00
2022-09-14 14:08:50 +00:00
Returns True if user is privilaged
Returns False if user is NOT privilaged
2022-09-12 14:15:16 +00:00
*/
2022-09-16 16:39:13 +00:00
function is_admin($conn, $id) {
2022-09-12 14:15:16 +00:00
if (isset($id) || !empty($id)) {
2022-09-16 16:39:13 +00:00
// Setting SQL query
2022-09-22 12:43:22 +00:00
$sql = "SELECT admin FROM users WHERE id = ?";
if ($stmt = mysqli_prepare($conn, $sql)) {
// Bind variables to the prepared statement as parameters
mysqli_stmt_bind_param($stmt, "i", $param_user_id);
$param_user_id = $id;
$stmt->execute();
$query = $stmt->get_result();
// Fetching associated info
$user_array = mysqli_fetch_assoc($query);
}
2022-09-16 16:39:13 +00:00
if ($user_array['admin'] || $id == 1) {
2022-09-12 14:15:16 +00:00
return True;
} else {
return False;
}
} else {
return False;
}
}
2022-09-14 14:08:50 +00:00
/*
Get target IP, used for logging
*/
function get_ip() {
if (!empty($_SERVER['HTTP_CLIENT_IP'])) {
$target_ip = $_SERVER['HTTP_CLIENT_IP'];
} elseif (!empty($_SERVER['HTTP_X_FORWARDED_FOR'])) {
$target_ip = $_SERVER['HTTP_X_FORWARDED_FOR'];
} else {
$target_ip = $_SERVER['REMOTE_ADDR'];
}
return $target_ip;
}
2022-09-12 14:15:16 +00:00
}
class Image {
/*
Get full image info from database
Returns array with image info
*/
function get_image_info($conn, $id) {
2022-09-24 14:08:14 +00:00
$sql = "SELECT * FROM images WHERE id = ?";
if ($stmt = mysqli_prepare($conn, $sql)) {
// Bind variables to the prepared statement as parameters
mysqli_stmt_bind_param($stmt, "i", $id);
$stmt->execute();
$query = $stmt->get_result();
// Fetching associated info
$group_array = mysqli_fetch_assoc($query);
}
2022-09-12 14:15:16 +00:00
2022-09-24 14:08:14 +00:00
return($group_array);
2022-09-12 14:15:16 +00:00
}
/*
Check if user is image owner
Returns True if user is privilaged
Returns False if user is NOT privilaged
*/
function image_privilage($id) {
$session_id = $_SESSION['id'];
if (isset($session_id) || !empty($session_id)) {
if ($session_id == $id) {
return True;
} else {
return False;
}
} else {
return False;
}
}
}
2022-09-15 15:40:12 +00:00
2022-09-24 14:08:14 +00:00
class Group {
function get_group_info($conn, $id) {
// Setting SQL query
$sql = "SELECT * FROM groups WHERE id = ?";
if ($stmt = mysqli_prepare($conn, $sql)) {
// Bind variables to the prepared statement as parameters
mysqli_stmt_bind_param($stmt, "i", $id);
$stmt->execute();
$query = $stmt->get_result();
// Fetching associated info
$group_array = mysqli_fetch_assoc($query);
}
return($group_array);
}
function get_group_members($conn, $id){
$user_array = array();
$sql = "SELECT * FROM groups WHERE id = ?";
if ($stmt = mysqli_prepare($conn, $sql)) {
// Bind variables to the prepared statement as parameters
mysqli_stmt_bind_param($stmt, "i", $id);
$stmt->execute();
$query = $stmt->get_result();
// Fetching associated info
$group_array = mysqli_fetch_assoc($query);
}
2022-09-24 16:47:34 +00:00
try {
$image_list = explode(" ", $group_array['image_list']);
$user_array = array();
foreach ($image_list as $image) {
$image_request = mysqli_query($conn, "SELECT author FROM images WHERE id = ".$image);
while ($author = mysqli_fetch_column($image_request)) {
if (!in_array($author, $user_array)) {
$user_array[] = $author;
}
2022-09-24 14:08:14 +00:00
}
}
2022-09-24 16:47:34 +00:00
} catch (Exception) {
2022-09-24 14:08:14 +00:00
}
return($user_array);
}
}
2022-09-15 15:40:12 +00:00
class Diff {
function time($past_time, $full_date = false) {
$now = new \DateTime;
$ago = new \DateTime($past_time);
$diff = $now->diff($ago);
$diff->w = floor($diff->d / 7);
$diff->d -= $diff->w * 7;
$string = array(
'y' => 'year',
'm' => 'month',
'w' => 'week',
'd' => 'day',
'h' => 'hour',
'i' => 'minute',
's' => 'second',
);
foreach ($string as $k => &$v) {
if ($diff->$k) {
$v = $diff->$k . ' ' . $v . ($diff->$k > 1 ? 's' : '');
} else {
unset($string[$k]);
}
}
if (!$full_date) $string = array_slice($string, 0, 1);
return $string ? implode(', ', $string) . ' ago' : 'just now';
}
2022-09-24 14:08:14 +00:00
}
class Sanity {
function check_json() {
$results = array();
if (!is_file(__DIR__."/settings/manifest.json")) {
$results[] = "Critical: manifest.json is missing";
} else {
$manifest = json_decode(file_get_contents(__DIR__."/settings/manifest.json"), true);
if (!isset($manifest['user_name']) || empty($manifest['user_name']) || $manifest['user_name'] == "[your name]") {
$results[] = "Warning: manifest.json is missing your name";
}
if ($manifest['upload']['rename_on_upload'] == true ) {
if (!isset($manifest['upload']['rename_to']) || empty($manifest['upload']['rename_to'])) {
$results[] = "Critical: manifest.json doesnt know what to rename your files to";
} else {
$rename_to = $manifest['upload']['rename_to'];
$rename_rate = 0;
if (str_contains($rename_to, '{{autoinc}}')) $rename_rate = 5;
if (str_contains($rename_to, '{{time}}')) $rename_rate = 5;
if (str_contains($rename_to, '{{date}}')) $rename_rate += 2;
if (str_contains($rename_to, '{{filename}}')) $rename_rate += 2;
if (str_contains($rename_to, '{{username}}') || str_contains($rename_to, '{{userid}}')) $rename_rate += 1;
if ($rename_rate == 0 || $rename_rate < 2) {
$results[] = "Critical: You will encounter errors when uploading images due to filenames, update your manifest.json";
} elseif ($rename_rate < 5 && $rename_rate > 2) {
$results[] = "Warning: You may encounter errors when uploading images due to filenames, concider update your manifest.json";
}
}
}
if ($manifest['is_testing']) {
$results[] = "Warning: You are currently in testing mode, errors will be displayed to the user";
}
}
return $results;
}
function check_files() {
$results = array();
if (!is_dir("images")) {
$results[] = "Critical: You need to setup an images folder, follow the guide on the GitHub repo";
}
if (!is_dir("images/pfp")) {
$results[] = "Critical: You need to setup an pfp folder, follow the guide on the GitHub repo";
}
if (!is_dir("images/previews")) {
$results[] = "Critical: You need to setup an previews folder, follow the guide on the GitHub repo";
}
if (!is_dir("images/thumbnails")) {
$results[] = "Critical: You need to setup an thumbnails folder, follow the guide on the GitHub repo";
}
return $results;
}
function check_version() {
$results = array();
if (PHP_VERSION_ID < 50102) {
$results[] = "Critical: Your current version of PHP is ".PHP_VERSION.". The reccomended version is 8.1.2";
}
return $results;
}
function get_results() {
$results = array();
foreach ($this->check_json() as $result) {
$results[] = $result;
}
foreach ($this->check_files() as $result) {
$results[] = $result;
}
foreach ($this->check_version() as $result) {
$results[] = $result;
}
return $results;
}
}