index.php 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. <?php
  2. /**
  3. * 入口文件
  4. *
  5. * 云函数版本维护:
  6. * 1、去掉顶部的 “#!/usr/bin/env php”,将文件名改为 index.php
  7. * 2、将 “define('IS_SCF', false);” 改为 “define('IS_SCF', true);”
  8. * 3、干掉最下方的 run(); 调用
  9. *
  10. * @author mybsdc <[email protected]>
  11. * @date 2019/3/2
  12. * @time 11:05
  13. * @link https://github.com/luolongfei/freenom
  14. */
  15. error_reporting(E_ERROR);
  16. ini_set('display_errors', 1);
  17. set_time_limit(0);
  18. define('IS_SCF', true); // 是否云函数环境
  19. define('IS_CLI', PHP_SAPI === 'cli');
  20. define('DS', DIRECTORY_SEPARATOR);
  21. define('ROOT_PATH', realpath(__DIR__));
  22. define('VENDOR_PATH', realpath(ROOT_PATH . '/vendor'));
  23. define('APP_PATH', realpath(ROOT_PATH . '/app'));
  24. define('DATA_PATH', IS_SCF ? '/tmp' : realpath(ROOT_PATH . '/app/Data')); // 云函数只有 /tmp 目录的读写权限
  25. define('RESOURCES_PATH', realpath(ROOT_PATH . '/resources'));
  26. date_default_timezone_set('Asia/Shanghai');
  27. /**
  28. * 注册错误处理
  29. */
  30. register_shutdown_function('customize_error_handler');
  31. /**
  32. * 注册异常处理
  33. */
  34. set_exception_handler('exception_handler');
  35. require VENDOR_PATH . '/autoload.php';
  36. use Luolongfei\Libs\Log;
  37. use Luolongfei\Libs\Message;
  38. /**
  39. * @throws Exception
  40. */
  41. function customize_error_handler()
  42. {
  43. if (!is_null($error = error_get_last())) {
  44. system_log(json_encode($error, JSON_UNESCAPED_UNICODE));
  45. Log::error(lang('100057'), $error);
  46. Message::send(lang('100058') . json_encode($error, JSON_UNESCAPED_UNICODE), lang('100059'));
  47. }
  48. }
  49. /**
  50. * @param \Exception $e
  51. *
  52. * @throws \Exception
  53. */
  54. function exception_handler($e)
  55. {
  56. Log::error(lang('100060') . $e->getMessage());
  57. Message::send(lang('100061') . $e->getMessage(), lang('100062'));
  58. }
  59. /**
  60. * 腾讯云函数
  61. *
  62. * @param $event
  63. * @param $context
  64. *
  65. * @return string
  66. */
  67. function main_handler($event, $context)
  68. {
  69. return run();
  70. }
  71. /**
  72. * 阿里云函数
  73. *
  74. * @param $event
  75. * @param $context
  76. *
  77. * @return string
  78. */
  79. function handler($event, $context)
  80. {
  81. $logger = $GLOBALS['fcLogger'];
  82. $logger->info(lang('100063'));
  83. return run();
  84. }
  85. /**
  86. * 华为云函数
  87. *
  88. * @param $event
  89. * @param $context
  90. *
  91. * @return bool|string
  92. */
  93. function huawei_handler($event, $context)
  94. {
  95. $logger = $context->getLogger();
  96. $logger->info('开始执行华为云函数');
  97. // 手动设置环境变量
  98. $logger->info('设置环境变量');
  99. $allEnvKeys = array_keys((array)env());
  100. foreach ($allEnvKeys as $key) {
  101. $value = $context->getUserData((string)$key);
  102. if (strlen($value) > 0) {
  103. $logger->info('从控制台发现环境变量:' . $key);
  104. putenv("{$key}={$value}");
  105. }
  106. }
  107. $logger->info('环境变量设置完成');
  108. return run();
  109. }
  110. /**
  111. * @return string|bool
  112. */
  113. function run()
  114. {
  115. try {
  116. system_check();
  117. $class = sprintf('Luolongfei\App\Console\%s', get_argv('c', 'FreeNom'));
  118. $fn = get_argv('m', 'handle');
  119. $class::getInstance()->$fn();
  120. return IS_SCF ? lang('100007') : true;
  121. } catch (\Exception $e) {
  122. system_log(sprintf(lang('100006'), $e->getMessage()), $e->getTrace());
  123. Message::send(lang('100004') . $e->getMessage(), lang('100005'));
  124. }
  125. return IS_SCF ? lang('100008') : false;
  126. }