Gcr.SecretExchange¶
- Subclasses:
None
Methods¶
- Inherited:
- Structs:
class |
|
|
|
|
|
|
|
|
|
|
Virtual Methods¶
- Inherited:
|
|
|
Properties¶
Name |
Type |
Flags |
Short Description |
---|---|---|---|
r/w/co |
Exchange protocol |
Signals¶
- Inherited:
Fields¶
- Inherited:
Name |
Type |
Access |
Description |
---|---|---|---|
parent |
r |
Class Details¶
- class Gcr.SecretExchange(**kwargs)¶
- Bases:
- Abstract:
No
- Structure:
Allows exchange of secrets between two processes on the same system without exposing those secrets to things like loggers, non-pageable memory etc.
This does not protect against active attacks like MITM attacks.
Each side creates a secret exchange object, and one of the sides calls [method`SecretExchange`.begin]. This creates a string, which should be passed to the other side. Each side passes the strings it receives into [method`SecretExchange`.receive].
In order to send a reply (either with or without a secret) use [method`SecretExchange`.send]. A side must have successfully called [method`SecretExchange`.receive] before it can use [method`SecretExchange`.send].
The secret exchange objects can be used for multiple iterations of the conversation, or for just one request/reply. The only limitation being that the initial request cannot contain a secret.
Caveat: Information about the approximate length (rounded up to the nearest 16 bytes) may be leaked. If this is considered inacceptable, do not use [class`SecretExchange`].
- classmethod new(protocol)[source]¶
- Parameters:
- Returns:
A new
Gcr.SecretExchange
object- Return type:
Create a new secret exchange object.
Specify a protocol of
None
to allow any protocol. This is especially relevant on the side of the exchange that does not call [method`SecretExchange`.begin], that is the originator. Currently the only protocol supported isGcr.SECRET_EXCHANGE_PROTOCOL_1
.
- begin()[source]¶
- Returns:
A newly allocated string to be sent to the other side of the secret exchange
- Return type:
Begin the secret exchange. The resulting string should be sent to the other side of the exchange. The other side should use [method`SecretExchange`.receive] to process the string.
- get_protocol()[source]¶
-
Will return
None
if no protocol was specified, and either [method`SecretExchange`.begin] or [method`SecretExchange`.receive] have not been called successfully.
- get_secret()[source]¶
- Returns:
the last secret received
- Return type:
[
str
]
Returns the last secret received. If no secret has yet been received this will return
None
. The string is owned by theGcr.SecretExchange
object and will be valid until the next time thatGcr.SecretExchange.receive
() is called on this object, or the object is destroyed.Depending on the secret passed into the other side of the secret exchange, the result may be a binary string. It does however have a null terminator, so if you’re certain that it is does not contain arbitrary binary data, it can be used as a string.
- receive(exchange)[source]¶
- Parameters:
exchange (
str
) – the string received- Returns:
whether the string was successfully parsed and received
- Return type:
Receive a string from the other side of secret exchange. This string will have been created by [method`SecretExchange`.begin] or [method`SecretExchange`.send].
After this call completes successfully the value returned from
Gcr.SecretExchange.get_secret
() will have changed.
- send(secret, secret_len)[source]¶
- Parameters:
- Returns:
a newly allocated string to be sent to the other side of the secret exchange
- Return type:
Send a reply to the other side of the secret exchange, optionally sending a secret.
[method`SecretExchange`.receive] must have been successfully called at least once on this object. In other words this object must have received data from the other side of the secret exchange, before we can send a secret.
- do_derive_transport_key(peer, n_peer) virtual¶
Property Details¶
- Gcr.SecretExchange.props.protocol¶
- Name:
protocol
- Type:
- Default Value:
'sx-aes-1'
- Flags:
The protocol being used for the exchange.
Will be
None
if no protocol was specified when creating this object, and either [method`SecretExchange`.begin] or [method`SecretExchange`.receive] have not been called successfully.