/* mcookie - generate a 128-bit random number (used for X "magic cookies")
*
* Copyright 2019 AD Isaac Dunham <ibid.ag@gmail.com>
*
* No standard.
*
* -f and -m are not supported: md5sums of arbitrary files are not a good
* source of entropy, just ask the system for 128 bits and print it.
USE_MCOOKIE(NEWTOY(mcookie, "v(verbose)V(version)", TOYFLAG_USR|TOYFLAG_BIN))
config MCOOKIE
bool "mcookie"
default y
help
usage: mcookie [-vV]
Generate a 128-bit strong random number.
-v show entropy source (verbose)
-V show version
*/
#define FOR_mcookie
#include "toys.h"
void mcookie_main(void)
{
long long *ll = (void *)toybuf;
if (FLAG(V)) return (void)puts("mcookie from toybox");
xgetrandom(toybuf, 16, 0);
if (FLAG(v)) fputs("Got 16 bytes from xgetrandom()\n", stderr);
xprintf("%016llx%06llx\n", ll[0], ll[1]);
}