jsonrpc


SUBMITTED BY: Guest

DATE: Jan. 8, 2014, 10:46 a.m.

FORMAT: Text only

SIZE: 4.5 kB

HITS: 1158

  1. <?php
  2. /*
  3. COPYRIGHT
  4. Copyright 2007 Sergio Vaccaro <sergio@inservibile.org>
  5. This file is part of JSON-RPC PHP.
  6. JSON-RPC PHP is free software; you can redistribute it and/or modify
  7. it under the terms of the GNU General Public License as published by
  8. the Free Software Foundation; either version 2 of the License, or
  9. (at your option) any later version.
  10. JSON-RPC PHP is distributed in the hope that it will be useful,
  11. but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. GNU General Public License for more details.
  14. You should have received a copy of the GNU General Public License
  15. along with JSON-RPC PHP; if not, write to the Free Software
  16. Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
  17. */
  18. /**
  19. * The object of this class are generic jsonRPC 1.0 clients
  20. * http://json-rpc.org/wiki/specification
  21. *
  22. * @author sergio <jsonrpcphp@inservibile.org>
  23. */
  24. class jsonRPCClient {
  25. /**
  26. * Debug state
  27. *
  28. * @var boolean
  29. */
  30. private $debug;
  31. /**
  32. * The server URL
  33. *
  34. * @var string
  35. */
  36. private $url;
  37. /**
  38. * The request id
  39. *
  40. * @var integer
  41. */
  42. private $id;
  43. /**
  44. * If true, notifications are performed instead of requests
  45. *
  46. * @var boolean
  47. */
  48. private $notification = false;
  49. /**
  50. * Takes the connection parameters
  51. *
  52. * @param string $url
  53. * @param boolean $debug
  54. */
  55. public function __construct($url,$debug = false) {
  56. // server URL
  57. $this->url = $url;
  58. // proxy
  59. empty($proxy) ? $this->proxy = '' : $this->proxy = $proxy;
  60. // debug state
  61. empty($debug) ? $this->debug = false : $this->debug = true;
  62. // message id
  63. $this->id = 1;
  64. }
  65. /**
  66. * Sets the notification state of the object. In this state, notifications are performed, instead of requests.
  67. *
  68. * @param boolean $notification
  69. */
  70. public function setRPCNotification($notification) {
  71. empty($notification) ?
  72. $this->notification = false
  73. :
  74. $this->notification = true;
  75. }
  76. /**
  77. * Performs a jsonRCP request and gets the results as an array
  78. *
  79. * @param string $method
  80. * @param array $params
  81. * @return array
  82. */
  83. public function __call($method,$params) {
  84. // check
  85. if (!is_scalar($method)) {
  86. throw new Exception('Method name has no scalar value');
  87. }
  88. // check
  89. if (is_array($params)) {
  90. // no keys
  91. $params = array_values($params);
  92. } else {
  93. throw new Exception('Params must be given as array');
  94. }
  95. // sets notification or request task
  96. if ($this->notification) {
  97. $currentId = NULL;
  98. } else {
  99. $currentId = $this->id;
  100. }
  101. // prepares the request
  102. $request = array(
  103. 'method' => $method,
  104. 'params' => $params,
  105. 'id' => $currentId
  106. );
  107. $request = json_encode($request);
  108. $this->debug && $this->debug.='***** Request *****'."\n".$request."\n".'***** End Of request *****'."\n\n";
  109. // performs the HTTP POST
  110. $opts = array ('http' => array (
  111. 'method' => 'POST',
  112. 'header' => 'Content-type: application/json',
  113. 'content' => $request
  114. ));
  115. $context = stream_context_create($opts);
  116. if ($fp = fopen($this->url, 'r', false, $context)) {
  117. $response = '';
  118. while($row = fgets($fp)) {
  119. $response.= trim($row)."\n";
  120. }
  121. $this->debug && $this->debug.='***** Server response *****'."\n".$response.'***** End of server response *****'."\n";
  122. $response = json_decode($response,true);
  123. } else {
  124. throw new Exception('Unable to connect to '.$this->url);
  125. }
  126. // debug output
  127. if ($this->debug) {
  128. echo nl2br($debug);
  129. }
  130. // final checks and return
  131. if (!$this->notification) {
  132. // check
  133. if ($response['id'] != $currentId) {
  134. throw new Exception('Incorrect response id (request id: '.$currentId.', response id: '.$response['id'].')');
  135. }
  136. if (!is_null($response['error'])) {
  137. throw new Exception('Request error: '.$response['error']);
  138. }
  139. return $response['result'];
  140. } else {
  141. return true;
  142. }
  143. }
  144. }
  145. ?>

comments powered by Disqus