blob: f0e1e811def73d4fb7e86f81846948b0dac0dabc [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/**
murgatroid999140a062015-03-26 11:27:58 -070038 * Represents an active call that allows for sending and recieving messages in
39 * 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
47 */
Stanislav Pavlovichevd58199b2016-08-23 23:20:34 +070048 public function start(array $metadata = [])
Stanley Cheungd5b20562015-10-27 13:27:05 -070049 {
50 $this->call->startBatch([
51 OP_SEND_INITIAL_METADATA => $metadata,
52 ]);
murgatroid99d8cc6b82015-04-01 11:14:16 -070053 }
Stanley Cheungd5b20562015-10-27 13:27:05 -070054
55 /**
56 * Reads the next value from the server.
57 *
Stanislav Pavlovichevd58199b2016-08-23 23:20:34 +070058 * @return mixed The next value from the server, or null if there is none
Stanley Cheungd5b20562015-10-27 13:27:05 -070059 */
60 public function read()
61 {
62 $batch = [OP_RECV_MESSAGE => true];
63 if ($this->metadata === null) {
64 $batch[OP_RECV_INITIAL_METADATA] = true;
65 }
66 $read_event = $this->call->startBatch($batch);
67 if ($this->metadata === null) {
68 $this->metadata = $read_event->metadata;
69 }
70
71 return $this->deserializeResponse($read_event->message);
murgatroid99d8cc6b82015-04-01 11:14:16 -070072 }
mlumishb892a272014-12-09 16:28:23 -080073
Stanley Cheungd5b20562015-10-27 13:27:05 -070074 /**
75 * Write a single message to the server. This cannot be called after
76 * writesDone is called.
77 *
78 * @param ByteBuffer $data The data to write
79 * @param array $options an array of options, possible keys:
80 * 'flags' => a number
81 */
82 public function write($data, $options = [])
83 {
Stanley Cheung881f4ff2016-09-22 16:15:58 -070084 $message_array = ['message' => $this->serializeMessage($data)];
Stanislav Pavlovichevd58199b2016-08-23 23:20:34 +070085 if (array_key_exists('flags', $options)) {
Stanley Cheungd5b20562015-10-27 13:27:05 -070086 $message_array['flags'] = $options['flags'];
87 }
88 $this->call->startBatch([
89 OP_SEND_MESSAGE => $message_array,
90 ]);
Stanley Cheung3ab8e792015-08-24 16:58:42 -070091 }
mlumishb892a272014-12-09 16:28:23 -080092
Stanley Cheungd5b20562015-10-27 13:27:05 -070093 /**
94 * Indicate that no more writes will be sent.
95 */
96 public function writesDone()
97 {
98 $this->call->startBatch([
99 OP_SEND_CLOSE_FROM_CLIENT => true,
100 ]);
101 }
mlumishb892a272014-12-09 16:28:23 -0800102
Stanley Cheungd5b20562015-10-27 13:27:05 -0700103 /**
104 * Wait for the server to send the status, and return it.
105 *
Stanislav Pavlovichevd58199b2016-08-23 23:20:34 +0700106 * @return \stdClass The status object, with integer $code, string $details,
107 * and array $metadata members
Stanley Cheungd5b20562015-10-27 13:27:05 -0700108 */
109 public function getStatus()
110 {
111 $status_event = $this->call->startBatch([
112 OP_RECV_STATUS_ON_CLIENT => true,
113 ]);
114
Stanley Cheung6668d512016-05-18 14:05:09 -0700115 $this->trailing_metadata = $status_event->status->metadata;
thinkeroua3730b72016-07-20 16:59:54 +0800116
Stanley Cheungd5b20562015-10-27 13:27:05 -0700117 return $status_event->status;
118 }
119}