processor.php 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  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. } elseif ($method == 'notify_mechant') {
  37. $order_id = intval($params['order_id']);
  38. $manual = $params['manual'] ?? false;
  39. $this->mProxy->notify_merchant($order_id, $manual);
  40. } elseif ($method == 'query') {
  41. $order_id = intval($params['order_id']);
  42. $this->mProxy->query($order_id);
  43. } elseif ($method == 'query_net') {
  44. $order_id = intval($params['order_id']);
  45. $this->mProxy->query_net($order_id);
  46. } elseif ($method == 'manual_success') {
  47. $order_id = intval($params['order_id']);
  48. $this->mProxy->manual_success($order_id);
  49. } elseif ($method == 'manual_cancel') {
  50. $order_id = intval($params['order_id']);
  51. $this->mProxy->manual_cancel($order_id);
  52. } elseif ($method == 'addthird') {
  53. $this->mProxy->addthird($params);
  54. } else {
  55. Log::record("Error Method={$method}", Log::DEBUG);
  56. }
  57. }
  58. catch (Exception $x) {
  59. Log::record("processor::handle ". $x->getMessage(), Log::ERR);
  60. }
  61. }
  62. return $method;
  63. }
  64. }