summaryrefslogtreecommitdiff
path: root/libs/libaxolotl/src/session_builder.h
blob: cfd67a1824c86149e5062065fc90891902dc2470 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
#ifndef SESSION_BUILDER_H
#define SESSION_BUILDER_H

#include <stdint.h>
#include "axolotl_types.h"

#ifdef __cplusplus
extern "C" {
#endif

/*
 * Session builder is responsible for setting up encrypted sessions.
 * Once a session has been established, session_cipher
 * can be used to encrypt/decrypt messages in that session.
 *
 * Sessions are built from one of three different possible vectors:
 * - A session_pre_key_bundle retrieved from a server
 * - A pre_key_whisper_message received from a client
 * - A key_exchange_message sent to or received from a client
 *
 * Sessions are constructed per AXOLOTL address
 * (recipient name + device ID tuple). Remote logical users are identified by
 * their recipient name, and each logical recipient can have multiple
 * physical devices.
 */

/**
 * Constructs a session builder.
 *
 * The store and global contexts must remain valid for the lifetime of the
 * session builder.
 *
 * When finished, free the returned instance by calling session_builder_free().
 *
 * @param builder set to a freshly allocated session builder instance
 * @param store the axolotl_store_context to store all state information in
 * @param remote_address the address of the remote user to build a session with
 * @param global_context the global library context
 * @return 0 on success, or negative on failure
 */
int session_builder_create(session_builder **builder,
        axolotl_store_context *store, const axolotl_address *remote_address,
        axolotl_context *global_context);

/**
 * Build a new session from a received pre_key_whisper_message.
 *
 * After a session is constructed in this way, the embedded whisper_message
 * can be decrypted.
 *
 * @param message The received pre_key_whisper_message.
 * @param unsigned_pre_key_id set to the unsigned pre key ID, if available.
 *     Return value indicates whether or not this value is available.
 * @retval 0 Success, no unsigned pre key value available
 * @retval 1 Success, an unsigned pre key is available
 * @retval AX_ERR_INVALID_KEY_ID when there is no local pre_key_record that
 *                               corresponds to the PreKey ID in the message.
 * @retval AX_ERR_INVALID_KEY when the message is formatted incorrectly.
 * @retval AX_ERR_UNTRUSTED_IDENTITY when the identity key of the sender is untrusted.
 */
int session_builder_process_pre_key_whisper_message(session_builder *builder,
        session_record *record, pre_key_whisper_message *message, uint32_t *unsigned_pre_key_id);

/**
 * Build a new session from a session_pre_key_bundle retrieved from a server.
 *
 * @param bundle A pre key bundle for the destination recipient, retrieved from a server.
 * @retval AX_SUCCESS Success
 * @retval AX_ERR_INVALID_KEY when the session_pre_key_bundle is badly formatted.
 * @retval AX_ERR_UNTRUSTED_IDENTITY when the sender's identity key is not trusted.
 */
int session_builder_process_pre_key_bundle(session_builder *builder, session_pre_key_bundle *bundle);

/**
 * Build a new session from a key_exchange_message received from a remote client.
 *
 * @param message The received key_exchange_message.
 * @param response_message Set to the key_exchange_message to respond with,
 *     or set to 0 if no response is necessary.
 * @retval AX_SUCCESS Success
 * @retval AX_ERR_INVALID_KEY if the received key_exchange_message is badly formatted.
 * @retval AX_ERR_UNTRUSTED_IDENTITY
 * @retval AX_ERR_STALE_KEY_EXCHANGE
 */
int session_builder_process_key_exchange_message(session_builder *builder, key_exchange_message *message, key_exchange_message **response_message);

/**
 * Initiate a new session by sending an initial key_exchange_message to the recipient.
 *
 * @param message Set to the key_exchange_message to deliver.
 * @return AX_SUCCESS on success, negative on error
 */
int session_builder_process(session_builder *builder, key_exchange_message **message);

void session_builder_free(session_builder *builder);

#ifdef __cplusplus
}
#endif

#endif /* SESSION_BUILDER_H */