| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208 |
- <?php
- /*
- *
- * Application Name: PHP Custom Content Uploader
- * Module Name: core.php
- *
- * Copyright (c) 2020 DBMXPCA Technologies. All rights reserved.
- * https://www.dbmxpca.com/
- *
- */
- require_once($_SERVER['DOCUMENT_ROOT'] . "/config.php");
- // Returns true if both strings are the same. Performs a case-insensitive comparison unless third parameter is true.
- function ARE_STRINGS_EQUAL($str1, $str2, $case_sensitive = false){
-
- switch($case_sensitive){
- case true:
- if (strcmp($str1, $str2) == 0){
- return true;
- }
- else{
- return false;
- }
- break;
- default:
- if (strcasecmp($str1, $str2) == 0){
- return true;
- }
- else{
- return false;
- }
- break;
- }
- return false;
- }
- function GET_JSON_DATA_FROM_FILE($full_path_to_file){
-
- $filename = $full_path_to_file;
- $fp = fopen($filename, 'r');
- $data = fread($fp, filesize($filename));
- fclose($fp);
-
- $r = json_decode($data, true);
- return $r;
- }
- // Returns the language-specific string with the specified key.
- function GET_LANG_STR($str){
-
- $lang = "en";
- $filename = "lang_strings.json";
- $not_found = strtoupper($str);
-
- if (!isset($filename)){
- return $not_found;
- }
-
- $contents = file_get_contents($filename);
- $json = json_decode($contents, true);
-
- if ($json == null){
- return $not_found;
- }
-
- if (array_key_exists($lang, $json)){
- if (array_key_exists($str, $json[$lang])){
- return $json[$lang][$str];
- }
- else{
- return $not_found;
- }
- }
- else{
- return $not_found;
- }
- }
- // Die with error string.
- function DIE_ERR($str){
-
- if (!DETAILED_ERRORS){
- $str = substr($str, 0, -2);
- }
-
- if (ENCLOSE_ERRORS_WITH_PRE_TAG){
- die("<pre>" . GET_LANG_STR($str) . "</pre>");
- }else{
- die(GET_LANG_STR($str));
- }
- }
- // Check user authorization.
- function CHECK_USER(&$err){
-
- // Is a valid user provided?
- if (isset($_REQUEST['u']) && !empty($_REQUEST['u'])){
- // Is a valid API key provided?
- if (isset($_REQUEST['k']) && !empty($_REQUEST['k'])){
-
- // Save request username and API key.
- $r_user = $_REQUEST['u'];
- $r_key = $_REQUEST['k'];
-
- // Fetch user database and check the username and API key combination.
- $users = GET_JSON_DATA_FROM_FILE(USERS_JSON);
-
- // Does user exist?
- if (isset($users[$r_user])){
-
- // Is user access enabled?
- if (isset($users[$r_user]['enabled'])){
-
- if ($users[$r_user]['enabled']){
-
- if (ARE_STRINGS_EQUAL($r_key, $users[$r_user]['api_key'], FORCE_CASE_SENSITIVE_API_KEYS)){
- // ALL USER CHECKS PASS.
- return true;
- }
- else{
- $err = "error_403_4";
- return false;
- }
- }
- else{
- $err = "error_403_3";
- return false;
- }
- }
- else{
- $err = "error_403_2";
- return false;
- }
- }
- else{
- $err = "error_403_1";
- return false;
- }
- }
-
- else{
-
- $err = "error_401_2";
- return false;
- }
- }
- else{
-
- $err = "error_401_1";
- return false;
- }
- }
- // Check image prelim data.
- function CHECK_IMAGE_PRELIM_DATA(&$err){
-
- if (empty($_FILES)){
-
- $err = "error_415_1";
- return false;
- }
-
- if (filesize($_FILES['image']['tmp_name']) > 0){
-
- if (isset($allowed_mime_types[$_FILES['image']['type']])){
-
- $err = null;
- return true;
- }
- else{
-
- $err = "error_415_3";
- return false;
- }
- }
- else{
-
- $err = "error_400_2";
- return false;
- }
- }
- // Check if any errors on file upload.
- function CHECK_IMAGE_ERRORS(&$err){
-
- if ($_FILES['image']['error'] > 0){
- $err = "error_500_0_";
- return false;
- }
- $err = null;
- return true;
- }
|