/* SSSD KCM Server - private header file Copyright (C) Red Hat, 2016 This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . */ #ifndef __KCMSRV_OPS_H__ #define __KCMSRV_OPS_H__ #include "config.h" #include #include #include "util/sss_iobuf.h" #include "responder/kcm/kcmsrv_pvt.h" /* The initial packet size, which can later be grown up to KCM_PACKET_MAX_SIZE. * The initial size is a trade off that is expected to best serve most of the * cases (typical credentials size). */ #define KCM_PACKET_INITIAL_SIZE 4096 /* The maximum length of a request or reply as defined by the RPC * protocol. This is the same constant size as MIT KRB5 uses * This limit comes from: * https://github.com/krb5/krb5/blob/c20251dafd6120fa08c76b19315cb9deb1a1b24e/src/lib/krb5/ccache/cc_kcm.c#L54 */ #define KCM_PACKET_MAX_SIZE 10*1024*1024 struct kcm_op; struct kcm_op *kcm_get_opt(uint16_t opcode); const char *kcm_opt_name(struct kcm_op *op); struct kcm_conn_data { /* Credentials obtained by GET_CRED_UUID_LIST. We use to improve performance * by avoiding ccache lookups in GET_CRED_BY_UUID. */ hash_table_t *creds; }; struct tevent_req *kcm_cmd_send(TALLOC_CTX *mem_ctx, struct tevent_context *ev, struct kcm_ops_queue_ctx *qctx, struct kcm_resp_ctx *kcm_data, struct kcm_conn_data *conn_data, struct cli_creds *client, struct kcm_data *input, struct kcm_op *op); errno_t kcm_cmd_recv(TALLOC_CTX *mem_ctx, struct tevent_req *req, struct sss_iobuf **_reply); #endif /* __KCMSRV_OPS_H__ */