Some documentation in enoise.erl
This commit is contained in:
parent
14fe5c7e8e
commit
dd5200d64f
@ -1,27 +1,48 @@
|
|||||||
%%%-------------------------------------------------------------------
|
%%% ------------------------------------------------------------------
|
||||||
%%% @copyright (C) 2018, Aeternity Anstalt
|
%%% @copyright 2018, Aeternity Anstalt
|
||||||
%%%-------------------------------------------------------------------
|
%%%
|
||||||
|
%%% @doc Module is an interface to the Noise protocol
|
||||||
|
%%% [https://noiseprotocol.org]
|
||||||
|
%%%
|
||||||
|
%%% The module implements Noise over TCP (i.e. `gen_tcp') and after "upgrading"
|
||||||
|
%%% a `gen_tcp'-socket into a `enoise'-socket it has a similar API as
|
||||||
|
%%% `gen_tcp'.
|
||||||
|
%%%
|
||||||
|
%%% @end
|
||||||
|
%%% ------------------------------------------------------------------
|
||||||
|
|
||||||
-module(enoise).
|
-module(enoise).
|
||||||
|
|
||||||
%% API exports - Mainly mimicing gen_tcp
|
%% API exports - Mainly mimicing gen_tcp
|
||||||
%% -export([ accept/1
|
-export([ accept/2
|
||||||
%% , accept/2
|
, close/1
|
||||||
%% , close/1
|
, connect/2
|
||||||
%% , connect/3
|
, controlling_process/2
|
||||||
%% , connect/4
|
, recv/2
|
||||||
%% , controlling_process/2
|
, recv/3
|
||||||
%% , listen/2
|
, send/2 ]).
|
||||||
%% , recv/2
|
|
||||||
%% , recv/3
|
|
||||||
%% , send/2
|
|
||||||
%% , shutdown/2 ]).
|
|
||||||
-compile([export_all, nowarn_export_all]).
|
|
||||||
|
|
||||||
-record(enoise, { pid }).
|
-record(enoise, { pid }).
|
||||||
|
|
||||||
-type noise_options() :: [{atom(), term()}].
|
-type noise_key() :: binary().
|
||||||
|
-type noise_keypair() :: term().
|
||||||
|
|
||||||
|
-type noise_options() :: [noise_option()].
|
||||||
|
-type noise_option() :: {noise, noise_protocol_option()} %% Required
|
||||||
|
| {e, noise_keypair()} %% Optional
|
||||||
|
| {s, noise_keypair()}
|
||||||
|
| {re, noise_key()}
|
||||||
|
| {rs, noise_key()}
|
||||||
|
| {prologue, binary()}.
|
||||||
|
|
||||||
|
-type noise_protocol_option() :: enoise_protocol:protocol() | string() |
|
||||||
|
binary().
|
||||||
|
%% Either an instantiated Noise protocol configuration or the name of a Noise
|
||||||
|
%% configuration (either as a string or a binary string).
|
||||||
|
|
||||||
-opaque noise_socket() :: #enoise{}.
|
-opaque noise_socket() :: #enoise{}.
|
||||||
|
%% An abstract Noise socket - holds a reference to a socket that has completed
|
||||||
|
%% a Noise handshake.
|
||||||
|
|
||||||
-export_type([noise_socket/0]).
|
-export_type([noise_socket/0]).
|
||||||
|
|
||||||
@ -47,22 +68,22 @@ connect(TcpSock, Options) ->
|
|||||||
accept(TcpSock, Options) ->
|
accept(TcpSock, Options) ->
|
||||||
start_handshake(TcpSock, responder, Options).
|
start_handshake(TcpSock, responder, Options).
|
||||||
|
|
||||||
%% @doc Writes `Data` to `Socket`
|
%% @doc Writes `Data' to `Socket'
|
||||||
%% @end
|
%% @end
|
||||||
-spec send(Socket :: noise_socket(), Data :: binary()) -> ok | {error, term()}.
|
-spec send(Socket :: noise_socket(), Data :: binary()) -> ok | {error, term()}.
|
||||||
send(#enoise{ pid = Pid }, Data) ->
|
send(#enoise{ pid = Pid }, Data) ->
|
||||||
enoise_connection:send(Pid, Data).
|
enoise_connection:send(Pid, Data).
|
||||||
|
|
||||||
%% @doc Receives a packet from a socket in passive mode. A closed socket is
|
%% @doc Receives a packet from a socket in passive mode. A closed socket is
|
||||||
%% indicated by return value `{error, closed}`.
|
%% indicated by return value `{error, closed}'.
|
||||||
%%
|
%%
|
||||||
%% Argument `Length` denotes the number of bytes to read. If Length = 0, all
|
%% Argument `Length' denotes the number of bytes to read. If Length = 0, all
|
||||||
%% available bytes are returned. If Length > 0, exactly Length bytes are
|
%% available bytes are returned. If Length > 0, exactly Length bytes are
|
||||||
%% returned, or an error; possibly discarding less than Length bytes of data
|
%% returned, or an error; possibly discarding less than Length bytes of data
|
||||||
%% when the socket gets closed from the other side.
|
%% when the socket gets closed from the other side.
|
||||||
%%
|
%%
|
||||||
%% Optional argument `Timeout` specifies a time-out in milliseconds. The
|
%% Optional argument `Timeout' specifies a time-out in milliseconds. The
|
||||||
%% default value is `infinity`.
|
%% default value is `infinity'.
|
||||||
%% @end
|
%% @end
|
||||||
-spec recv(Socket :: noise_socket(), Length :: integer()) ->
|
-spec recv(Socket :: noise_socket(), Length :: integer()) ->
|
||||||
{ok, binary()} | {error, term()}.
|
{ok, binary()} | {error, term()}.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user