xref: /aosp_15_r20/external/grpc-grpc/src/php/lib/Grpc/ServerCallWriter.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 2020 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 * This is an experimental and incomplete implementation of gRPC server
24*cc02d7e2SAndroid Build Coastguard Worker * for PHP. APIs are _definitely_ going to be changed.
25*cc02d7e2SAndroid Build Coastguard Worker *
26*cc02d7e2SAndroid Build Coastguard Worker * DO NOT USE in production.
27*cc02d7e2SAndroid Build Coastguard Worker */
28*cc02d7e2SAndroid Build Coastguard Worker
29*cc02d7e2SAndroid Build Coastguard Workerclass ServerCallWriter
30*cc02d7e2SAndroid Build Coastguard Worker{
31*cc02d7e2SAndroid Build Coastguard Worker    public function __construct($call, $serverContext)
32*cc02d7e2SAndroid Build Coastguard Worker    {
33*cc02d7e2SAndroid Build Coastguard Worker        $this->call_ = $call;
34*cc02d7e2SAndroid Build Coastguard Worker        $this->serverContext_ = $serverContext;
35*cc02d7e2SAndroid Build Coastguard Worker    }
36*cc02d7e2SAndroid Build Coastguard Worker
37*cc02d7e2SAndroid Build Coastguard Worker    public function start(
38*cc02d7e2SAndroid Build Coastguard Worker        $data = null,
39*cc02d7e2SAndroid Build Coastguard Worker        array $options = []
40*cc02d7e2SAndroid Build Coastguard Worker    ) {
41*cc02d7e2SAndroid Build Coastguard Worker        $batch = [];
42*cc02d7e2SAndroid Build Coastguard Worker        $this->addSendInitialMetadataOpIfNotSent(
43*cc02d7e2SAndroid Build Coastguard Worker            $batch,
44*cc02d7e2SAndroid Build Coastguard Worker            $this->serverContext_->initialMetadata()
45*cc02d7e2SAndroid Build Coastguard Worker        );
46*cc02d7e2SAndroid Build Coastguard Worker        $this->addSendMessageOpIfHasData($batch, $data, $options);
47*cc02d7e2SAndroid Build Coastguard Worker        $this->call_->startBatch($batch);
48*cc02d7e2SAndroid Build Coastguard Worker    }
49*cc02d7e2SAndroid Build Coastguard Worker
50*cc02d7e2SAndroid Build Coastguard Worker    public function write(
51*cc02d7e2SAndroid Build Coastguard Worker        $data,
52*cc02d7e2SAndroid Build Coastguard Worker        array $options = []
53*cc02d7e2SAndroid Build Coastguard Worker    ) {
54*cc02d7e2SAndroid Build Coastguard Worker        $batch = [];
55*cc02d7e2SAndroid Build Coastguard Worker        $this->addSendInitialMetadataOpIfNotSent(
56*cc02d7e2SAndroid Build Coastguard Worker            $batch,
57*cc02d7e2SAndroid Build Coastguard Worker            $this->serverContext_->initialMetadata()
58*cc02d7e2SAndroid Build Coastguard Worker        );
59*cc02d7e2SAndroid Build Coastguard Worker        $this->addSendMessageOpIfHasData($batch, $data, $options);
60*cc02d7e2SAndroid Build Coastguard Worker        $this->call_->startBatch($batch);
61*cc02d7e2SAndroid Build Coastguard Worker    }
62*cc02d7e2SAndroid Build Coastguard Worker
63*cc02d7e2SAndroid Build Coastguard Worker    public function finish(
64*cc02d7e2SAndroid Build Coastguard Worker        $data = null,
65*cc02d7e2SAndroid Build Coastguard Worker        array $options = []
66*cc02d7e2SAndroid Build Coastguard Worker    ) {
67*cc02d7e2SAndroid Build Coastguard Worker        $batch = [
68*cc02d7e2SAndroid Build Coastguard Worker            OP_SEND_STATUS_FROM_SERVER =>
69*cc02d7e2SAndroid Build Coastguard Worker            $this->serverContext_->status() ?? Status::ok(),
70*cc02d7e2SAndroid Build Coastguard Worker            OP_RECV_CLOSE_ON_SERVER => true,
71*cc02d7e2SAndroid Build Coastguard Worker        ];
72*cc02d7e2SAndroid Build Coastguard Worker        $this->addSendInitialMetadataOpIfNotSent(
73*cc02d7e2SAndroid Build Coastguard Worker            $batch,
74*cc02d7e2SAndroid Build Coastguard Worker            $this->serverContext_->initialMetadata()
75*cc02d7e2SAndroid Build Coastguard Worker        );
76*cc02d7e2SAndroid Build Coastguard Worker        $this->addSendMessageOpIfHasData($batch, $data, $options);
77*cc02d7e2SAndroid Build Coastguard Worker        $this->call_->startBatch($batch);
78*cc02d7e2SAndroid Build Coastguard Worker    }
79*cc02d7e2SAndroid Build Coastguard Worker
80*cc02d7e2SAndroid Build Coastguard Worker    ////////////////////////////
81*cc02d7e2SAndroid Build Coastguard Worker
82*cc02d7e2SAndroid Build Coastguard Worker    private function addSendInitialMetadataOpIfNotSent(
83*cc02d7e2SAndroid Build Coastguard Worker        array &$batch,
84*cc02d7e2SAndroid Build Coastguard Worker        array $initialMetadata = null
85*cc02d7e2SAndroid Build Coastguard Worker    ) {
86*cc02d7e2SAndroid Build Coastguard Worker        if (!$this->initialMetadataSent_) {
87*cc02d7e2SAndroid Build Coastguard Worker            $batch[OP_SEND_INITIAL_METADATA] = $initialMetadata ?? [];
88*cc02d7e2SAndroid Build Coastguard Worker            $this->initialMetadataSent_ = true;
89*cc02d7e2SAndroid Build Coastguard Worker        }
90*cc02d7e2SAndroid Build Coastguard Worker    }
91*cc02d7e2SAndroid Build Coastguard Worker
92*cc02d7e2SAndroid Build Coastguard Worker    private function addSendMessageOpIfHasData(
93*cc02d7e2SAndroid Build Coastguard Worker        array &$batch,
94*cc02d7e2SAndroid Build Coastguard Worker        $data = null,
95*cc02d7e2SAndroid Build Coastguard Worker        array $options = []
96*cc02d7e2SAndroid Build Coastguard Worker    ) {
97*cc02d7e2SAndroid Build Coastguard Worker        if ($data) {
98*cc02d7e2SAndroid Build Coastguard Worker            $message_array = ['message' => $data->serializeToString()];
99*cc02d7e2SAndroid Build Coastguard Worker            if (array_key_exists('flags', $options)) {
100*cc02d7e2SAndroid Build Coastguard Worker                $message_array['flags'] = $options['flags'];
101*cc02d7e2SAndroid Build Coastguard Worker            }
102*cc02d7e2SAndroid Build Coastguard Worker            $batch[OP_SEND_MESSAGE] = $message_array;
103*cc02d7e2SAndroid Build Coastguard Worker        }
104*cc02d7e2SAndroid Build Coastguard Worker    }
105*cc02d7e2SAndroid Build Coastguard Worker
106*cc02d7e2SAndroid Build Coastguard Worker    private $call_;
107*cc02d7e2SAndroid Build Coastguard Worker    private $initialMetadataSent_ = false;
108*cc02d7e2SAndroid Build Coastguard Worker    private $serverContext_;
109*cc02d7e2SAndroid Build Coastguard Worker}
110