2016-05-17 12:52:06 +02:00
|
|
|
/* Copyright 2016 OpenMarket Ltd
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* functions for encoding and decoding messages in the Olm protocol.
|
|
|
|
*
|
|
|
|
* Some of these functions have only C++ bindings, and are declared in
|
|
|
|
* message.hh; in time, they should probably be converted to plain C and
|
|
|
|
* declared here.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef OLM_MESSAGE_H_
|
|
|
|
#define OLM_MESSAGE_H_
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <stddef.h>
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The length of the buffer needed to hold a group message.
|
|
|
|
*/
|
|
|
|
size_t _olm_encode_group_message_length(
|
|
|
|
size_t group_session_id_length,
|
|
|
|
uint32_t chain_index,
|
|
|
|
size_t ciphertext_length,
|
|
|
|
size_t mac_length
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Writes the message headers into the output buffer.
|
|
|
|
*
|
|
|
|
* version: version number of the olm protocol
|
|
|
|
* session_id: group session identifier
|
|
|
|
* session_id_length: length of session_id
|
2016-05-19 08:53:07 +02:00
|
|
|
* message_index: message index
|
2016-05-17 12:52:06 +02:00
|
|
|
* ciphertext_length: length of the ciphertext
|
|
|
|
* output: where to write the output. Should be at least
|
|
|
|
* olm_encode_group_message_length() bytes long.
|
|
|
|
* ciphertext_ptr: returns the address that the ciphertext
|
|
|
|
* should be written to, followed by the MAC.
|
2016-05-24 17:23:19 +02:00
|
|
|
*
|
|
|
|
* Returns the size of the message, up to the MAC.
|
2016-05-17 12:52:06 +02:00
|
|
|
*/
|
2016-05-24 17:23:19 +02:00
|
|
|
size_t _olm_encode_group_message(
|
2016-05-17 12:52:06 +02:00
|
|
|
uint8_t version,
|
|
|
|
const uint8_t *session_id,
|
|
|
|
size_t session_id_length,
|
2016-05-19 08:53:07 +02:00
|
|
|
uint32_t message_index,
|
2016-05-17 12:52:06 +02:00
|
|
|
size_t ciphertext_length,
|
|
|
|
uint8_t *output,
|
|
|
|
uint8_t **ciphertext_ptr
|
|
|
|
);
|
|
|
|
|
|
|
|
|
2016-05-18 18:23:09 +02:00
|
|
|
struct _OlmDecodeGroupMessageResults {
|
|
|
|
uint8_t version;
|
|
|
|
const uint8_t *session_id;
|
|
|
|
size_t session_id_length;
|
2016-05-19 08:53:07 +02:00
|
|
|
uint32_t message_index;
|
|
|
|
int has_message_index;
|
2016-05-18 18:23:09 +02:00
|
|
|
const uint8_t *ciphertext;
|
|
|
|
size_t ciphertext_length;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Reads the message headers from the input buffer.
|
|
|
|
*/
|
|
|
|
void _olm_decode_group_message(
|
|
|
|
const uint8_t *input, size_t input_length,
|
|
|
|
size_t mac_length,
|
|
|
|
|
|
|
|
/* output structure: updated with results */
|
|
|
|
struct _OlmDecodeGroupMessageResults *results
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
|
2016-05-17 12:52:06 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
} // extern "C"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* OLM_MESSAGE_H_ */
|