%% -*- mode: erlang; tab-width: 4; indent-tabs-mode: 1; st-rulers: [70] -*-
%% vim: ts=4 sw=4 ft=erlang noet
%%%-------------------------------------------------------------------
%%% @author Andrew Bennett <potatosaladx@gmail.com>
%%% @copyright 2015-2022, Andrew Bennett
%%% @doc
%%%
%%% @end
%%% Created : 31 Dec 2015 by Andrew Bennett <potatosaladx@gmail.com>
%%%-------------------------------------------------------------------
-module(libsodium_crypto_aead_aes256gcm).
-define(NAMESPACE, crypto_aead_aes256gcm).
%% API
-export([is_available/0]).
-export([keybytes/0]).
-export([nsecbytes/0]).
-export([npubbytes/0]).
-export([abytes/0]).
-export([messagebytes_max/0]).
-export([statebytes/0]).
-export([encrypt/3]).
-export([encrypt/4]).
-export([decrypt/3]).
-export([decrypt/4]).
-export([encrypt_detached/3]).
-export([encrypt_detached/4]).
-export([decrypt_detached/4]).
-export([decrypt_detached/5]).
% -export([beforenm/1]).
% -export([encrypt_afternm/3]).
% -export([encrypt_afternm/4]).
% -export([decrypt_afternm/3]).
% -export([decrypt_afternm/4]).
% -export([encrypt_detached_afternm/3]).
% -export([encrypt_detached_afternm/4]).
-export([keygen/0]).
%% Internal API
-export([call/1]).
-export([call/2]).
%%%===================================================================
%%% API
%%%===================================================================
is_available() ->
call(is_available).
keybytes() ->
call(keybytes).
nsecbytes() ->
call(nsecbytes).
npubbytes() ->
call(npubbytes).
abytes() ->
call(abytes).
messagebytes_max() ->
call(messagebytes_max).
statebytes() ->
call(statebytes).
encrypt(M, NPub, K)
when is_binary(M)
andalso is_binary(NPub)
andalso is_binary(K) ->
encrypt(M, <<>>, NPub, K).
encrypt(M, AD, NPub, K)
when is_binary(M)
andalso is_binary(AD)
andalso is_binary(NPub)
andalso is_binary(K) ->
call(encrypt, {M, AD, <<>>, NPub, K}).
decrypt(C, NPub, K)
when is_binary(C)
andalso is_binary(NPub)
andalso is_binary(K) ->
decrypt(C, <<>>, NPub, K).
decrypt(C, AD, NPub, K)
when is_binary(C)
andalso is_binary(AD)
andalso is_binary(NPub)
andalso is_binary(K) ->
call(decrypt, {<<>>, C, AD, NPub, K}).
encrypt_detached(M, NPub, K)
when is_binary(M)
andalso is_binary(NPub)
andalso is_binary(K) ->
encrypt_detached(M, <<>>, NPub, K).
encrypt_detached(M, AD, NPub, K)
when is_binary(M)
andalso is_binary(AD)
andalso is_binary(NPub)
andalso is_binary(K) ->
call(encrypt_detached, {M, AD, <<>>, NPub, K}).
decrypt_detached(C, MAC, NPub, K)
when is_binary(C)
andalso is_binary(MAC)
andalso is_binary(NPub)
andalso is_binary(K) ->
decrypt_detached(C, MAC, <<>>, NPub, K).
decrypt_detached(C, MAC, AD, NPub, K)
when is_binary(C)
andalso is_binary(MAC)
andalso is_binary(AD)
andalso is_binary(NPub)
andalso is_binary(K) ->
call(decrypt_detached, {<<>>, C, MAC, AD, NPub, K}).
% beforenm(K)
% when is_binary(K) ->
% call(beforenm, {K}).
% encrypt_afternm(M, NPub, Ctx)
% when is_binary(M)
% andalso is_binary(NPub)
% andalso is_binary(Ctx) ->
% encrypt_afternm(M, <<>>, NPub, Ctx).
% encrypt_afternm(M, AD, NPub, Ctx)
% when is_binary(M)
% andalso is_binary(AD)
% andalso is_binary(NPub)
% andalso is_binary(Ctx) ->
% call(encrypt_afternm, {M, AD, <<>>, NPub, Ctx}).
% decrypt_afternm(C, NPub, Ctx)
% when is_binary(C)
% andalso is_binary(NPub)
% andalso is_binary(Ctx) ->
% decrypt_afternm(C, <<>>, NPub, Ctx).
% decrypt_afternm(C, AD, NPub, Ctx)
% when is_binary(C)
% andalso is_binary(AD)
% andalso is_binary(NPub)
% andalso is_binary(Ctx) ->
% call(decrypt_afternm, {<<>>, C, AD, NPub, Ctx}).
% encrypt_detached_afternm(M, NPub, K)
% when is_binary(M)
% andalso is_binary(NPub)
% andalso is_binary(K) ->
% encrypt_detached_afternm(M, <<>>, NPub, K).
% encrypt_detached_afternm(M, AD, NPub, K)
% when is_binary(M)
% andalso is_binary(AD)
% andalso is_binary(NPub)
% andalso is_binary(K) ->
% call(encrypt_detached_afternm, {M, AD, <<>>, NPub, K}).
keygen() ->
call(keygen).
%%%-------------------------------------------------------------------
%%% Internal functions
%%%-------------------------------------------------------------------
%% @private
call(Function) when is_atom(Function) ->
call(Function, {}).
%% @private
call(Function, Arguments) when is_atom(Function) andalso is_tuple(Arguments) ->
libsodium:call(?NAMESPACE, Function, Arguments).