libzmq/tools/curve_keygen.cpp

56 lines
2.1 KiB
C++
Raw Normal View History

/*
2014-01-02 12:00:57 +01:00
Copyright (c) 2007-2014 Contributors as noted in the AUTHORS file
This file is part of 0MQ.
2013-09-09 19:58:31 +02:00
This tool generates a CurveZMQ keypair, as two printable strings you can
use in configuration files or source code. The encoding uses Z85, which
is a base-85 format that is described in 0MQ RFC 32, and which has an
implementation in the z85_codec.h source used by this tool. The keypair
always works with the secret key held by one party and the public key
2013-09-09 19:58:31 +02:00
distributed (securely!) to peers wishing to connect to it.
0MQ is free software; you can redistribute it and/or modify it under
the terms of the GNU Lesser General Public License as published by
the Free Software Foundation; either version 3 of the License, or
(at your option) any later version.
0MQ is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include <stdlib.h>
2013-09-26 11:35:52 +02:00
#include <assert.h>
2013-09-29 22:05:27 +02:00
#include <zmq.h>
int main (void)
{
2013-09-09 19:58:31 +02:00
puts ("This tool generates a CurveZMQ keypair, as two printable strings you can");
puts ("use in configuration files or source code. The encoding uses Z85, which");
puts ("is a base-85 format that is described in 0MQ RFC 32, and which has an");
puts ("implementation in the z85_codec.h source used by this tool. The keypair");
puts ("always works with the secret key held by one party and the public key");
2013-09-09 19:58:31 +02:00
puts ("distributed (securely!) to peers wishing to connect to it.");
2013-09-29 22:05:27 +02:00
char public_key [41];
char secret_key [41];
if (zmq_curve_keypair (public_key, secret_key)) {
if (zmq_errno () == ENOTSUP)
2013-09-29 22:05:27 +02:00
puts ("To use curve_keygen, please install libsodium and then rebuild libzmq.");
exit (1);
}
puts ("\n== CURVE PUBLIC KEY ==");
2013-09-29 22:05:27 +02:00
puts (public_key);
puts ("\n== CURVE SECRET KEY ==");
2013-09-29 22:05:27 +02:00
puts (secret_key);
exit (0);
}