blob: 1d51a8e66caa4af3225534a5482ac002c491e3c4 [file] [log] [blame]
mlumish156e67d2015-01-02 14:59:16 -08001<?php
Craig Tiller2e498aa2015-02-16 12:09:31 -08002/*
3 *
4 * Copyright 2015, Google Inc.
5 * All rights reserved.
6 *
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions are
9 * met:
10 *
11 * * Redistributions of source code must retain the above copyright
12 * notice, this list of conditions and the following disclaimer.
13 * * Redistributions in binary form must reproduce the above
14 * copyright notice, this list of conditions and the following disclaimer
15 * in the documentation and/or other materials provided with the
16 * distribution.
17 * * Neither the name of Google Inc. nor the names of its
18 * contributors may be used to endorse or promote products derived from
19 * this software without specific prior written permission.
20 *
21 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
24 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
25 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
26 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
27 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
28 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
29 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
30 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
31 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32 *
33 */
Stanley Cheungd5b20562015-10-27 13:27:05 -070034
mlumish156e67d2015-01-02 14:59:16 -080035namespace Grpc;
murgatroid999140a062015-03-26 11:27:58 -070036
Stanislav Pavlovichevd58199b2016-08-23 23:20:34 +070037/**
thinkerou9a669b62016-11-01 21:31:43 +080038 * Class AbstractCall.
Stanislav Pavlovichevd58199b2016-08-23 23:20:34 +070039 * @package Grpc
40 */
Stanley Cheungd5b20562015-10-27 13:27:05 -070041abstract class AbstractCall
42{
Stanislav Pavlovichevd58199b2016-08-23 23:20:34 +070043 /**
44 * @var Call
45 */
Stanley Cheungd5b20562015-10-27 13:27:05 -070046 protected $call;
47 protected $deserialize;
48 protected $metadata;
Stanley Cheung6668d512016-05-18 14:05:09 -070049 protected $trailing_metadata;
murgatroid999140a062015-03-26 11:27:58 -070050
Stanley Cheungd5b20562015-10-27 13:27:05 -070051 /**
52 * Create a new Call wrapper object.
53 *
Stanley Cheung35805802015-12-10 11:42:55 -080054 * @param Channel $channel The channel to communicate on
55 * @param string $method The method to call on the
56 * remote server
57 * @param callback $deserialize A callback function to deserialize
58 * the response
59 * @param array $options Call options (optional)
Stanley Cheungd5b20562015-10-27 13:27:05 -070060 */
thinkerou16713db2017-01-20 14:43:19 +080061 public function __construct(Channel $channel,
62 $method,
63 $deserialize,
64 array $options = [])
65 {
Stanislav Pavlovichevd58199b2016-08-23 23:20:34 +070066 if (array_key_exists('timeout', $options) &&
67 is_numeric($timeout = $options['timeout'])
68 ) {
Stanley Cheungd5b20562015-10-27 13:27:05 -070069 $now = Timeval::now();
70 $delta = new Timeval($timeout);
71 $deadline = $now->add($delta);
72 } else {
73 $deadline = Timeval::infFuture();
74 }
75 $this->call = new Call($channel, $method, $deadline);
76 $this->deserialize = $deserialize;
77 $this->metadata = null;
Stanley Cheung6668d512016-05-18 14:05:09 -070078 $this->trailing_metadata = null;
Stanislav Pavlovichevd58199b2016-08-23 23:20:34 +070079 if (array_key_exists('call_credentials_callback', $options) &&
Stanley Cheung35805802015-12-10 11:42:55 -080080 is_callable($call_credentials_callback =
Stanislav Pavlovichevd58199b2016-08-23 23:20:34 +070081 $options['call_credentials_callback'])
82 ) {
Stanley Cheung35805802015-12-10 11:42:55 -080083 $call_credentials = CallCredentials::createFromPlugin(
Stanislav Pavlovichevd58199b2016-08-23 23:20:34 +070084 $call_credentials_callback
85 );
Stanley Cheung35805802015-12-10 11:42:55 -080086 $this->call->setCredentials($call_credentials);
87 }
Stanley Cheungcc019af2015-06-15 11:45:00 -070088 }
mlumish156e67d2015-01-02 14:59:16 -080089
Stanley Cheungd5b20562015-10-27 13:27:05 -070090 /**
thinkerou0c3e8db2016-12-15 00:27:03 +080091 * @return mixed The metadata sent by the server
Stanley Cheungd5b20562015-10-27 13:27:05 -070092 */
93 public function getMetadata()
94 {
95 return $this->metadata;
murgatroid999140a062015-03-26 11:27:58 -070096 }
Stanley Cheungd5b20562015-10-27 13:27:05 -070097
98 /**
thinkerou0c3e8db2016-12-15 00:27:03 +080099 * @return mixed The trailing metadata sent by the server
Stanley Cheung6668d512016-05-18 14:05:09 -0700100 */
101 public function getTrailingMetadata()
102 {
103 return $this->trailing_metadata;
104 }
105
106 /**
thinkerou0c3e8db2016-12-15 00:27:03 +0800107 * @return string The URI of the endpoint
Stanley Cheungd5b20562015-10-27 13:27:05 -0700108 */
109 public function getPeer()
110 {
111 return $this->call->getPeer();
112 }
113
114 /**
115 * Cancels the call.
116 */
117 public function cancel()
118 {
119 $this->call->cancel();
120 }
121
122 /**
thinkerou9a669b62016-11-01 21:31:43 +0800123 * Serialize a message to the protobuf binary format.
Stanley Cheung881f4ff2016-09-22 16:15:58 -0700124 *
125 * @param mixed $data The Protobuf message
126 *
127 * @return string The protobuf binary format
128 */
thinkerou9a669b62016-11-01 21:31:43 +0800129 protected function serializeMessage($data)
130 {
Stanley Cheung881f4ff2016-09-22 16:15:58 -0700131 // Proto3 implementation
132 if (method_exists($data, 'encode')) {
133 return $data->encode();
134 }
135
136 // Protobuf-PHP implementation
137 return $data->serialize();
138 }
139
140 /**
Stanley Cheungd5b20562015-10-27 13:27:05 -0700141 * Deserialize a response value to an object.
142 *
143 * @param string $value The binary value to deserialize
144 *
Stanislav Pavlovichevd58199b2016-08-23 23:20:34 +0700145 * @return mixed The deserialized value
Stanley Cheungd5b20562015-10-27 13:27:05 -0700146 */
147 protected function deserializeResponse($value)
148 {
149 if ($value === null) {
150 return;
151 }
152
Stanley Cheung881f4ff2016-09-22 16:15:58 -0700153 // Proto3 implementation
154 if (is_array($this->deserialize)) {
155 list($className, $deserializeFunc) = $this->deserialize;
156 $obj = new $className();
157 $obj->$deserializeFunc($value);
thinkerou9a669b62016-11-01 21:31:43 +0800158
Stanley Cheung881f4ff2016-09-22 16:15:58 -0700159 return $obj;
160 }
161
162 // Protobuf-PHP implementation
Stanley Cheungd5b20562015-10-27 13:27:05 -0700163 return call_user_func($this->deserialize, $value);
164 }
Stanley Cheung6bd31802015-12-16 12:58:19 -0800165
166 /**
167 * Set the CallCredentials for the underlying Call.
168 *
thinkerou0c3e8db2016-12-15 00:27:03 +0800169 * @param CallCredentials $call_credentials The CallCredentials object
Stanley Cheung6bd31802015-12-16 12:58:19 -0800170 */
171 public function setCallCredentials($call_credentials)
172 {
173 $this->call->setCredentials($call_credentials);
174 }
Stanley Cheung3ab8e792015-08-24 16:58:42 -0700175}