processor.php 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. <?php
  2. require_once(BASE_CORE_PATH . '/framework/function/http.php');
  3. class processor extends queue\ILooper
  4. {
  5. private $mProxy;
  6. public function __construct($comode = false)
  7. {
  8. if ($comode) {
  9. parent::__construct(new queue\CoDispatcherServer());
  10. } else {
  11. parent::__construct(new queue\DispatcherServer());
  12. }
  13. $this->mProxy = new proxy();
  14. }
  15. protected function handle($msg)
  16. {
  17. if (empty($msg)) return '';
  18. $method = '';
  19. foreach ($msg as $key => $params)
  20. {
  21. if (empty($params)) continue;
  22. $method = strtolower($key);
  23. Log::record("processor hanlde method={$method}", Log::DEBUG);
  24. try
  25. {
  26. if ($method == 'add') {
  27. $this->mProxy->add($params);
  28. } elseif ($method == 'add_zero') {
  29. $this->mProxy->add_zero($params);
  30. } elseif ($method == 'notify') {
  31. $channel = $params['channel'];
  32. $input = $params['params'];
  33. if (empty($channel) || empty($params))
  34. continue;
  35. $this->mProxy->notify($channel, $input);
  36. }
  37. elseif ($method == 'notify_mechant') {
  38. $order_id = intval($params['order_id']);
  39. $manual = $params['manual'] ?? false;
  40. $this->mProxy->notify_merchant($order_id, $manual);
  41. } elseif ($method == 'query') {
  42. $order_id = intval($params['order_id']);
  43. $this->mProxy->query($order_id);
  44. } elseif ($method == 'query_net') {
  45. $order_id = intval($params['order_id']);
  46. $this->mProxy->query_net($order_id);
  47. } elseif ($method == 'manual_success') {
  48. $order_id = intval($params['order_id']);
  49. $this->mProxy->manual_success($order_id);
  50. } elseif ($method == 'manual_cancel') {
  51. $order_id = intval($params['order_id']);
  52. $this->mProxy->manual_cancel($order_id);
  53. } elseif ($method == 'addthird') {
  54. $this->mProxy->addthird($params);
  55. }
  56. else {
  57. Log::record("Error Method={$method}", Log::DEBUG);
  58. }
  59. }
  60. catch (Exception $x) {
  61. Log::record("processor::handle ". $x->getMessage(), Log::ERR);
  62. }
  63. }
  64. return $method;
  65. }
  66. }