blob: b03bbd204fb447b9efd90efcdf67f7506926093b [file] [log] [blame]
mlumishb892a272014-12-09 16:28:23 -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
mlumishb892a272014-12-09 16:28:23 -080035namespace Grpc;
36
37/**
thinkerou0c3e8db2016-12-15 00:27:03 +080038 * Represents an active call that allows for sending and recieving messages
39 * in streams in any order.
mlumishb892a272014-12-09 16:28:23 -080040 */
Stanley Cheungd5b20562015-10-27 13:27:05 -070041class BidiStreamingCall extends AbstractCall
42{
43 /**
44 * Start the call.
45 *
46 * @param array $metadata Metadata to send with the call, if applicable
thinkerou0c3e8db2016-12-15 00:27:03 +080047 * (optional)
Stanley Cheungd5b20562015-10-27 13:27:05 -070048 */
Stanislav Pavlovichevd58199b2016-08-23 23:20:34 +070049 public function start(array $metadata = [])
Stanley Cheungd5b20562015-10-27 13:27:05 -070050 {
51 $this->call->startBatch([
52 OP_SEND_INITIAL_METADATA => $metadata,
53 ]);
murgatroid99d8cc6b82015-04-01 11:14:16 -070054 }
Stanley Cheungd5b20562015-10-27 13:27:05 -070055
56 /**
57 * Reads the next value from the server.
58 *
Stanislav Pavlovichevd58199b2016-08-23 23:20:34 +070059 * @return mixed The next value from the server, or null if there is none
Stanley Cheungd5b20562015-10-27 13:27:05 -070060 */
61 public function read()
62 {
63 $batch = [OP_RECV_MESSAGE => true];
64 if ($this->metadata === null) {
65 $batch[OP_RECV_INITIAL_METADATA] = true;
66 }
67 $read_event = $this->call->startBatch($batch);
68 if ($this->metadata === null) {
69 $this->metadata = $read_event->metadata;
70 }
71
72 return $this->deserializeResponse($read_event->message);
murgatroid99d8cc6b82015-04-01 11:14:16 -070073 }
mlumishb892a272014-12-09 16:28:23 -080074
Stanley Cheungd5b20562015-10-27 13:27:05 -070075 /**
76 * Write a single message to the server. This cannot be called after
77 * writesDone is called.
78 *
79 * @param ByteBuffer $data The data to write
thinkerou0c3e8db2016-12-15 00:27:03 +080080 * @param array $options An array of options, possible keys:
81 * 'flags' => a number (optional)
Stanley Cheungd5b20562015-10-27 13:27:05 -070082 */
thinkerou0c3e8db2016-12-15 00:27:03 +080083 public function write($data, array $options = [])
Stanley Cheungd5b20562015-10-27 13:27:05 -070084 {
Stanley Cheung881f4ff2016-09-22 16:15:58 -070085 $message_array = ['message' => $this->serializeMessage($data)];
Stanislav Pavlovichevd58199b2016-08-23 23:20:34 +070086 if (array_key_exists('flags', $options)) {
Stanley Cheungd5b20562015-10-27 13:27:05 -070087 $message_array['flags'] = $options['flags'];
88 }
89 $this->call->startBatch([
90 OP_SEND_MESSAGE => $message_array,
91 ]);
Stanley Cheung3ab8e792015-08-24 16:58:42 -070092 }
mlumishb892a272014-12-09 16:28:23 -080093
Stanley Cheungd5b20562015-10-27 13:27:05 -070094 /**
95 * Indicate that no more writes will be sent.
96 */
97 public function writesDone()
98 {
99 $this->call->startBatch([
100 OP_SEND_CLOSE_FROM_CLIENT => true,
101 ]);
102 }
mlumishb892a272014-12-09 16:28:23 -0800103
Stanley Cheungd5b20562015-10-27 13:27:05 -0700104 /**
105 * Wait for the server to send the status, and return it.
106 *
thinkerou0c3e8db2016-12-15 00:27:03 +0800107 * @return \stdClass The status object, with integer $code, string
108 * $details, and array $metadata members
Stanley Cheungd5b20562015-10-27 13:27:05 -0700109 */
110 public function getStatus()
111 {
112 $status_event = $this->call->startBatch([
113 OP_RECV_STATUS_ON_CLIENT => true,
114 ]);
115
Stanley Cheung6668d512016-05-18 14:05:09 -0700116 $this->trailing_metadata = $status_event->status->metadata;
thinkeroua3730b72016-07-20 16:59:54 +0800117
Stanley Cheungd5b20562015-10-27 13:27:05 -0700118 return $status_event->status;
119 }
120}