2023-09-06 05:38:18 +03:00
|
|
|
<?php // Create new post
|
|
|
|
|
2023-10-31 21:57:17 +03:00
|
|
|
// Includes
|
2023-09-06 05:38:18 +03:00
|
|
|
require_once("../_auth.php");
|
|
|
|
require_once("../_utils.php");
|
2023-11-03 02:38:51 +03:00
|
|
|
require_once("../_errorslist.php");
|
2023-10-31 21:57:17 +03:00
|
|
|
require_once("../_types.php");
|
2023-09-07 23:05:23 +03:00
|
|
|
require_once("../user/index.php");
|
2023-09-06 05:38:18 +03:00
|
|
|
|
|
|
|
|
|
|
|
|
2023-11-03 02:38:51 +03:00
|
|
|
// Functions
|
|
|
|
|
2023-10-31 21:57:17 +03:00
|
|
|
/*
|
|
|
|
* FUNCTION
|
|
|
|
* Check if image size properties are valid
|
|
|
|
*/
|
2023-11-03 02:38:51 +03:00
|
|
|
function Post_ImgResIsValid ($x, $y): bool {
|
2023-10-31 21:57:17 +03:00
|
|
|
global $Config;
|
|
|
|
|
|
|
|
return ($x <= $Config["media"]["max_pic_res"]["x"])
|
|
|
|
&& ($y <= $Config["media"]["max_pic_res"]["y"])
|
2023-11-03 02:38:51 +03:00
|
|
|
&& (Utils_GetRatio($x, $y) <= $Config["media"]["max_pic_res"]["ratio"]);
|
2023-10-31 21:57:17 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* FUNCTION
|
|
|
|
* Create preview version of image
|
|
|
|
*/
|
2023-11-03 02:38:51 +03:00
|
|
|
function Post_CreatePreviewFromImage ($src, $dst): ReturnT {
|
2023-10-31 21:57:17 +03:00
|
|
|
$img = null;
|
|
|
|
|
|
|
|
// Reading image from source path
|
|
|
|
switch (mime_content_type($src)) {
|
|
|
|
case "image/jpeg":
|
|
|
|
$img = imagecreatefromjpeg($src);
|
|
|
|
break;
|
|
|
|
case "image/png":
|
|
|
|
$img = imagecreatefrompng($src);
|
|
|
|
break;
|
|
|
|
default:
|
2023-11-03 02:38:51 +03:00
|
|
|
return new ReturnT(err_code: E_UIN_FILETYPE, err_desc: "invalid mime type");
|
2023-10-31 21:57:17 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
// Saving it as LQ JPEG
|
|
|
|
imagejpeg($img, $dst, 30);
|
2023-11-03 02:38:51 +03:00
|
|
|
|
|
|
|
return new ReturnT(data: true);
|
2023-10-31 21:57:17 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* FUNCTION
|
|
|
|
* Store image
|
|
|
|
*/
|
2023-11-03 02:38:51 +03:00
|
|
|
function Post_StoreImage ($path, $preview = true): ReturnT {
|
2023-10-31 21:57:17 +03:00
|
|
|
global $Config;
|
|
|
|
|
|
|
|
// Paths
|
|
|
|
$ext = strtolower(pathinfo($path, PATHINFO_EXTENSION));
|
|
|
|
$fileName = strval(time()) . "_" . GenerateRandomString(4);
|
|
|
|
$targetDir = "../../" . $Config["media"]["pics_path"];
|
|
|
|
$targetPath = JoinPaths($targetDir, $fileName . "." . $ext);
|
|
|
|
|
|
|
|
// Creating preview file
|
|
|
|
if ($Config["media"]["previews_enabled"] && $preview) {
|
|
|
|
$previewDir = "../../" . $Config["media"]["prevs_path"];
|
|
|
|
$previewPath = JoinPaths($previewDir, $fileName . ".jpg");
|
2023-11-03 02:38:51 +03:00
|
|
|
$res = Post_CreatePreviewFromImage($path, $previewPath);
|
|
|
|
if ($res.IsError())
|
|
|
|
return $res;
|
2023-10-31 21:57:17 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
move_uploaded_file($path, $targetPath);
|
|
|
|
|
2023-11-03 02:38:51 +03:00
|
|
|
return new ReturnT(data: true);
|
|
|
|
}
|
2023-10-31 21:57:17 +03:00
|
|
|
|
|
|
|
/*
|
2023-11-03 02:38:51 +03:00
|
|
|
* FUNCTION
|
2023-10-31 21:57:17 +03:00
|
|
|
* Create single publication
|
|
|
|
*/
|
2023-11-03 02:38:51 +03:00
|
|
|
function Post_Create (
|
|
|
|
int $author_id,
|
|
|
|
string $tags,
|
|
|
|
string $pic_path,
|
|
|
|
?string $title = null,
|
|
|
|
?string $prev_path = null,
|
|
|
|
bool $comms_enabled = false,
|
|
|
|
bool $edit_lock = false
|
|
|
|
): ReturnT {
|
2023-10-31 21:57:17 +03:00
|
|
|
$result = null;
|
|
|
|
|
|
|
|
// Author ID should exist
|
2023-11-03 02:38:51 +03:00
|
|
|
if (!User_IDExist($author_id))
|
|
|
|
return new ReturnT(err_code: E_UIN_WRONGID, err_desc: "specified user id does not exist");
|
2023-10-31 21:57:17 +03:00
|
|
|
|
|
|
|
// Performing SQL query
|
|
|
|
$s = $db->prepare("INSERT INTO posts (author_id,comment_section_id,tags,title,pic_path,preview_path,comments_enabled,edit_lock) VALUES (?,?,?,?,?,?,?,?)");
|
2023-11-03 02:38:51 +03:00
|
|
|
$s->bind_param("ssssssss", $author_id, null, $tags, $title, $pic_path, $prev_path, $comms_enabled, $edit_lock);
|
2023-10-31 21:57:17 +03:00
|
|
|
|
2023-11-03 02:38:51 +03:00
|
|
|
if ($s->execute() === false)
|
|
|
|
return new ReturnT(err_code: E_DBE_INSERTFAIL, err_desc: "failed to create post record in DB");
|
2023-09-06 05:38:18 +03:00
|
|
|
|
2023-11-03 02:38:51 +03:00
|
|
|
return new ReturnT(data: $result);
|
2023-09-06 05:38:18 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2023-11-03 02:38:51 +03:00
|
|
|
// Methods
|
|
|
|
|
|
|
|
/*
|
|
|
|
* METHOD
|
|
|
|
* Create single publication
|
|
|
|
*/
|
|
|
|
function Post_Create_Method (array $req, array $files): ReturnT {
|
|
|
|
global $db, $Config, $LOGGED_IN, $THIS_USER;
|
|
|
|
|
|
|
|
$author_id = $THIS_USER;
|
|
|
|
$tags = null;
|
|
|
|
$pic_path = null;
|
|
|
|
$title = null;
|
|
|
|
$prev_path = null;
|
|
|
|
$comms_enabled = false;
|
|
|
|
|
|
|
|
// Input sanity checks
|
|
|
|
|
|
|
|
// Check if user is authenticated
|
|
|
|
if (!$LOGGED_IN)
|
|
|
|
return new ReturnT(err_code: E_AUT_NOTAUTHED, err_desc: "you must be logged in to create posts");
|
2023-09-06 05:38:18 +03:00
|
|
|
|
|
|
|
// Check if there are necessary input
|
2023-11-03 02:38:51 +03:00
|
|
|
if (!(isset($req["tags"]) && isset($files["pic"])))
|
|
|
|
return new ReturnT(err_code: E_UIN_INSUFARGS, err_desc: "tags and picture are necessary");
|
2023-09-06 05:38:18 +03:00
|
|
|
|
2023-09-07 23:05:23 +03:00
|
|
|
// TODO: add rate-limiting, instead of this
|
2023-11-03 02:38:51 +03:00
|
|
|
// Check user role
|
|
|
|
if (User_HasRole($THIS_USER, "newbie").GetData())
|
|
|
|
return new ReturnT(err_code: E_ACS_INSUFROLE, err_desc: "newbies cant create posts");
|
2023-09-07 23:05:23 +03:00
|
|
|
|
|
|
|
// Check image properties
|
|
|
|
// If size is too large
|
2023-11-03 02:38:51 +03:00
|
|
|
if ($files["pic"]["size"] > $Config["media"]["max_pic_size"])
|
|
|
|
return new ReturnT(err_code: E_UIN_FILE2LARGE, err_desc: "picture size is too large");
|
2023-09-07 23:05:23 +03:00
|
|
|
$TmpFilePath = $_FILES["pic"]["tmp_name"];
|
|
|
|
$Ext = strtolower(pathinfo($TmpFilePath, PATHINFO_EXTENSION));
|
|
|
|
// If file extension is not in list of allowed
|
2023-11-03 02:38:51 +03:00
|
|
|
if (!in_array($Ext, $Config["media"]["allowed_exts"]))
|
|
|
|
return new ReturnT(err_code: E_UIN_FILETYPE, err_desc: "picture extension is invalid");
|
2023-09-07 23:05:23 +03:00
|
|
|
// If file mime type is not in list of allowed
|
2023-11-03 02:38:51 +03:00
|
|
|
if (!in_array(mime_content_type($TmpFilePath), $Config["media"]["allowed_mimetypes"]))
|
|
|
|
return new ReturnT(err_code: E_UIN_FILETYPE, err_desc: "picture mime type is invalid");
|
2023-09-07 23:05:23 +03:00
|
|
|
// Check if resolution is bigger than allowed or have unacceptable aspect ratio
|
|
|
|
list($SzX, $SzY, $Type, $Attr) = getimagesize($TmpFilePath);
|
2023-11-03 02:38:51 +03:00
|
|
|
if (!Post_ImgResIsValid($SzX, $SzY))
|
|
|
|
return new ReturnT(err_code: E_UIN_IMGBADRES, err_desc: "image with that resolution or aspect ratio cant be accepted");
|
2023-10-31 21:57:17 +03:00
|
|
|
|
|
|
|
// Copy picture to storage folder
|
2023-11-03 02:38:51 +03:00
|
|
|
$res = Post_StoreImage($TmpFilePath, $Config["media"]["previews_enabled"]);
|
|
|
|
if ($res.IsError())
|
|
|
|
return $res;
|
|
|
|
|
|
|
|
// TODO
|
|
|
|
|
|
|
|
// Actions
|
|
|
|
|
|
|
|
return Post_Create($author_id, $tags, $pic_path, $title, $prev_path, $comms_enabled, false);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (ThisFileIsRequested(__FILE__)) {
|
|
|
|
require_once("../_json.php");
|
2023-10-31 21:57:17 +03:00
|
|
|
|
2023-11-03 02:38:51 +03:00
|
|
|
// TODO: cleanup if bad result
|
2023-09-06 05:38:18 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
?>
|