made a little progress on grids demo
i mostly have my head wrapped around the problem a lot more, and need to just let my brain sit
This commit is contained in:
parent
9adbf67ebd
commit
8a9f060b2d
@ -1,3 +1,9 @@
|
|||||||
|
2026-02-25(PRH):
|
||||||
|
grids: instead of spying the chain for a tx, let's use dead drop
|
||||||
|
|
||||||
|
- so for "generate", need to form tx for the user to sign
|
||||||
|
- make dead drop -> have process that knows each tx and the dead drop location
|
||||||
|
|
||||||
OPEN LOOPS - 2025-11-12
|
OPEN LOOPS - 2025-11-12
|
||||||
- websockets
|
- websockets
|
||||||
- separate websocket handling from websocket parsing/sending
|
- separate websocket handling from websocket parsing/sending
|
||||||
|
|||||||
2
priv/static/js/dist/grids-basic.js
vendored
2
priv/static/js/dist/grids-basic.js
vendored
@ -59,7 +59,7 @@ async function grids_request(net_id, recipient, amount, payload) {
|
|||||||
'amount': amount,
|
'amount': amount,
|
||||||
'payload': payload };
|
'payload': payload };
|
||||||
let obj_text = JSON.stringify(obj, undefined, 4);
|
let obj_text = JSON.stringify(obj, undefined, 4);
|
||||||
let url = '/grids-spend';
|
let url = '/grids-mkdd';
|
||||||
let req_options = { method: 'POST',
|
let req_options = { method: 'POST',
|
||||||
headers: { 'content-type': 'application/json' },
|
headers: { 'content-type': 'application/json' },
|
||||||
body: obj_text };
|
body: obj_text };
|
||||||
|
|||||||
2
priv/static/js/dist/grids-basic.js.map
vendored
2
priv/static/js/dist/grids-basic.js.map
vendored
@ -1 +1 @@
|
|||||||
{"version":3,"file":"grids-basic.js","sourceRoot":"","sources":["../ts/grids-basic.ts"],"names":[],"mappings":";AAAA;;;;;;;;GAQG;AAEH,IAAI,EAAE,CAAC;AAGP;;GAEG;AACH,KAAK,UACL,IAAI;IAGA,IAAI,OAAO,GAAM,QAAQ,CAAC,cAAc,CAAC,SAAS,CAA0B,CAAC;IAC7E,IAAI,OAAO,GAAM,QAAQ,CAAC,cAAc,CAAC,SAAS,CAA0B,CAAC;IAC7E,IAAI,OAAO,GAAM,QAAQ,CAAC,cAAc,CAAC,SAAS,CAA0B,CAAC;IAC7E,IAAI,OAAO,GAAM,QAAQ,CAAC,cAAc,CAAC,SAAS,CAA0B,CAAC;IAC7E,IAAI,UAAU,GAAG,QAAQ,CAAC,cAAc,CAAC,cAAc,CAAqB,CAAC;IAE7E,IAAI,aAAa,GAAG,QAAQ,CAAC,cAAc,CAAC,WAAW,CAAwB,CAAC;IAChF,IAAI,aAAa,GAAG,QAAQ,CAAC,cAAc,CAAC,WAAW,CAAqB,CAAC;IAE7E,sBAAsB;IACtB,UAAU,CAAC,gBAAgB,CACvB,OAAO,EACP,KAAK,WAAU,CAAC;QACZ,MAAM,SAAS,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,aAAa,CAAC,CAAA;IACrF,CAAC,CACJ,CAAC;IAEF,iBAAiB;IACjB,UAAU,CAAC,QAAQ,GAAG,KAAK,CAAC;AAChC,CAAC;AAED,KAAK,UACL,SAAS,CACJ,OAAgC,EAChC,OAAgC,EAChC,OAAgC,EAChC,OAAgC,EAChC,aAAmC,EACnC,aAAgC;IAGjC,kBAAkB;IAClB,IAAI,UAAU,GAAY,OAAO,CAAC,KAAK,CAAC;IACxC,IAAI,SAAS,GAAa,OAAO,CAAC,KAAK,CAAC;IACxC,IAAI,MAAM,GAAgB,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;IAClD,IAAI,OAAO,GAAe,OAAO,CAAC,KAAK,CAAC;IAExC,IAAI,MAAM,GAAsB,MAAM,aAAa,CAAC,UAAU,EAAE,SAAS,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;IAE5F,yBAAyB;IACzB,IAAI,MAAM,CAAC,EAAE,EAAE;QACX,IAAI,GAAG,GAAmB,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC;QAC5C,IAAI,UAAU,GAAY,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC;QAEnD,IAAI,UAAU,GAAY,wBAAwB,CAAA;QAElD,IAAI,GAAG,GAAG,UAAU,GAAG,UAAU,CAAC;QAElC,aAAa,CAAC,SAAS,GAAG,GAAG,CAAC;QAC9B,aAAa,CAAC,GAAG,GAAS,GAAG,CAAC;QAE9B,aAAa,CAAC,MAAM,GAAG,KAAK,CAAC;QAC7B,aAAa,CAAC,MAAM,GAAG,KAAK,CAAC;KAChC;SACI;QACD,KAAK,CAAC,SAAS,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;KACnC;AACL,CAAC;AASD;;GAEG;AACH,KAAK,UACL,aAAa,CACR,MAAkB,EAClB,SAAkB,EAClB,MAAkB,EAClB,OAAkB;IAGnB,kCAAkC;IAClC,IAAI,GAAG,GAAiB,EAAC,YAAY,EAAG,MAAM;QACrB,WAAW,EAAI,SAAS;QACxB,QAAQ,EAAO,MAAM;QACrB,SAAS,EAAM,OAAO,EAAC,CAAC;IACjD,IAAI,QAAQ,GAAY,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC;IAG1D,IAAI,GAAG,GAAG,cAAc,CAAC;IACzB,IAAI,WAAW,GAAI,EAAC,MAAM,EAAG,MAAM;QACf,OAAO,EAAE,EAAC,cAAc,EAAE,kBAAkB,EAAC;QAC7C,IAAI,EAAK,QAAQ,EAAC,CAAC;IAGvC,IAAI,MAAM,GACF,EAAC,EAAE,EAAM,KAAK;QACb,KAAK,EAAG,kCAAkC,EAAC,CAAC;IAErD,IAAI;QACA,IAAI,QAAQ,GAAc,MAAM,KAAK,CAAC,GAAG,EAAE,WAAW,CAAC,CAAC;QACxD,IAAI,QAAQ,CAAC,EAAE;YACX,MAAM,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAuB,CAAC;aACnD;YACD,OAAO,CAAC,GAAG,CAAC,oBAAoB,EAAE,QAAQ,CAAC,CAAC;YAC5C,MAAM,GAAG,EAAC,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,mBAAmB,EAAC,CAAC;SACpD;KACJ;IACD,OAAO,CAAM,EAAE;QACX,OAAO,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC,CAAC,CAAC;QACjC,MAAM,GAAG,EAAC,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,eAAe,EAAC,CAAC;KAChD;IAED,OAAO,MAAM,CAAC;AAClB,CAAC"}
|
{"version":3,"file":"grids-basic.js","sourceRoot":"","sources":["../ts/grids-basic.ts"],"names":[],"mappings":"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"}
|
||||||
@ -103,7 +103,7 @@ grids_request
|
|||||||
let obj_text : string = JSON.stringify(obj, undefined, 4);
|
let obj_text : string = JSON.stringify(obj, undefined, 4);
|
||||||
|
|
||||||
|
|
||||||
let url = '/grids-spend';
|
let url = '/grids-mkdd';
|
||||||
let req_options = {method: 'POST',
|
let req_options = {method: 'POST',
|
||||||
headers: {'content-type': 'application/json'},
|
headers: {'content-type': 'application/json'},
|
||||||
body: obj_text};
|
body: obj_text};
|
||||||
|
|||||||
@ -9,7 +9,7 @@
|
|||||||
|
|
||||||
-export([
|
-export([
|
||||||
%% caller context
|
%% caller context
|
||||||
mk_spend/4,
|
mkdd/4,
|
||||||
|
|
||||||
%% api
|
%% api
|
||||||
start_link/0,
|
start_link/0,
|
||||||
@ -22,16 +22,26 @@
|
|||||||
-include("$zx_include/zx_logger.hrl").
|
-include("$zx_include/zx_logger.hrl").
|
||||||
|
|
||||||
%% for craig's autism
|
%% for craig's autism
|
||||||
-record(sp,
|
%-type grids_get_response() :: #{"grids" := 1,
|
||||||
{recipient :: string(),
|
% "chain" := "gajumaru",
|
||||||
amount :: non_neg_integer(),
|
% "network_id" := "groot.testnet",
|
||||||
payload :: binary()}).
|
% "type" := "tx",
|
||||||
|
% "public_id" := false,
|
||||||
|
% "payload" := string()}.
|
||||||
|
%
|
||||||
|
% semantic type for hex encoding of a random binary string
|
||||||
|
-type hex() :: binary().
|
||||||
|
-define(SEC, 1).
|
||||||
|
-define(MIN, 60*SEC).
|
||||||
|
-define(DEAD_DROP_TTL, 30*MIN).
|
||||||
|
|
||||||
-type search_pattern() :: #sp{}.
|
-record(dd,
|
||||||
-type sp() :: search_pattern().
|
{created_at :: integer(),
|
||||||
|
payload :: string()}).
|
||||||
|
-type dd() :: #dd{}.
|
||||||
|
|
||||||
-record(s,
|
-record(s,
|
||||||
{looking_for = [] :: [{sp(), NotifyWhenSeen :: pid()}]}).
|
{drops = #{} :: #{hex() := dd()}}).
|
||||||
|
|
||||||
-type state() :: #s{}.
|
-type state() :: #s{}.
|
||||||
|
|
||||||
@ -40,7 +50,7 @@
|
|||||||
%% caller context
|
%% caller context
|
||||||
%%-----------------------------------------------------------------------------
|
%%-----------------------------------------------------------------------------
|
||||||
|
|
||||||
-spec mk_spend(NetworkId, Recipient, Amount, Payload) -> Result
|
-spec mkdd(NetworkId, Recipient, Amount, Payload) -> Result
|
||||||
when NetworkId :: string(),
|
when NetworkId :: string(),
|
||||||
Recipient :: string(),
|
Recipient :: string(),
|
||||||
Amount :: non_neg_integer(),
|
Amount :: non_neg_integer(),
|
||||||
@ -50,10 +60,10 @@
|
|||||||
URL :: string(),
|
URL :: string(),
|
||||||
QR_PNG :: binary().
|
QR_PNG :: binary().
|
||||||
% @doc
|
% @doc
|
||||||
% Very important: amount MUST be an integer >= 0
|
% make a dead drop
|
||||||
|
|
||||||
mk_spend(NetworkId, Recipient, Amount, Payload) ->
|
mkdd(NetworkId, Recipient, Amount, Payload) ->
|
||||||
gen_server:call(?MODULE, {mk_spend, NetworkId, Recipient, Amount, Payload}).
|
gen_server:call(?MODULE, {mkdd, NetworkId, Recipient, Amount, Payload}).
|
||||||
|
|
||||||
|
|
||||||
%% gen_server callbacks
|
%% gen_server callbacks
|
||||||
@ -73,8 +83,8 @@ init(none) ->
|
|||||||
{ok, InitState}.
|
{ok, InitState}.
|
||||||
|
|
||||||
|
|
||||||
handle_call({mk_spend, NetworkId, Recipient, Amount, Payload}, From, State) ->
|
handle_call({mkdd, NetworkId, Recipient, Amount, Payload}, From, State) ->
|
||||||
case i_mk_spend(NetworkId, Recipient, Amount, Payload, From, State) of
|
case do_mkdd(NetworkId, Recipient, Amount, Payload, State) of
|
||||||
{ok, URL, PNG, NewState} -> {reply, {ok, URL, PNG}, NewState};
|
{ok, URL, PNG, NewState} -> {reply, {ok, URL, PNG}, NewState};
|
||||||
Error -> {reply, Error, State}
|
Error -> {reply, Error, State}
|
||||||
end;
|
end;
|
||||||
@ -104,67 +114,46 @@ terminate(_, _) ->
|
|||||||
%% internals
|
%% internals
|
||||||
%%-----------------------------------------------------------------------------
|
%%-----------------------------------------------------------------------------
|
||||||
|
|
||||||
-spec i_mk_spend(NetworkId, Recipient, Amount, Payload, From, State) -> Result
|
-spec do_mkdd(NetworkId, Recipient, Amount, Payload, State) -> Result
|
||||||
when NetworkId :: string(),
|
when NetworkId :: string(),
|
||||||
Recipient :: string(),
|
Recipient :: string(),
|
||||||
Amount :: non_neg_integer(),
|
Amount :: pos_integer(),
|
||||||
Payload :: binary(),
|
Payload :: binary(),
|
||||||
From :: {pid(), reference()},
|
|
||||||
State :: state(),
|
State :: state(),
|
||||||
Result :: {ok, URL, QR_PNG, NewState}
|
Result :: {ok, URL, QR_PNG, NewState}
|
||||||
| {error, string()},
|
| {error, Reason},
|
||||||
URL :: string(),
|
URL :: string(),
|
||||||
QR_PNG :: binary(),
|
QR_PNG :: binary(),
|
||||||
NewState :: state().
|
NewState :: state(),
|
||||||
|
Reason :: any().
|
||||||
|
|
||||||
i_mk_spend(NetworkId, Recipient, Amount, Payload, {FromPID, _}, State)
|
do_mkdd(NetId, Recipient, Amount, Payload, State = #s{drops = Drops}) ->
|
||||||
when is_integer(Amount), Amount >= 0,
|
HexStr = rand_hex(),
|
||||||
is_binary(Payload) ->
|
CreatedAt = now_sec(),
|
||||||
URL = gmgrids:encode({spend, NetworkId, Recipient},
|
TxStr = form_txstr(NetId, Recipient, Amount, Payload),
|
||||||
[{amount, Amount},
|
DD = #dd{created_at = CreatedAt, payload = TxStr},
|
||||||
{payload, Payload}]),
|
URL = dd_url(HexStr),
|
||||||
URLBin = unicode:characters_to_binary(URL),
|
PNG = qr:encode_png(unicode:characters_to_binary(URL)),
|
||||||
PNG = qr:encode_png(URLBin),
|
NewDrops = maps:put(HexStr, DD, Drops),
|
||||||
case i_register(Recipient, Amount, Payload, FromPID, State) of
|
NewState = State#s{drops = NewDrops},
|
||||||
{ok, NewState} -> {ok, URL, PNG, NewState};
|
{ok, URL, PNG, NewState}.
|
||||||
Error -> Error
|
|
||||||
end;
|
now_sec() ->
|
||||||
i_mk_spend(_, _, Amount, _, _, _) when (not is_integer(Amount)) ->
|
calendar:datetime_to_gregorian_seconds(calendar:universal_time()).
|
||||||
{error, "non_integer_amount"};
|
|
||||||
i_mk_spend(_, _, Amount, _, _, _) when Amount < 0 ->
|
|
||||||
{error, "negative_amount"};
|
|
||||||
i_mk_spend(_, _, _, _, _, _) ->
|
|
||||||
{error, "bad_payload"}.
|
|
||||||
|
|
||||||
|
|
||||||
i_register(Recipient, Amount, Payload, FromPID, State = #s{looking_for = Patterns}) ->
|
-spec rand_hex() -> hex().
|
||||||
SP = i_sp(Recipient, Amount, Payload),
|
rand_hex() ->
|
||||||
case i_lookup(SP, State) of
|
unicode:characters_to_binary(hexify(rand:bytes(10))).
|
||||||
not_found ->
|
|
||||||
NewPattern = {SP, FromPID},
|
|
||||||
NewPatterns = [NewPattern | Patterns],
|
|
||||||
NewState = State#s{looking_for = NewPatterns},
|
|
||||||
{ok, NewState};
|
|
||||||
{found, _} ->
|
|
||||||
{error, already_registered}
|
|
||||||
end.
|
|
||||||
|
|
||||||
%% future proofing
|
hexify(<<B:8, Rest/binary>>) when B < 16#10 -> ["0", integer_to_list(B, 16), hexify(Rest)];
|
||||||
i_sp(Recipient, Amount, Payload) ->
|
hexify(<<B:8, Rest/binary>>) -> [integer_to_list(B, 16), hexify(Rest)];
|
||||||
{sp, Recipient, Amount, Payload}.
|
hexify(<<>>) -> [].
|
||||||
|
|
||||||
|
dd_url(HexStr) ->
|
||||||
|
unicode:characters_to_list(["grids://", fewd:host(), "/1/d/", HexStr]).
|
||||||
|
|
||||||
|
|
||||||
-spec i_lookup(SearchPattern, State) -> Result
|
% ref
|
||||||
when SearchPattern :: sp(),
|
form_txstr(_NetId, _Recipient, _Amount, _Payload) ->
|
||||||
State :: state(),
|
"foobar".
|
||||||
Result :: {found, NotifyPID :: pid()}
|
|
||||||
| not_found.
|
|
||||||
|
|
||||||
% @private look up search pattern and see if we're looking for it
|
|
||||||
|
|
||||||
i_lookup(SearchPattern, State) ->
|
|
||||||
#s{looking_for = Patterns} = State,
|
|
||||||
case lists:keyfind(SearchPattern, 1, Patterns) of
|
|
||||||
false -> not_found;
|
|
||||||
{_, Notify} -> {found, Notify}
|
|
||||||
end.
|
|
||||||
|
|||||||
@ -238,9 +238,9 @@ route(Sock, get, Route, Request, Received) ->
|
|||||||
end;
|
end;
|
||||||
route(Sock, post, Route, Request, Received) ->
|
route(Sock, post, Route, Request, Received) ->
|
||||||
case Route of
|
case Route of
|
||||||
<<"/grids-spend">> -> grids_spend(Sock, Request) , Received;
|
<<"/grids-mkdd">> -> grids_mkdd(Sock, Request) , Received;
|
||||||
<<"/wfcin">> -> wfcin(Sock, Request) , Received;
|
<<"/wfcin">> -> wfcin(Sock, Request) , Received;
|
||||||
_ -> fd_httpd_utils:http_err(Sock, 404) , Received
|
_ -> fd_httpd_utils:http_err(Sock, 404) , Received
|
||||||
end;
|
end;
|
||||||
route(Sock, _, _, _, Received) ->
|
route(Sock, _, _, _, Received) ->
|
||||||
fd_httpd_utils:http_err(Sock, 404),
|
fd_httpd_utils:http_err(Sock, 404),
|
||||||
@ -324,14 +324,14 @@ ws_echo_loop(Sock, Frames, Received) ->
|
|||||||
%% grids
|
%% grids
|
||||||
%% ------------------------------
|
%% ------------------------------
|
||||||
|
|
||||||
grids_spend(Sock, #request{enctype = json,
|
grids_mkdd(Sock, #request{enctype = json,
|
||||||
body = B = #{"network_id" := NetId,
|
body = B = #{"network_id" := NetId,
|
||||||
"recipient" := Recipient,
|
"recipient" := Recipient,
|
||||||
"amount" := Amount,
|
"amount" := Amount,
|
||||||
"payload" := Payload}}) ->
|
"payload" := Payload}}) ->
|
||||||
tell("grids_spend good request: ~tp", [B]),
|
tell("grids_mkdd good request: ~tp", [B]),
|
||||||
RespObj =
|
RespObj =
|
||||||
case fd_gridsd:mk_spend(NetId, Recipient, Amount, unicode:characters_to_binary(Payload)) of
|
case fd_gridsd:mkdd(NetId, Recipient, Amount, unicode:characters_to_binary(Payload)) of
|
||||||
{ok, URL, PNG} ->
|
{ok, URL, PNG} ->
|
||||||
#{"ok" => true,
|
#{"ok" => true,
|
||||||
"result" => #{"url" => URL,
|
"result" => #{"url" => URL,
|
||||||
@ -345,8 +345,8 @@ grids_spend(Sock, #request{enctype = json,
|
|||||||
Response = #response{headers = [{"content-type", "application/json"}],
|
Response = #response{headers = [{"content-type", "application/json"}],
|
||||||
body = Body},
|
body = Body},
|
||||||
fd_httpd_utils:respond(Sock, Response);
|
fd_httpd_utils:respond(Sock, Response);
|
||||||
grids_spend(Sock, Request) ->
|
grids_mkdd(Sock, Request) ->
|
||||||
tell("grids_spend: bad request: ~tp", [Request]),
|
tell("grids_mkdd: bad request: ~tp", [Request]),
|
||||||
fd_httpd_utils:http_err(Sock, 400).
|
fd_httpd_utils:http_err(Sock, 400).
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@ -9,13 +9,15 @@
|
|||||||
-copyright("Peter Harpending <peterharpending@qpq.swiss>").
|
-copyright("Peter Harpending <peterharpending@qpq.swiss>").
|
||||||
-license("BSD-2-Clause-FreeBSD").
|
-license("BSD-2-Clause-FreeBSD").
|
||||||
|
|
||||||
-export([network_id/0, pubkey/0, akstr/0]).
|
-export([url/0, host/0, network_id/0, pubkey/0, akstr/0]).
|
||||||
-export([listen/1, ignore/0]).
|
-export([listen/1, ignore/0]).
|
||||||
-export([start/2, stop/1]).
|
-export([start/2, stop/1]).
|
||||||
|
|
||||||
-include("$zx_include/zx_logger.hrl").
|
-include("$zx_include/zx_logger.hrl").
|
||||||
|
|
||||||
|
|
||||||
|
url() -> "http://" ++ host().
|
||||||
|
host() -> "localhost:8000".
|
||||||
network_id() -> "groot.testnet".
|
network_id() -> "groot.testnet".
|
||||||
pubkey() -> pad32(<<"fewd demo">>).
|
pubkey() -> pad32(<<"fewd demo">>).
|
||||||
akstr() -> gmgrids:akstr(pubkey()).
|
akstr() -> gmgrids:akstr(pubkey()).
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user