blob: 3f59a4423d33544d62b07ad53c580b9ee478c475 [file] [log] [blame]
/*
*
* Copyright 2016 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.
*
*/
#ifndef GRPC_GRPC_POSIX_H
#define GRPC_GRPC_POSIX_H
#include <stddef.h>
#include <grpc/grpc.h>
#include <grpc/impl/grpc_types.h>
#include <grpc/support/port_platform.h>
#ifdef __cplusplus
extern "C" {
#endif
/*! \mainpage GRPC Core POSIX
*
* The GRPC Core POSIX library provides some POSIX-specific low-level
* functionality on top of GRPC Core.
*/
/** Create a secure channel to 'target' using file descriptor 'fd' and passed-in
credentials. The 'target' argument will be used to indicate the name for
this channel. Note that this API currently only supports insecure channel
credentials. Using other types of credentials will result in a failure. */
GRPCAPI grpc_channel* grpc_channel_create_from_fd(
const char* target, int fd, grpc_channel_credentials* creds,
const grpc_channel_args* args);
/** Add the connected secure communication channel based on file descriptor 'fd'
to the 'server' and server credentials 'creds'. The 'fd' must be an open file
descriptor corresponding to a connected socket. Events from the file
descriptor may come on any of the server completion queues (i.e completion
queues registered via the grpc_server_register_completion_queue API).
Note that this API currently only supports inseure server credentials
Using other types of credentials will result in a failure.
TODO(hork): add channel_args to this API to allow endpoints and transports
created in this function to participate in the resource quota feature. */
GRPCAPI void grpc_server_add_channel_from_fd(grpc_server* server, int fd,
grpc_server_credentials* creds);
#ifdef __cplusplus
}
#endif
#endif /* GRPC_GRPC_POSIX_H */