core.php 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208
  1. <?php
  2. /*
  3. *
  4. * Application Name: PHP Custom Content Uploader
  5. * Module Name: core.php
  6. *
  7. * Copyright (c) 2020 DBMXPCA Technologies. All rights reserved.
  8. * https://www.dbmxpca.com/
  9. *
  10. */
  11. require_once($_SERVER['DOCUMENT_ROOT'] . "/config.php");
  12. // Returns true if both strings are the same. Performs a case-insensitive comparison unless third parameter is true.
  13. function ARE_STRINGS_EQUAL($str1, $str2, $case_sensitive = false){
  14. switch($case_sensitive){
  15. case true:
  16. if (strcmp($str1, $str2) == 0){
  17. return true;
  18. }
  19. else{
  20. return false;
  21. }
  22. break;
  23. default:
  24. if (strcasecmp($str1, $str2) == 0){
  25. return true;
  26. }
  27. else{
  28. return false;
  29. }
  30. break;
  31. }
  32. return false;
  33. }
  34. function GET_JSON_DATA_FROM_FILE($full_path_to_file){
  35. $filename = $full_path_to_file;
  36. $fp = fopen($filename, 'r');
  37. $data = fread($fp, filesize($filename));
  38. fclose($fp);
  39. $r = json_decode($data, true);
  40. return $r;
  41. }
  42. // Returns the language-specific string with the specified key.
  43. function GET_LANG_STR($str){
  44. $lang = "en";
  45. $filename = "lang_strings.json";
  46. $not_found = strtoupper($str);
  47. if (!isset($filename)){
  48. return $not_found;
  49. }
  50. $contents = file_get_contents($filename);
  51. $json = json_decode($contents, true);
  52. if ($json == null){
  53. return $not_found;
  54. }
  55. if (array_key_exists($lang, $json)){
  56. if (array_key_exists($str, $json[$lang])){
  57. return $json[$lang][$str];
  58. }
  59. else{
  60. return $not_found;
  61. }
  62. }
  63. else{
  64. return $not_found;
  65. }
  66. }
  67. // Die with error string.
  68. function DIE_ERR($str){
  69. if (!DETAILED_ERRORS){
  70. $str = substr($str, 0, -2);
  71. }
  72. if (ENCLOSE_ERRORS_WITH_PRE_TAG){
  73. die("<pre>" . GET_LANG_STR($str) . "</pre>");
  74. }else{
  75. die(GET_LANG_STR($str));
  76. }
  77. }
  78. // Check user authorization.
  79. function CHECK_USER(&$err){
  80. // Is a valid user provided?
  81. if (isset($_REQUEST['u']) && !empty($_REQUEST['u'])){
  82. // Is a valid API key provided?
  83. if (isset($_REQUEST['k']) && !empty($_REQUEST['k'])){
  84. // Save request username and API key.
  85. $r_user = $_REQUEST['u'];
  86. $r_key = $_REQUEST['k'];
  87. // Fetch user database and check the username and API key combination.
  88. $users = GET_JSON_DATA_FROM_FILE(USERS_JSON);
  89. // Does user exist?
  90. if (isset($users[$r_user])){
  91. // Is user access enabled?
  92. if (isset($users[$r_user]['enabled'])){
  93. if ($users[$r_user]['enabled']){
  94. if (ARE_STRINGS_EQUAL($r_key, $users[$r_user]['api_key'], FORCE_CASE_SENSITIVE_API_KEYS)){
  95. // ALL USER CHECKS PASS.
  96. return true;
  97. }
  98. else{
  99. $err = "error_403_4";
  100. return false;
  101. }
  102. }
  103. else{
  104. $err = "error_403_3";
  105. return false;
  106. }
  107. }
  108. else{
  109. $err = "error_403_2";
  110. return false;
  111. }
  112. }
  113. else{
  114. $err = "error_403_1";
  115. return false;
  116. }
  117. }
  118. else{
  119. $err = "error_401_2";
  120. return false;
  121. }
  122. }
  123. else{
  124. $err = "error_401_1";
  125. return false;
  126. }
  127. }
  128. // Check image prelim data.
  129. function CHECK_IMAGE_PRELIM_DATA(&$err){
  130. if (empty($_FILES)){
  131. $err = "error_415_1";
  132. return false;
  133. }
  134. if (filesize($_FILES['image']['tmp_name']) > 0){
  135. if (isset($allowed_mime_types[$_FILES['image']['type']])){
  136. $err = null;
  137. return true;
  138. }
  139. else{
  140. $err = "error_415_3";
  141. return false;
  142. }
  143. }
  144. else{
  145. $err = "error_400_2";
  146. return false;
  147. }
  148. }
  149. // Check if any errors on file upload.
  150. function CHECK_IMAGE_ERRORS(&$err){
  151. if ($_FILES['image']['error'] > 0){
  152. $err = "error_500_0_";
  153. return false;
  154. }
  155. $err = null;
  156. return true;
  157. }