start draft of gnunet-transport
authorChristian Grothoff <christian@grothoff.org>
Wed, 26 Oct 2011 08:59:07 +0000 (08:59 +0000)
committerChristian Grothoff <christian@grothoff.org>
Wed, 26 Oct 2011 08:59:07 +0000 (08:59 +0000)
src/transport/gnunet-transport.c

index cd883fee3a962e6a2825d000e12d42553a39fe93..419a0cdc3a9525c7183671a0035072a491fc81ff 100644 (file)
 #include "gnunet_protocols.h"
 #include "gnunet_transport_service.h"
 
+static char *cpid;
+
+static struct GNUNET_TRANSPORT_Handle *handle;
+
+static void
+do_disconnect (void *cls,
+              const struct GNUNET_SCHEDULER_TaskContext *tc)
+{
+  GNUNET_TRANSPORT_disconnect (handle);  
+}
+
+
+/**
+ * Main function that will be run by the scheduler.
+ *
+ * @param cls closure
+ * @param args remaining command-line arguments
+ * @param cfgfile name of the configuration file used (for saving, can be NULL!)
+ * @param cfg configuration
+ */
+static void
+run (void *cls, char *const *args, const char *cfgfile,
+     const struct GNUNET_CONFIGURATION_Handle *cfg)
+{
+  struct GNUNET_PeerIdentity pid;
+  if (NULL != cpid)
+  {
+    handle = GNUNET_TRANSPORT_connect (cfg, NULL, NULL,
+                                      NULL, NULL, NULL);
+    if (GNUNET_OK !=
+       GNUNET_CRYPTO_hash_from_string (cpid, &pid.hashPubKey))
+    {
+      fprintf (stderr,
+              _("Failed to parse peer identity `%s'\n"),
+              cpid);
+      GNUNET_TRANSPORT_disconnect (handle);
+      return;
+    }
+    GNUNET_TRANSPORT_try_connect (handle, &pid);
+    GNUNET_SCHEDULER_add_delayed (GNUNET_TIME_UNIT_SECONDS,
+                                 &do_disconnect,
+                                 NULL);
+  }
+}
+
+
 int
 main (int argc, char *const *argv)
 {
-  return 0;
+  static const struct GNUNET_GETOPT_CommandLineOption options[] = {
+    {'C', "connect", "PEER",
+     gettext_noop ("try to connect to the given peer"),
+     0, &GNUNET_GETOPT_set_string, &cpid},
+    GNUNET_GETOPT_OPTION_END
+  };
+  return (GNUNET_OK ==
+          GNUNET_PROGRAM_run (argc, argv, "gnunet-transport",
+                              gettext_noop ("Direct access to transport service."),
+                              options, &run, NULL)) ? 0 : 1;
 }