core.php 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  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. function CHECK_USER(&$err){
  79. // Is a valid user provided?
  80. if (isset($_REQUEST['u']) && !empty($_REQUEST['u'])){
  81. // Is a valid API key provided?
  82. if (isset($_REQUEST['k']) && !empty($_REQUEST['k'])){
  83. // Save request username and API key.
  84. $r_user = $_REQUEST['u'];
  85. $r_key = $_REQUEST['k'];
  86. // Fetch user database and check the username and API key combination.
  87. $users = GET_JSON_DATA_FROM_FILE(USERS_JSON);
  88. // Does user exist?
  89. if (isset($users[$r_user])){
  90. // Is user access enabled?
  91. if (isset($users[$r_user]['enabled'])){
  92. if ($users[$r_user]['enabled']){
  93. if (ARE_STRINGS_EQUAL($r_key, $users[$r_user]['api_key'], FORCE_CASE_SENSITIVE_API_KEYS)){
  94. // ALL USER CHECKS PASS.
  95. return true;
  96. }
  97. else{
  98. $err = "error_403_4";
  99. return false;
  100. }
  101. }
  102. else{
  103. $err = "error_403_3";
  104. return false;
  105. }
  106. }
  107. else{
  108. $err = "error_403_2";
  109. return false;
  110. }
  111. }
  112. else{
  113. $err = "error_403_1";
  114. return false;
  115. }
  116. }
  117. else{
  118. $err = "error_401_2";
  119. return false;
  120. }
  121. }
  122. else{
  123. $err = "error_401_1";
  124. return false;
  125. }
  126. }