int main (int argc, char *argv[]) { #if START_DAEMON struct GNUNET_OS_Process *daemon; #endif int ok; struct GNUNET_ECRS_URI *uri; char *filename = NULL; char *keywords[] = { "fsui_foo", "fsui_bar", }; char keyword[40]; char *fn; int prog; struct GNUNET_MetaData *meta; struct GNUNET_ECRS_URI *kuri; struct GNUNET_GC_Configuration *cfg; struct GNUNET_FSUI_UploadList *upload = NULL; struct GNUNET_FSUI_SearchList *search = NULL; struct GNUNET_FSUI_UnindexList *unindex = NULL; struct GNUNET_FSUI_DownloadList *download = NULL; cfg = GNUNET_GC_create (); if (-1 == GNUNET_GC_parse_configuration (cfg, "check.conf")) { GNUNET_GC_free (cfg); return -1; } #if START_DAEMON daemon = GNUNET_daemon_start (NULL, cfg, "peer.conf", GNUNET_NO); GNUNET_GE_ASSERT (NULL, daemon != NULL); CHECK (GNUNET_OK == GNUNET_wait_for_daemon_running (NULL, cfg, 60 * GNUNET_CRON_SECONDS)); #endif GNUNET_thread_sleep (5 * GNUNET_CRON_SECONDS); /* give apps time to start */ ok = GNUNET_YES; /* ACTUAL TEST CODE */ ctx = GNUNET_FSUI_start (NULL, cfg, "basic_fsui_test", 32, /* thread pool size */ GNUNET_NO, /* no resume */ &eventCallback, NULL); CHECK (ctx != NULL); filename = makeName (42); GNUNET_disk_file_write (NULL, filename, "foo bar test!", strlen ("foo bar test!"), "600"); meta = GNUNET_meta_data_create (); kuri = GNUNET_ECRS_keyword_command_line_to_uri (NULL, 2, (const char **) keywords); /* upload */ upload = GNUNET_FSUI_upload_start (ctx, filename, (GNUNET_FSUI_DirectoryScanCallback) & GNUNET_disk_directory_scan, NULL, 0, /* anonymity */ 0, /* priority */ GNUNET_YES, GNUNET_NO, GNUNET_NO, GNUNET_get_time () + 5 * GNUNET_CRON_HOURS, meta, kuri, kuri); CHECK (upload != NULL); GNUNET_ECRS_uri_destroy (kuri); GNUNET_meta_data_destroy (meta); prog = 0; while (lastEvent != GNUNET_FSUI_upload_completed) { prog++; CHECK (prog < 10000) GNUNET_thread_sleep (50 * GNUNET_CRON_MILLISECONDS); if (GNUNET_shutdown_test () == GNUNET_YES) break; } /* search */ GNUNET_snprintf (keyword, 40, "+%s +%s", keywords[0], keywords[1]); uri = GNUNET_ECRS_keyword_string_to_uri (NULL, keyword); search = GNUNET_FSUI_search_start (ctx, 0, uri); GNUNET_ECRS_uri_destroy (uri); CHECK (search != NULL); prog = 0; while (lastEvent != GNUNET_FSUI_search_result) { prog++; CHECK (prog < 10000); GNUNET_thread_sleep (50 * GNUNET_CRON_MILLISECONDS); if (GNUNET_shutdown_test () == GNUNET_YES) break; } GNUNET_FSUI_search_abort (search); GNUNET_FSUI_search_stop (search); /* download */ fn = makeName (43); download = GNUNET_FSUI_download_start (ctx, 0, GNUNET_NO, search_uri, search_meta, fn, NULL, NULL); GNUNET_free (fn); prog = 0; while (lastEvent != GNUNET_FSUI_download_completed) { prog++; CHECK (prog < 10000); GNUNET_thread_sleep (50 * GNUNET_CRON_MILLISECONDS); if (GNUNET_shutdown_test () == GNUNET_YES) break; } GNUNET_FSUI_download_stop (download); download = NULL; GNUNET_ECRS_uri_destroy (search_uri); GNUNET_meta_data_destroy (search_meta); /* unindex */ unindex = GNUNET_FSUI_unindex_start (ctx, filename); prog = 0; while (lastEvent != GNUNET_FSUI_unindex_completed) { prog++; CHECK (prog < 10000); GNUNET_thread_sleep (50 * GNUNET_CRON_MILLISECONDS); if (GNUNET_shutdown_test () == GNUNET_YES) break; } if (lastEvent != GNUNET_FSUI_unindex_completed) GNUNET_FSUI_unindex_abort (unindex); GNUNET_FSUI_unindex_stop (unindex); /* END OF TEST CODE */ FAILURE: if (ctx != NULL) GNUNET_FSUI_stop (ctx); if (filename != NULL) { UNLINK (filename); GNUNET_free (filename); } if (download != NULL) { GNUNET_FSUI_download_abort (download); GNUNET_FSUI_download_stop (download); } filename = makeName (43); /* TODO: verify file 'filename(42)' == file 'filename(43)' */ UNLINK (filename); GNUNET_free (filename); #if START_DAEMON GNUNET_GE_ASSERT (NULL, GNUNET_OK == GNUNET_daemon_stop (NULL, daemon)); GNUNET_OS_process_destroy (daemon); #endif GNUNET_GC_free (cfg); return (ok == GNUNET_YES) ? 0 : 1; }
/** * Listen to the pipe, decode messages and send to core. */ static void * listenAndDistribute (void *unused) { char *line; unsigned int linesize; SMTPMessage *mp; FILE *fdes; char *retl; char *out; unsigned int size; GNUNET_TransportPacket *coreMP; int fd; unsigned int pos; linesize = ((GNUNET_MAX_BUFFER_SIZE * 4 / 3) + 8) * (MAX_CHAR_PER_LINE + 2) / MAX_CHAR_PER_LINE; /* maximum size of a line supported */ line = GNUNET_malloc (linesize + 2); /* 2 bytes for off-by-one errors, just to be safe... */ #define READLINE(l,limit) \ do { retl = fgets(l, (limit), fdes); \ if ( (retl == NULL) || (smtp_shutdown == GNUNET_YES)) {\ goto END; \ }\ if (core_api->load_monitor != NULL) \ GNUNET_network_monitor_notify_transmission(core_api->load_monitor, GNUNET_ND_DOWNLOAD, strlen(retl)); \ } while (0) while (smtp_shutdown == GNUNET_NO) { fd = OPEN (pipename, O_RDONLY | O_ASYNC); if (fd == -1) { if (smtp_shutdown == GNUNET_NO) GNUNET_thread_sleep (5 * GNUNET_CRON_SECONDS); continue; } fdes = fdopen (fd, "r"); while (smtp_shutdown == GNUNET_NO) { /* skip until end of header */ do { READLINE (line, linesize); } while ((line[0] != '\r') && (line[0] != '\n')); /* expect newline */ READLINE (line, linesize); /* read base64 encoded message; decode, process */ pos = 0; while (1) { pos = strlen (line) - 1; /* ignore new line */ READLINE (&line[pos], linesize - pos); /* read base64 encoded message; decode, process */ if ((line[pos] == '\r') || (line[pos] == '\n')) break; /* empty line => end of message! */ } size = GNUNET_STRINGS_base64_decode (line, pos, &out); if (size < sizeof (SMTPMessage)) { GNUNET_GE_BREAK (ectx, 0); GNUNET_free (out); goto END; } mp = (SMTPMessage *) &out[size - sizeof (SMTPMessage)]; if (ntohs (mp->header.size) != size) { GNUNET_GE_LOG (ectx, GNUNET_GE_WARNING | GNUNET_GE_BULK | GNUNET_GE_USER, _("Received malformed message via %s. Ignored.\n"), "SMTP"); #if DEBUG_SMTP GNUNET_GE_LOG (ectx, GNUNET_GE_DEBUG | GNUNET_GE_REQUEST | GNUNET_GE_USER, "Size returned by base64=%d, in the msg=%d.\n", size, ntohl (mp->size)); #endif GNUNET_free (out); goto END; } if (stats != NULL) stats->change (stat_bytesReceived, size); coreMP = GNUNET_new (GNUNET_TransportPacket); coreMP->msg = out; coreMP->size = size - sizeof (SMTPMessage); coreMP->tsession = NULL; coreMP->sender = mp->sender; #if DEBUG_SMTP GNUNET_GE_LOG (ectx, GNUNET_GE_DEBUG | GNUNET_GE_REQUEST | GNUNET_GE_USER, "SMTP message passed to the core.\n"); #endif core_api->receive (coreMP); } END: #if DEBUG_SMTP GNUNET_GE_LOG (ectx, GNUNET_GE_DEBUG | GNUNET_GE_REQUEST | GNUNET_GE_USER, "SMTP message processed.\n"); #endif if (fdes != NULL) fclose (fdes); } GNUNET_free (line); return NULL; }