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