2018-07-30 21:33:10 +05:30
|
|
|
syntax = "proto3";
|
|
|
|
|
|
|
|
import "sec0.proto";
|
|
|
|
import "sec1.proto";
|
2022-05-30 15:03:54 +05:30
|
|
|
import "sec2.proto";
|
2018-07-30 21:33:10 +05:30
|
|
|
|
|
|
|
/* Allowed values for the type of security
|
|
|
|
* being used in a protocomm session */
|
|
|
|
enum SecSchemeVersion {
|
2022-05-30 15:03:54 +05:30
|
|
|
SecScheme0 = 0; /*!< Unsecured - plaintext communication */
|
|
|
|
SecScheme1 = 1; /*!< Security scheme 1 - Curve25519 + AES-256-CTR*/
|
|
|
|
SecScheme2 = 2; /*!< Security scheme 2 - SRP6a + AES-256-GCM*/
|
|
|
|
|
2018-07-30 21:33:10 +05:30
|
|
|
}
|
|
|
|
|
|
|
|
/* Data structure exchanged when establishing
|
|
|
|
* secure session between Host and Client */
|
|
|
|
message SessionData {
|
|
|
|
SecSchemeVersion sec_ver = 2; /*!< Type of security */
|
|
|
|
oneof proto {
|
|
|
|
Sec0Payload sec0 = 10; /*!< Payload data in case of security 0 */
|
|
|
|
Sec1Payload sec1 = 11; /*!< Payload data in case of security 1 */
|
2022-05-30 15:03:54 +05:30
|
|
|
Sec2Payload sec2 = 12; /*!< Payload data in case of security 2 */
|
2018-07-30 21:33:10 +05:30
|
|
|
}
|
|
|
|
}
|