run 3.3 KB

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