xref: /aosp_15_r20/external/grpc-grpc/src/php/lib/Grpc/BidiStreamingCall.php (revision cc02d7e222339f7a4f6ba5f422e6413f4bd931f2)
1*cc02d7e2SAndroid Build Coastguard Worker<?php
2*cc02d7e2SAndroid Build Coastguard Worker/*
3*cc02d7e2SAndroid Build Coastguard Worker *
4*cc02d7e2SAndroid Build Coastguard Worker * Copyright 2015 gRPC authors.
5*cc02d7e2SAndroid Build Coastguard Worker *
6*cc02d7e2SAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License");
7*cc02d7e2SAndroid Build Coastguard Worker * you may not use this file except in compliance with the License.
8*cc02d7e2SAndroid Build Coastguard Worker * You may obtain a copy of the License at
9*cc02d7e2SAndroid Build Coastguard Worker *
10*cc02d7e2SAndroid Build Coastguard Worker *     http://www.apache.org/licenses/LICENSE-2.0
11*cc02d7e2SAndroid Build Coastguard Worker *
12*cc02d7e2SAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software
13*cc02d7e2SAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS,
14*cc02d7e2SAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15*cc02d7e2SAndroid Build Coastguard Worker * See the License for the specific language governing permissions and
16*cc02d7e2SAndroid Build Coastguard Worker * limitations under the License.
17*cc02d7e2SAndroid Build Coastguard Worker *
18*cc02d7e2SAndroid Build Coastguard Worker */
19*cc02d7e2SAndroid Build Coastguard Worker
20*cc02d7e2SAndroid Build Coastguard Workernamespace Grpc;
21*cc02d7e2SAndroid Build Coastguard Worker
22*cc02d7e2SAndroid Build Coastguard Worker/**
23*cc02d7e2SAndroid Build Coastguard Worker * Represents an active call that allows for sending and receiving messages
24*cc02d7e2SAndroid Build Coastguard Worker * in streams in any order.
25*cc02d7e2SAndroid Build Coastguard Worker */
26*cc02d7e2SAndroid Build Coastguard Workerclass BidiStreamingCall extends AbstractCall
27*cc02d7e2SAndroid Build Coastguard Worker{
28*cc02d7e2SAndroid Build Coastguard Worker    /**
29*cc02d7e2SAndroid Build Coastguard Worker     * Start the call.
30*cc02d7e2SAndroid Build Coastguard Worker     *
31*cc02d7e2SAndroid Build Coastguard Worker     * @param array $metadata Metadata to send with the call, if applicable
32*cc02d7e2SAndroid Build Coastguard Worker     *                        (optional)
33*cc02d7e2SAndroid Build Coastguard Worker     */
34*cc02d7e2SAndroid Build Coastguard Worker    public function start(array $metadata = [])
35*cc02d7e2SAndroid Build Coastguard Worker    {
36*cc02d7e2SAndroid Build Coastguard Worker        $this->call->startBatch([
37*cc02d7e2SAndroid Build Coastguard Worker            OP_SEND_INITIAL_METADATA => $metadata,
38*cc02d7e2SAndroid Build Coastguard Worker        ]);
39*cc02d7e2SAndroid Build Coastguard Worker    }
40*cc02d7e2SAndroid Build Coastguard Worker
41*cc02d7e2SAndroid Build Coastguard Worker    /**
42*cc02d7e2SAndroid Build Coastguard Worker     * Reads the next value from the server.
43*cc02d7e2SAndroid Build Coastguard Worker     *
44*cc02d7e2SAndroid Build Coastguard Worker     * @return mixed The next value from the server, or null if there is none
45*cc02d7e2SAndroid Build Coastguard Worker     */
46*cc02d7e2SAndroid Build Coastguard Worker    public function read()
47*cc02d7e2SAndroid Build Coastguard Worker    {
48*cc02d7e2SAndroid Build Coastguard Worker        $batch = [OP_RECV_MESSAGE => true];
49*cc02d7e2SAndroid Build Coastguard Worker        if ($this->metadata === null) {
50*cc02d7e2SAndroid Build Coastguard Worker            $batch[OP_RECV_INITIAL_METADATA] = true;
51*cc02d7e2SAndroid Build Coastguard Worker        }
52*cc02d7e2SAndroid Build Coastguard Worker        $read_event = $this->call->startBatch($batch);
53*cc02d7e2SAndroid Build Coastguard Worker        if ($this->metadata === null) {
54*cc02d7e2SAndroid Build Coastguard Worker            $this->metadata = $read_event->metadata;
55*cc02d7e2SAndroid Build Coastguard Worker        }
56*cc02d7e2SAndroid Build Coastguard Worker
57*cc02d7e2SAndroid Build Coastguard Worker        return $this->_deserializeResponse($read_event->message);
58*cc02d7e2SAndroid Build Coastguard Worker    }
59*cc02d7e2SAndroid Build Coastguard Worker
60*cc02d7e2SAndroid Build Coastguard Worker    /**
61*cc02d7e2SAndroid Build Coastguard Worker     * Write a single message to the server. This cannot be called after
62*cc02d7e2SAndroid Build Coastguard Worker     * writesDone is called.
63*cc02d7e2SAndroid Build Coastguard Worker     *
64*cc02d7e2SAndroid Build Coastguard Worker     * @param ByteBuffer $data    The data to write
65*cc02d7e2SAndroid Build Coastguard Worker     * @param array      $options An array of options, possible keys:
66*cc02d7e2SAndroid Build Coastguard Worker     *                            'flags' => a number (optional)
67*cc02d7e2SAndroid Build Coastguard Worker     */
68*cc02d7e2SAndroid Build Coastguard Worker    public function write($data, array $options = [])
69*cc02d7e2SAndroid Build Coastguard Worker    {
70*cc02d7e2SAndroid Build Coastguard Worker        $message_array = ['message' => $this->_serializeMessage($data)];
71*cc02d7e2SAndroid Build Coastguard Worker        if (array_key_exists('flags', $options)) {
72*cc02d7e2SAndroid Build Coastguard Worker            $message_array['flags'] = $options['flags'];
73*cc02d7e2SAndroid Build Coastguard Worker        }
74*cc02d7e2SAndroid Build Coastguard Worker        $this->call->startBatch([
75*cc02d7e2SAndroid Build Coastguard Worker            OP_SEND_MESSAGE => $message_array,
76*cc02d7e2SAndroid Build Coastguard Worker        ]);
77*cc02d7e2SAndroid Build Coastguard Worker    }
78*cc02d7e2SAndroid Build Coastguard Worker
79*cc02d7e2SAndroid Build Coastguard Worker    /**
80*cc02d7e2SAndroid Build Coastguard Worker     * Indicate that no more writes will be sent.
81*cc02d7e2SAndroid Build Coastguard Worker     */
82*cc02d7e2SAndroid Build Coastguard Worker    public function writesDone()
83*cc02d7e2SAndroid Build Coastguard Worker    {
84*cc02d7e2SAndroid Build Coastguard Worker        $this->call->startBatch([
85*cc02d7e2SAndroid Build Coastguard Worker            OP_SEND_CLOSE_FROM_CLIENT => true,
86*cc02d7e2SAndroid Build Coastguard Worker        ]);
87*cc02d7e2SAndroid Build Coastguard Worker    }
88*cc02d7e2SAndroid Build Coastguard Worker
89*cc02d7e2SAndroid Build Coastguard Worker    /**
90*cc02d7e2SAndroid Build Coastguard Worker     * Wait for the server to send the status, and return it.
91*cc02d7e2SAndroid Build Coastguard Worker     *
92*cc02d7e2SAndroid Build Coastguard Worker     * @return \stdClass The status object, with integer $code, string
93*cc02d7e2SAndroid Build Coastguard Worker     *                   $details, and array $metadata members
94*cc02d7e2SAndroid Build Coastguard Worker     */
95*cc02d7e2SAndroid Build Coastguard Worker    public function getStatus()
96*cc02d7e2SAndroid Build Coastguard Worker    {
97*cc02d7e2SAndroid Build Coastguard Worker        $status_event = $this->call->startBatch([
98*cc02d7e2SAndroid Build Coastguard Worker            OP_RECV_STATUS_ON_CLIENT => true,
99*cc02d7e2SAndroid Build Coastguard Worker        ]);
100*cc02d7e2SAndroid Build Coastguard Worker
101*cc02d7e2SAndroid Build Coastguard Worker        $this->trailing_metadata = $status_event->status->metadata;
102*cc02d7e2SAndroid Build Coastguard Worker
103*cc02d7e2SAndroid Build Coastguard Worker        return $status_event->status;
104*cc02d7e2SAndroid Build Coastguard Worker    }
105*cc02d7e2SAndroid Build Coastguard Worker}
106