mirror of
https://github.com/urbit/shrub.git
synced 2025-01-08 22:18:12 +03:00
Merge pull request #1091 from urbit/dawn-take-error
adds more rudimentary error handle to pre-boot validation
This commit is contained in:
commit
e3f2519055
83
vere/dawn.c
83
vere/dawn.c
@ -164,6 +164,24 @@ _dawn_fail(u3_noun who, u3_noun rac, u3_noun sas)
|
|||||||
u3_lo_bail();
|
u3_lo_bail();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* _dawn_need_unit(): produce a value or print error and exit
|
||||||
|
*/
|
||||||
|
static u3_noun
|
||||||
|
_dawn_need_unit(u3_noun nit, c3_c* msg_c)
|
||||||
|
{
|
||||||
|
if ( u3_nul == nit ) {
|
||||||
|
fprintf(stderr, "%s\r\n", msg_c);
|
||||||
|
// bails, won't return
|
||||||
|
u3_lo_bail();
|
||||||
|
return u3_none;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
u3_noun pro = u3k(u3t(nit));
|
||||||
|
u3z(nit);
|
||||||
|
return pro;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* _dawn_purl(): ethereum gateway url as (unit purl)
|
/* _dawn_purl(): ethereum gateway url as (unit purl)
|
||||||
*/
|
*/
|
||||||
static u3_noun
|
static u3_noun
|
||||||
@ -269,15 +287,19 @@ u3_dawn_vent(u3_noun seed)
|
|||||||
//
|
//
|
||||||
if ( c3y == u3_Host.ops_u.etn ) {
|
if ( c3y == u3_Host.ops_u.etn ) {
|
||||||
fprintf(stderr, "boot: extracting block from snapshot\r\n");
|
fprintf(stderr, "boot: extracting block from snapshot\r\n");
|
||||||
bok = u3do("bloq:snap:dawn", u3k(u3t(sap)));
|
|
||||||
|
bok = _dawn_need_unit(u3do("bloq:snap:dawn", u3k(u3t(sap))),
|
||||||
|
"boot: failed to extract "
|
||||||
|
"block from snapshot");
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
fprintf(stderr, "boot: retrieving latest block\r\n");
|
fprintf(stderr, "boot: retrieving latest block\r\n");
|
||||||
|
|
||||||
u3_noun oct = u3v_wish("bloq:give:dawn");
|
u3_noun oct = u3v_wish("bloq:give:dawn");
|
||||||
u3_noun kob = _dawn_eth_rpc(url_c, u3k(oct));
|
u3_noun kob = _dawn_eth_rpc(url_c, u3k(oct));
|
||||||
bok = u3do("bloq:take:dawn", u3k(kob));
|
|
||||||
|
|
||||||
|
bok = _dawn_need_unit(u3do("bloq:take:dawn", u3k(kob)),
|
||||||
|
"boot: block retrieval failed");
|
||||||
u3z(oct); u3z(kob);
|
u3z(oct); u3z(kob);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -287,7 +309,11 @@ u3_dawn_vent(u3_noun seed)
|
|||||||
u3_noun hul;
|
u3_noun hul;
|
||||||
|
|
||||||
if ( c3y == u3_Host.ops_u.etn ) {
|
if ( c3y == u3_Host.ops_u.etn ) {
|
||||||
hul = u3dc("hull:snap:dawn", u3k(ship), u3k(u3t(sap)));
|
fprintf(stderr, "boot: extracting public keys from snapshot\r\n");
|
||||||
|
|
||||||
|
hul = _dawn_need_unit(u3dc("hull:snap:dawn", u3k(ship), u3k(u3t(sap))),
|
||||||
|
"boot: failed to extract "
|
||||||
|
"public keys from snapshot");
|
||||||
}
|
}
|
||||||
else if ( c3__pawn == rank ) {
|
else if ( c3__pawn == rank ) {
|
||||||
// irrelevant, just bunt +hull
|
// irrelevant, just bunt +hull
|
||||||
@ -295,30 +321,37 @@ u3_dawn_vent(u3_noun seed)
|
|||||||
hul = u3v_wish("*hull:constitution:ethe");
|
hul = u3v_wish("*hull:constitution:ethe");
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
u3_noun oct;
|
u3_noun who;
|
||||||
|
|
||||||
if ( c3__earl == rank ) {
|
if ( c3__earl == rank ) {
|
||||||
u3_noun seg = u3do("^sein:title", u3k(ship));
|
who = u3do("^sein:title", u3k(ship));
|
||||||
u3_noun ges = u3dc("scot", 'p', u3k(seg));
|
|
||||||
c3_c* seg_c = u3r_string(ges);
|
|
||||||
|
|
||||||
fprintf(stderr, "boot: retrieving %s's public keys (for %s)\r\n",
|
{
|
||||||
seg_c, u3_Host.ops_u.who_c);
|
u3_noun seg = u3dc("scot", 'p', u3k(who));
|
||||||
oct = u3dc("hull:give:dawn", u3k(bok), u3k(seg));
|
c3_c* seg_c = u3r_string(seg);
|
||||||
|
|
||||||
free(seg_c);
|
fprintf(stderr, "boot: retrieving %s's public keys (for %s)\r\n",
|
||||||
u3z(seg); u3z(ges);
|
seg_c, u3_Host.ops_u.who_c);
|
||||||
|
free(seg_c);
|
||||||
|
u3z(seg);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
who = u3k(ship);
|
||||||
fprintf(stderr, "boot: retrieving %s's public keys\r\n",
|
fprintf(stderr, "boot: retrieving %s's public keys\r\n",
|
||||||
u3_Host.ops_u.who_c);
|
u3_Host.ops_u.who_c);
|
||||||
oct = u3dc("hull:give:dawn", u3k(bok), u3k(ship));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
u3_noun luh = _dawn_eth_rpc(url_c, u3k(oct));
|
{
|
||||||
hul = u3dc("hull:take:dawn", u3k(ship), u3k(luh));
|
u3_noun oct = u3dc("hull:give:dawn", u3k(bok), u3k(who));
|
||||||
|
u3_noun luh = _dawn_eth_rpc(url_c, u3k(oct));
|
||||||
|
|
||||||
u3z(oct); u3z(luh);
|
hul = _dawn_need_unit(u3dc("hull:take:dawn", u3k(ship), u3k(luh)),
|
||||||
|
"boot: failed to retrieve public keys");
|
||||||
|
u3z(oct); u3z(luh);
|
||||||
|
}
|
||||||
|
|
||||||
|
u3z(who);
|
||||||
}
|
}
|
||||||
|
|
||||||
// +live:dawn: network state
|
// +live:dawn: network state
|
||||||
@ -351,15 +384,20 @@ u3_dawn_vent(u3_noun seed)
|
|||||||
// (map ship [=life =pass]): galaxy table
|
// (map ship [=life =pass]): galaxy table
|
||||||
//
|
//
|
||||||
if ( c3y == u3_Host.ops_u.etn ) {
|
if ( c3y == u3_Host.ops_u.etn ) {
|
||||||
zar = u3do("czar:snap:dawn", u3k(u3t(sap)));
|
fprintf(stderr, "boot: extracting galaxy table from snapshot\r\n");
|
||||||
|
|
||||||
|
zar = _dawn_need_unit(u3do("czar:snap:dawn", u3k(u3t(sap))),
|
||||||
|
"boot: failed to extract "
|
||||||
|
"galaxy table from snapshot");
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
fprintf(stderr, "boot: retrieving galaxy table\r\n");
|
fprintf(stderr, "boot: retrieving galaxy table\r\n");
|
||||||
|
|
||||||
u3_noun oct = u3do("czar:give:dawn", u3k(bok));
|
u3_noun oct = u3do("czar:give:dawn", u3k(bok));
|
||||||
u3_noun raz = _dawn_eth_rpc(url_c, u3k(oct));
|
u3_noun raz = _dawn_eth_rpc(url_c, u3k(oct));
|
||||||
zar = u3do("czar:take:dawn", u3k(raz));
|
|
||||||
|
|
||||||
|
zar = _dawn_need_unit(u3do("czar:take:dawn", u3k(raz)),
|
||||||
|
"boot: failed to retrieve galaxy table");
|
||||||
u3z(oct); u3z(raz);
|
u3z(oct); u3z(raz);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -369,15 +407,20 @@ u3_dawn_vent(u3_noun seed)
|
|||||||
tuf = _dawn_turf(u3_Host.ops_u.dns_c);
|
tuf = _dawn_turf(u3_Host.ops_u.dns_c);
|
||||||
}
|
}
|
||||||
else if ( c3y == u3_Host.ops_u.etn ) {
|
else if ( c3y == u3_Host.ops_u.etn ) {
|
||||||
tuf = u3do("turf:snap:dawn", u3k(u3t(sap)));
|
fprintf(stderr, "boot: extracting network domains from snapshot\r\n");
|
||||||
|
|
||||||
|
tuf = _dawn_need_unit(u3do("turf:snap:dawn", u3k(u3t(sap))),
|
||||||
|
"boot: failed to extract "
|
||||||
|
"network domains from snapshot");
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
fprintf(stderr, "boot: retrieving network domains\r\n");
|
fprintf(stderr, "boot: retrieving network domains\r\n");
|
||||||
|
|
||||||
u3_noun oct = u3do("turf:give:dawn", u3k(bok));
|
u3_noun oct = u3do("turf:give:dawn", u3k(bok));
|
||||||
u3_noun fut = _dawn_eth_rpc(url_c, u3k(oct));
|
u3_noun fut = _dawn_eth_rpc(url_c, u3k(oct));
|
||||||
tuf = u3do("turf:take:dawn", u3k(fut));
|
|
||||||
|
|
||||||
|
tuf = _dawn_need_unit(u3do("turf:take:dawn", u3k(fut)),
|
||||||
|
"boot: failed to retrieve network domains");
|
||||||
u3z(oct); u3z(fut);
|
u3z(oct); u3z(fut);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user