blob: c03735f96df930894a8a7bf68a426548cbbcbc93 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Sage Weilec0994e2010-02-02 16:25:35 -08002#ifndef _FS_CEPH_AUTH_X_H
3#define _FS_CEPH_AUTH_X_H
4
5#include <linux/rbtree.h>
6
Yehuda Sadeh3d14c5d2010-04-06 15:14:15 -07007#include <linux/ceph/auth.h>
8
Sage Weilec0994e2010-02-02 16:25:35 -08009#include "crypto.h"
Sage Weilec0994e2010-02-02 16:25:35 -080010#include "auth_x_protocol.h"
11
12/*
13 * Handle ticket for a single service.
14 */
15struct ceph_x_ticket_handler {
16 struct rb_node node;
Eric Dumazet95c96172012-04-15 05:58:06 +000017 unsigned int service;
Sage Weilec0994e2010-02-02 16:25:35 -080018
19 struct ceph_crypto_key session_key;
Ilya Dryomov6abe0972016-01-14 16:35:35 +010020 bool have_key;
Sage Weilec0994e2010-02-02 16:25:35 -080021
22 u64 secret_id;
23 struct ceph_buffer *ticket_blob;
24
Arnd Bergmann473bd2d2018-07-13 22:18:34 +020025 time64_t renew_after, expires;
Sage Weilec0994e2010-02-02 16:25:35 -080026};
27
Ilya Dryomov7882a262016-12-02 16:35:07 +010028#define CEPHX_AU_ENC_BUF_LEN 128 /* big enough for encrypted blob */
Sage Weilec0994e2010-02-02 16:25:35 -080029
30struct ceph_x_authorizer {
Ilya Dryomov6c1ea262016-04-11 19:34:49 +020031 struct ceph_authorizer base;
Yan, Zhengae385ea2014-11-04 16:32:35 +080032 struct ceph_crypto_key session_key;
Sage Weilec0994e2010-02-02 16:25:35 -080033 struct ceph_buffer *buf;
Eric Dumazet95c96172012-04-15 05:58:06 +000034 unsigned int service;
Sage Weilec0994e2010-02-02 16:25:35 -080035 u64 nonce;
Sage Weil0bed9b52013-03-25 10:26:01 -070036 u64 secret_id;
Ilya Dryomov7882a262016-12-02 16:35:07 +010037 char enc_buf[CEPHX_AU_ENC_BUF_LEN] __aligned(8);
Sage Weilec0994e2010-02-02 16:25:35 -080038};
39
40struct ceph_x_info {
41 struct ceph_crypto_key secret;
42
43 bool starting;
44 u64 server_challenge;
45
Eric Dumazet95c96172012-04-15 05:58:06 +000046 unsigned int have_keys;
Sage Weilec0994e2010-02-02 16:25:35 -080047 struct rb_root ticket_handlers;
48
49 struct ceph_x_authorizer auth_authorizer;
50};
51
Joe Perches348662a2013-10-18 13:48:22 -070052int ceph_x_init(struct ceph_auth_client *ac);
Sage Weilec0994e2010-02-02 16:25:35 -080053
54#endif