php-gallery/app/app.php

260 lines
7.1 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;
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) {
// Replace hyphens
$string = str_replace('-', '_', $string);
// Regex
$string = preg_replace('/[^A-Za-z0-9\_ ]/', '', $string);
// Change to lowercase
$string = strtolower($string);
// Removing extra spaces
$string = preg_replace('/ +/', ' ', $string);
return $string;
}
}
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
}