404

[ Avaa Bypassed ]




Upload:

Command:

botdev@3.145.85.212: ~ $
<?php
/*
 *
 * Copyright 2020 gRPC authors.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 *
 */

namespace Grpc;

/**
 * This is an experimental and incomplete implementation of gRPC server
 * for PHP. APIs are _definitely_ going to be changed.
 *
 * DO NOT USE in production.
 */

/**
 * Class RpcServer
 * @package Grpc
 */
class RpcServer extends Server
{
    // [ <String method_full_path> => MethodDescriptor ]
    private $paths_map = [];

    private function waitForNextEvent()
    {
        return $this->requestCall();
    }

    /**
     * Add a service to this server
     *
     * @param Object   $service      The service to be added
     */
    public function handle($service)
    {
        $methodDescriptors = $service->getMethodDescriptors();
        $exist_methods = array_intersect_key($this->paths_map, $methodDescriptors);
        if (!empty($exist_methods)) {
            fwrite(STDERR, "WARNING: " . 'override already registered methods: ' .
                implode(', ', array_keys($exist_methods)) . PHP_EOL);
        }

        $this->paths_map = array_merge($this->paths_map, $methodDescriptors);
        return $this->paths_map;
    }

    public function run()
    {
        $this->start();
        while (true) try {
            // This blocks until the server receives a request
            $event = $this->waitForNextEvent();

            $full_path = $event->method;
            $context = new ServerContext($event);
            $server_writer = new ServerCallWriter($event->call, $context);

            if (!array_key_exists($full_path, $this->paths_map)) {
                $context->setStatus(Status::unimplemented());
                $server_writer->finish();
                continue;
            };

            $method_desc = $this->paths_map[$full_path];
            $server_reader = new ServerCallReader(
                $event->call,
                $method_desc->request_type
            );

            try {
                $this->processCall(
                    $method_desc,
                    $server_reader,
                    $server_writer,
                    $context
                );
            } catch (\Exception $e) {
                $context->setStatus(Status::status(
                    STATUS_INTERNAL,
                    $e->getMessage()
                ));
                $server_writer->finish();
            }
        } catch (\Exception $e) {
            fwrite(STDERR, "ERROR: " . $e->getMessage() . PHP_EOL);
            exit(1);
        }
    }

    private function processCall(
        MethodDescriptor $method_desc,
        ServerCallReader $server_reader,
        ServerCallWriter $server_writer,
        ServerContext $context
    ) {
        // Dispatch to actual server logic
        switch ($method_desc->call_type) {
            case MethodDescriptor::UNARY_CALL:
                $request = $server_reader->read();
                $response =
                    call_user_func(
                        array($method_desc->service, $method_desc->method_name),
                        $request ?? new $method_desc->request_type,
                        $context
                    );
                $server_writer->finish($response);
                break;
            case MethodDescriptor::SERVER_STREAMING_CALL:
                $request = $server_reader->read();
                call_user_func(
                    array($method_desc->service, $method_desc->method_name),
                    $request ?? new $method_desc->request_type,
                    $server_writer,
                    $context
                );
                break;
            case MethodDescriptor::CLIENT_STREAMING_CALL:
                $response = call_user_func(
                    array($method_desc->service, $method_desc->method_name),
                    $server_reader,
                    $context
                );
                $server_writer->finish($response);
                break;
            case MethodDescriptor::BIDI_STREAMING_CALL:
                call_user_func(
                    array($method_desc->service, $method_desc->method_name),
                    $server_reader,
                    $server_writer,
                    $context
                );
                break;
            default:
                throw new \Exception();
        }
    }
}

Filemanager

Name Type Size Permission Actions
Internal Folder 2755
AbstractCall.php File 3.91 KB 0755
BaseStub.php File 20.69 KB 0755
BidiStreamingCall.php File 2.94 KB 0755
CallInvoker.php File 1.14 KB 0755
ClientStreamingCall.php File 2.31 KB 0755
DefaultCallInvoker.php File 1.48 KB 0755
Interceptor.php File 2.6 KB 0755
MethodDescriptor.php File 1.37 KB 0755
RpcServer.php File 4.76 KB 0755
ServerCallReader.php File 1.31 KB 0755
ServerCallWriter.php File 2.97 KB 0755
ServerContext.php File 1.64 KB 0755
ServerStreamingCall.php File 3.01 KB 0755
Status.php File 1.39 KB 0755
UnaryCall.php File 2.53 KB 0755