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 single message and then gets a 24*cc02d7e2SAndroid Build Coastguard Worker * stream of responses. 25*cc02d7e2SAndroid Build Coastguard Worker */ 26*cc02d7e2SAndroid Build Coastguard Workerclass ServerStreamingCall 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 mixed $data The data to send 32*cc02d7e2SAndroid Build Coastguard Worker * @param array $metadata Metadata to send with the call, if applicable 33*cc02d7e2SAndroid Build Coastguard Worker * (optional) 34*cc02d7e2SAndroid Build Coastguard Worker * @param array $options An array of options, possible keys: 35*cc02d7e2SAndroid Build Coastguard Worker * 'flags' => a number (optional) 36*cc02d7e2SAndroid Build Coastguard Worker */ 37*cc02d7e2SAndroid Build Coastguard Worker public function start($data, array $metadata = [], array $options = []) 38*cc02d7e2SAndroid Build Coastguard Worker { 39*cc02d7e2SAndroid Build Coastguard Worker $message_array = ['message' => $this->_serializeMessage($data)]; 40*cc02d7e2SAndroid Build Coastguard Worker if (array_key_exists('flags', $options)) { 41*cc02d7e2SAndroid Build Coastguard Worker $message_array['flags'] = $options['flags']; 42*cc02d7e2SAndroid Build Coastguard Worker } 43*cc02d7e2SAndroid Build Coastguard Worker $this->call->startBatch([ 44*cc02d7e2SAndroid Build Coastguard Worker OP_SEND_INITIAL_METADATA => $metadata, 45*cc02d7e2SAndroid Build Coastguard Worker OP_SEND_MESSAGE => $message_array, 46*cc02d7e2SAndroid Build Coastguard Worker OP_SEND_CLOSE_FROM_CLIENT => true, 47*cc02d7e2SAndroid Build Coastguard Worker ]); 48*cc02d7e2SAndroid Build Coastguard Worker } 49*cc02d7e2SAndroid Build Coastguard Worker 50*cc02d7e2SAndroid Build Coastguard Worker /** 51*cc02d7e2SAndroid Build Coastguard Worker * @return mixed An iterator of response values 52*cc02d7e2SAndroid Build Coastguard Worker */ 53*cc02d7e2SAndroid Build Coastguard Worker public function responses() 54*cc02d7e2SAndroid Build Coastguard Worker { 55*cc02d7e2SAndroid Build Coastguard Worker $batch = [OP_RECV_MESSAGE => true]; 56*cc02d7e2SAndroid Build Coastguard Worker if ($this->metadata === null) { 57*cc02d7e2SAndroid Build Coastguard Worker $batch[OP_RECV_INITIAL_METADATA] = true; 58*cc02d7e2SAndroid Build Coastguard Worker } 59*cc02d7e2SAndroid Build Coastguard Worker $read_event = $this->call->startBatch($batch); 60*cc02d7e2SAndroid Build Coastguard Worker if ($this->metadata === null) { 61*cc02d7e2SAndroid Build Coastguard Worker $this->metadata = $read_event->metadata; 62*cc02d7e2SAndroid Build Coastguard Worker } 63*cc02d7e2SAndroid Build Coastguard Worker $response = $read_event->message; 64*cc02d7e2SAndroid Build Coastguard Worker while ($response !== null) { 65*cc02d7e2SAndroid Build Coastguard Worker yield $this->_deserializeResponse($response); 66*cc02d7e2SAndroid Build Coastguard Worker $response = $this->call->startBatch([ 67*cc02d7e2SAndroid Build Coastguard Worker OP_RECV_MESSAGE => true, 68*cc02d7e2SAndroid Build Coastguard Worker ])->message; 69*cc02d7e2SAndroid Build Coastguard Worker } 70*cc02d7e2SAndroid Build Coastguard Worker } 71*cc02d7e2SAndroid Build Coastguard Worker 72*cc02d7e2SAndroid Build Coastguard Worker /** 73*cc02d7e2SAndroid Build Coastguard Worker * Wait for the server to send the status, and return it. 74*cc02d7e2SAndroid Build Coastguard Worker * 75*cc02d7e2SAndroid Build Coastguard Worker * @return \stdClass The status object, with integer $code, string 76*cc02d7e2SAndroid Build Coastguard Worker * $details, and array $metadata members 77*cc02d7e2SAndroid Build Coastguard Worker */ 78*cc02d7e2SAndroid Build Coastguard Worker public function getStatus() 79*cc02d7e2SAndroid Build Coastguard Worker { 80*cc02d7e2SAndroid Build Coastguard Worker $status_event = $this->call->startBatch([ 81*cc02d7e2SAndroid Build Coastguard Worker OP_RECV_STATUS_ON_CLIENT => true, 82*cc02d7e2SAndroid Build Coastguard Worker ]); 83*cc02d7e2SAndroid Build Coastguard Worker 84*cc02d7e2SAndroid Build Coastguard Worker $this->trailing_metadata = $status_event->status->metadata; 85*cc02d7e2SAndroid Build Coastguard Worker 86*cc02d7e2SAndroid Build Coastguard Worker return $status_event->status; 87*cc02d7e2SAndroid Build Coastguard Worker } 88*cc02d7e2SAndroid Build Coastguard Worker 89*cc02d7e2SAndroid Build Coastguard Worker /** 90*cc02d7e2SAndroid Build Coastguard Worker * @return mixed The metadata sent by the server 91*cc02d7e2SAndroid Build Coastguard Worker */ 92*cc02d7e2SAndroid Build Coastguard Worker public function getMetadata() 93*cc02d7e2SAndroid Build Coastguard Worker { 94*cc02d7e2SAndroid Build Coastguard Worker if ($this->metadata === null) { 95*cc02d7e2SAndroid Build Coastguard Worker $event = $this->call->startBatch([OP_RECV_INITIAL_METADATA => true]); 96*cc02d7e2SAndroid Build Coastguard Worker $this->metadata = $event->metadata; 97*cc02d7e2SAndroid Build Coastguard Worker } 98*cc02d7e2SAndroid Build Coastguard Worker return $this->metadata; 99*cc02d7e2SAndroid Build Coastguard Worker } 100*cc02d7e2SAndroid Build Coastguard Worker} 101