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 sends a stream of messages and then gets 24*cc02d7e2SAndroid Build Coastguard Worker * a single response. 25*cc02d7e2SAndroid Build Coastguard Worker */ 26*cc02d7e2SAndroid Build Coastguard Workerclass ClientStreamingCall 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 * Write a single message to the server. This cannot be called after 43*cc02d7e2SAndroid Build Coastguard Worker * wait is called. 44*cc02d7e2SAndroid Build Coastguard Worker * 45*cc02d7e2SAndroid Build Coastguard Worker * @param ByteBuffer $data The data to write 46*cc02d7e2SAndroid Build Coastguard Worker * @param array $options An array of options, possible keys: 47*cc02d7e2SAndroid Build Coastguard Worker * 'flags' => a number (optional) 48*cc02d7e2SAndroid Build Coastguard Worker */ 49*cc02d7e2SAndroid Build Coastguard Worker public function write($data, array $options = []) 50*cc02d7e2SAndroid Build Coastguard Worker { 51*cc02d7e2SAndroid Build Coastguard Worker $message_array = ['message' => $this->_serializeMessage($data)]; 52*cc02d7e2SAndroid Build Coastguard Worker if (array_key_exists('flags', $options)) { 53*cc02d7e2SAndroid Build Coastguard Worker $message_array['flags'] = $options['flags']; 54*cc02d7e2SAndroid Build Coastguard Worker } 55*cc02d7e2SAndroid Build Coastguard Worker $this->call->startBatch([ 56*cc02d7e2SAndroid Build Coastguard Worker OP_SEND_MESSAGE => $message_array, 57*cc02d7e2SAndroid Build Coastguard Worker ]); 58*cc02d7e2SAndroid Build Coastguard Worker } 59*cc02d7e2SAndroid Build Coastguard Worker 60*cc02d7e2SAndroid Build Coastguard Worker /** 61*cc02d7e2SAndroid Build Coastguard Worker * Wait for the server to respond with data and a status. 62*cc02d7e2SAndroid Build Coastguard Worker * 63*cc02d7e2SAndroid Build Coastguard Worker * @return array [response data, status] 64*cc02d7e2SAndroid Build Coastguard Worker */ 65*cc02d7e2SAndroid Build Coastguard Worker public function wait() 66*cc02d7e2SAndroid Build Coastguard Worker { 67*cc02d7e2SAndroid Build Coastguard Worker $event = $this->call->startBatch([ 68*cc02d7e2SAndroid Build Coastguard Worker OP_SEND_CLOSE_FROM_CLIENT => true, 69*cc02d7e2SAndroid Build Coastguard Worker OP_RECV_INITIAL_METADATA => true, 70*cc02d7e2SAndroid Build Coastguard Worker OP_RECV_MESSAGE => true, 71*cc02d7e2SAndroid Build Coastguard Worker OP_RECV_STATUS_ON_CLIENT => true, 72*cc02d7e2SAndroid Build Coastguard Worker ]); 73*cc02d7e2SAndroid Build Coastguard Worker $this->metadata = $event->metadata; 74*cc02d7e2SAndroid Build Coastguard Worker 75*cc02d7e2SAndroid Build Coastguard Worker $status = $event->status; 76*cc02d7e2SAndroid Build Coastguard Worker $this->trailing_metadata = $status->metadata; 77*cc02d7e2SAndroid Build Coastguard Worker 78*cc02d7e2SAndroid Build Coastguard Worker return [$this->_deserializeResponse($event->message), $status]; 79*cc02d7e2SAndroid Build Coastguard Worker } 80*cc02d7e2SAndroid Build Coastguard Worker} 81