#  Licensed to the Apache Software Foundation (ASF) under one
#  or more contributor license agreements. See the NOTICE file
#  distributed with this work for additional information
#  regarding copyright ownership. The ASF licenses this file
#  to you 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.

# Generated by the gRPC Python protocol compiler plugin. DO NOT EDIT!
"""Client and server classes corresponding to protobuf-defined services."""
import grpc

import custos.server.integration.ClusterManagementService_pb2 as ClusterManagementService__pb2


class ClusterManagementServiceStub(object):
    """Missing associated documentation comment in .proto file."""

    def __init__(self, channel):
        """Constructor.

        Args:
            channel: A grpc.Channel.
        """
        self.getCustosServerCertificate = channel.unary_unary(
                '/org.apache.custos.cluster.management.service.ClusterManagementService/getCustosServerCertificate',
                request_serializer=ClusterManagementService__pb2.GetServerCertificateRequest.SerializeToString,
                response_deserializer=ClusterManagementService__pb2.GetServerCertificateResponse.FromString,
                )


class ClusterManagementServiceServicer(object):
    """Missing associated documentation comment in .proto file."""

    def getCustosServerCertificate(self, request, context):
        """Missing associated documentation comment in .proto file."""
        context.set_code(grpc.StatusCode.UNIMPLEMENTED)
        context.set_details('Method not implemented!')
        raise NotImplementedError('Method not implemented!')


def add_ClusterManagementServiceServicer_to_server(servicer, server):
    rpc_method_handlers = {
            'getCustosServerCertificate': grpc.unary_unary_rpc_method_handler(
                    servicer.getCustosServerCertificate,
                    request_deserializer=ClusterManagementService__pb2.GetServerCertificateRequest.FromString,
                    response_serializer=ClusterManagementService__pb2.GetServerCertificateResponse.SerializeToString,
            ),
    }
    generic_handler = grpc.method_handlers_generic_handler(
            'org.apache.custos.cluster.management.service.ClusterManagementService', rpc_method_handlers)
    server.add_generic_rpc_handlers((generic_handler,))


 # This class is part of an EXPERIMENTAL API.
class ClusterManagementService(object):
    """Missing associated documentation comment in .proto file."""

    @staticmethod
    def getCustosServerCertificate(request,
            target,
            options=(),
            channel_credentials=None,
            call_credentials=None,
            insecure=False,
            compression=None,
            wait_for_ready=None,
            timeout=None,
            metadata=None):
        return grpc.experimental.unary_unary(request, target, '/org.apache.custos.cluster.management.service.ClusterManagementService/getCustosServerCertificate',
            ClusterManagementService__pb2.GetServerCertificateRequest.SerializeToString,
            ClusterManagementService__pb2.GetServerCertificateResponse.FromString,
            options, channel_credentials,
            insecure, call_credentials, compression, wait_for_ready, timeout, metadata)
