2 This file is part of GNUnet.
5 GNUnet is free software: you can redistribute it and/or modify it
6 under the terms of the GNU Affero General Public License as published
7 by the Free Software Foundation, either version 3 of the License,
8 or (at your option) any later version.
10 GNUnet is distributed in the hope that it will be useful, but
11 WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 Affero General Public License for more details.
15 You should have received a copy of the GNU Affero General Public License
16 along with this program. If not, see <http://www.gnu.org/licenses/>.
18 SPDX-License-Identifier: AGPL3.0-or-later
22 * @file peerstore/gnunet-peerstore.c
23 * @brief peerstore tool
24 * @author Omar Tarabai
27 #include "gnunet_util_lib.h"
28 #include "gnunet_peerstore_service.h"
33 * Handle to PEERSTORE service
35 static struct GNUNET_PEERSTORE_Handle *peerstore_handle;
44 shutdown_task (void *cls)
46 if (NULL != peerstore_handle)
48 GNUNET_PEERSTORE_disconnect (peerstore_handle, GNUNET_YES);
49 peerstore_handle = NULL;
55 * Main function that will be run by the scheduler.
58 * @param args remaining command-line arguments
59 * @param cfgfile name of the configuration file used (for saving, can be NULL!)
60 * @param cfg configuration
66 const struct GNUNET_CONFIGURATION_Handle *cfg)
68 GNUNET_SCHEDULER_add_shutdown (&shutdown_task,
70 peerstore_handle = GNUNET_PEERSTORE_connect (cfg);
71 GNUNET_assert (NULL != peerstore_handle);
77 * The main function to peerstore.
79 * @param argc number of arguments from the command line
80 * @param argv command line arguments
81 * @return 0 ok, 1 on error
84 main (int argc, char *const *argv)
86 static const struct GNUNET_GETOPT_CommandLineOption options[] = {
87 GNUNET_GETOPT_OPTION_END
90 GNUNET_PROGRAM_run (argc, argv, "gnunet-peerstore [options [value]]",
91 gettext_noop ("peerstore"), options, &run,
95 /* end of gnunet-peerstore.c */