/*
This file is part of GNUnet.
Copyright (C) 2019 GNUnet e.V.
GNUnet is free software: you can redistribute it and/or modify it
under the terms of the GNU Affero General Public License as published
by the Free Software Foundation, either version 3 of the License,
or (at your option) any later version.
GNUnet 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
Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see .
SPDX-License-Identifier: AGPL3.0-or-later
*/
/**
* @file transport/test_communicator_unix.c
* @brief test the unix communicator
* @author Julius Bünger
*/
#include "platform.h"
#include "gnunet_util_lib.h"
#include "transport-testing2.h"
#include "gnunet_ats_transport_service.h"
#include "gnunet_signatures.h"
#include "transport.h"
#include
#define LOG(kind, ...) GNUNET_log_from(kind, "test_transport_communicator_unix", __VA_ARGS__)
#define NUM_PEERS 2
static struct GNUNET_PeerIdentity peer_id[NUM_PEERS];
static struct GNUNET_TRANSPORT_TESTING_TransportCommunicatorHandle *tc_hs[NUM_PEERS];
//static char *addresses[NUM_PEERS];
#define PAYLOAD_SIZE 256
//static char payload[PAYLOAD_SIZE] = "TEST PAYLOAD";
//static char payload[] = "TEST PAYLOAD";
static uint32_t payload = 42;
static void
communicator_available_cb(void *cls,
struct GNUNET_TRANSPORT_TESTING_TransportCommunicatorHandle *tc_h,
enum GNUNET_TRANSPORT_CommunicatorCharacteristics cc,
char *address_prefix)
{
LOG(GNUNET_ERROR_TYPE_DEBUG,
"Communicator available. (cc: %u, prefix: %s)\n",
cc,
address_prefix);
}
static void
add_address_cb(void *cls,
struct GNUNET_TRANSPORT_TESTING_TransportCommunicatorHandle *tc_h,
const char *address,
struct GNUNET_TIME_Relative expiration,
uint32_t aid,
enum GNUNET_NetworkType nt)
{
LOG(GNUNET_ERROR_TYPE_DEBUG,
"New address. (addr: %s, expir: %" PRIu32 ", ID: %" PRIu32 ", nt: %u\n",
address,
expiration.rel_value_us,
aid,
nt);
//addresses[1] = GNUNET_strdup (address);
GNUNET_TRANSPORT_TESTING_transport_communicator_open_queue(tc_hs[0],
&peer_id[1],
address);
}
/**
* @brief Callback that informs whether the requested queue will be
* established
*
* Implements #GNUNET_TRANSPORT_TESTING_QueueCreateReplyCallback.
*
* @param cls Closure - unused
* @param tc_h Communicator handle - unused
* @param will_try #GNUNET_YES if queue will be established
* #GNUNET_NO if queue will not be established (bogous address)
*/
static void
queue_create_reply_cb(void *cls,
struct GNUNET_TRANSPORT_TESTING_TransportCommunicatorHandle *tc_h,
int will_try)
{
if (GNUNET_YES == will_try)
LOG(GNUNET_ERROR_TYPE_DEBUG,
"Queue will be established!\n");
else
LOG(GNUNET_ERROR_TYPE_WARNING,
"Queue won't be established (bougus address?)!\n");
}
/**
* @brief Handle opening of queue
*
* Issues sending of test data
*
* Implements #GNUNET_TRANSPORT_TESTING_AddQueueCallback
*
* @param cls Closure
* @param tc_h Communicator handle
* @param tc_queue Handle to newly opened queue
*/
static void
add_queue_cb(void *cls,
struct GNUNET_TRANSPORT_TESTING_TransportCommunicatorHandle *tc_h,
struct GNUNET_TRANSPORT_TESTING_TransportCommunicatorQueue *tc_queue)
{
LOG(GNUNET_ERROR_TYPE_DEBUG,
"Got Queue!\n");
GNUNET_TRANSPORT_TESTING_transport_communicator_send(tc_queue,
&payload,
sizeof(payload));
}
/**
* @brief Handle an incoming message
*
* Implements #GNUNET_TRANSPORT_TESTING_IncomingMessageCallback
* @param cls Closure
* @param tc_h Handle to the receiving communicator
* @param msg Received message
*/
void
incoming_message_cb(void *cls,
struct GNUNET_TRANSPORT_TESTING_TransportCommunicatorHandle *tc_h,
const struct GNUNET_MessageHeader *msg)
{
}
/**
* @brief Main function called by the scheduler
*
* @param cls Closure - Handle to configuration
*/
static void
run(void *cls)
{
struct GNUNET_CONFIGURATION_Handle *cfg = cls;
tc_hs[0] = GNUNET_TRANSPORT_TESTING_transport_communicator_service_start(
"transport",
"gnunet-communicator-unix",
"test_communicator_1.conf",
&communicator_available_cb,
NULL,
&queue_create_reply_cb,
&add_queue_cb,
NULL,
NULL); /* cls */
tc_hs[1] = GNUNET_TRANSPORT_TESTING_transport_communicator_service_start(
"transport",
"gnunet-communicator-unix",
"test_communicator_2.conf",
&communicator_available_cb,
&add_address_cb,
NULL,
&add_queue_cb,
NULL,
NULL); /* cls */
}
int
main(int argc,
char *const *argv)
{
char *cfg_filename;
char *opt_cfg_filename;
const char *xdg;
char *loglev;
char *logfile;
struct GNUNET_CONFIGURATION_Handle *cfg;
struct GNUNET_GETOPT_CommandLineOption service_options[] = {
GNUNET_GETOPT_option_cfgfile(&opt_cfg_filename),
GNUNET_GETOPT_option_help(NULL),
GNUNET_GETOPT_option_loglevel(&loglev),
GNUNET_GETOPT_option_logfile(&logfile),
GNUNET_GETOPT_OPTION_END
};
if (GNUNET_OK != GNUNET_log_setup("test_communicator_unix",
loglev,
logfile))
{
GNUNET_break(0);
return GNUNET_SYSERR;
}
xdg = getenv("XDG_CONFIG_HOME");
if (NULL != xdg)
GNUNET_asprintf(&cfg_filename,
"%s%s%s",
xdg,
DIR_SEPARATOR_STR,
GNUNET_OS_project_data_get()->config_file);
else
cfg_filename = GNUNET_strdup(GNUNET_OS_project_data_get()->user_config_file);
cfg = GNUNET_CONFIGURATION_create();
if (NULL != opt_cfg_filename)
{
if ((GNUNET_YES !=
GNUNET_DISK_file_test(opt_cfg_filename)) ||
(GNUNET_SYSERR ==
GNUNET_CONFIGURATION_load(cfg,
opt_cfg_filename)))
{
GNUNET_log(GNUNET_ERROR_TYPE_ERROR,
_("Malformed configuration file `%s', exit ...\n"),
opt_cfg_filename);
return GNUNET_SYSERR;
}
}
else
{
if (GNUNET_YES ==
GNUNET_DISK_file_test(cfg_filename))
{
if (GNUNET_SYSERR ==
GNUNET_CONFIGURATION_load(cfg,
cfg_filename))
{
GNUNET_log(GNUNET_ERROR_TYPE_ERROR,
_("Malformed configuration file `%s', exit ...\n"),
cfg_filename);
return GNUNET_SYSERR;
}
}
else
{
if (GNUNET_SYSERR ==
GNUNET_CONFIGURATION_load(cfg,
NULL))
{
GNUNET_log(GNUNET_ERROR_TYPE_ERROR,
_("Malformed configuration, exit ...\n"));
return GNUNET_SYSERR;
}
}
}
GNUNET_SCHEDULER_run(&run,
cfg);
}