[fix] changed path to app to julian's home instate oft tobias's should change that completly

This commit is contained in:
Julian Sparber
2017-08-15 12:00:21 +02:00
parent 3cdafec827
commit cc74445f13
5 changed files with 79 additions and 41 deletions

View File

@@ -24,16 +24,6 @@ finished (SoupSession *session, SoupMessage *msg, gpointer loop)
g_main_loop_quit (loop);
}
char*
concat(const char *s1, const char *s2)
{
char *result = malloc(strlen(s1)+strlen(s2)+1);//+1 for the zero-terminator
//in real code you would check for errors in malloc here
strcpy(result, s1);
strcat(result, s2);
return result;
}
int
get (char *url, const gchar *output_file_path)
{
@@ -59,9 +49,9 @@ get (char *url, const gchar *output_file_path)
loop = g_main_loop_new (NULL, TRUE);
const char *name;
SoupMessage *msg;
const char *header;
const char *name;
FILE *output_file = NULL;
msg = soup_message_new ("GET", url);
@@ -80,18 +70,23 @@ get (char *url, const gchar *output_file_path)
if (SOUP_STATUS_IS_REDIRECTION (msg->status_code)) {
g_print ("%s: %d %s\n", name, msg->status_code, msg->reason_phrase);
} else if (SOUP_STATUS_IS_SUCCESSFUL (msg->status_code)) {
g_print ("###########Name: %s\n", concat(output_file_path, name));
output_file = fopen (concat(output_file_path, "name"), "w");
if (!output_file)
g_printerr ("Error trying to create file %s.\n", output_file_path);
//if there is no file name and path the page will not get saved
if (output_file_path == NULL) {
g_print ("Got a file offered form a other peer. Will not save anything.\n");
}
else {
output_file = fopen (output_file_path, "w");
if (!output_file)
g_printerr ("Error trying to create file %s.\n", output_file_path);
if (output_file) {
fwrite (msg->response_body->data,
1,
msg->response_body->length,
output_file);
if (output_file) {
fwrite (msg->response_body->data,
1,
msg->response_body->length,
output_file);
fclose (output_file);
fclose (output_file);
}
}
}
@@ -100,20 +95,17 @@ get (char *url, const gchar *output_file_path)
return 0;
}
//int do_get_request (char * url)
int do_client_notify (char * url)
{
//url and absoulte path to download dir
//get ("http://juliansparber.com/index.html", "./test_download");
get (g_strdup(url),"./test_download");
get (g_strdup(url), NULL);
return 0;
}
int do_downloading (char * url)
int do_downloading (char * url, char * file_name)
{
g_print("Downloading url %s\n", url);
//get (g_strdup(url),"./test_download");
get ("http://juliansparber.com/index.html", "./test_download");
//get ("http://juliansparber.com/index.html", "./test_download");
return 0;
}
@@ -121,5 +113,5 @@ int do_downloading (char * url)
/*int main () {
get ("http://juliansparber.com/index.html", "./test_download");
return 0;
}
*/
}
*/

View File

@@ -2,7 +2,7 @@
#define __GET_H
extern int do_downloading(char *);
extern int do_downloading(char *, const char *);
extern int do_client_notify(char *);
#endif /* __GET_H */

View File

@@ -1,6 +1,6 @@
[Desktop Entry]
Name=Teleport
Exec=/home/tobi/code/teleport/src/teleportapp
Exec=/home/julian/Projects/teleport/src/teleportapp
Icon=utilities-terminal
Type=Application
Categories=GTK;GNOME;Utility;

View File

@@ -231,7 +231,7 @@ do_get_response_json (SoupServer *server, SoupMessage *msg, const char *path)
}
static void handle_incoming_file(const char * hash, const char * name, const char * size, const char * origin) {
//If the user accepts the file
do_downloading(g_strdup_printf("http://%s:%d/transfer/%s", origin, port, hash));
do_downloading(g_strdup_printf("http://%s:%d/transfer/%s", origin, port, hash), name);
g_print("Got a new file form %s with size:%s with title: %s\n", origin, size, name);
}
@@ -320,7 +320,8 @@ int addRouteToServer(char *name, char *file_to_send, char *destination) {
//send notification of avabile file to the client
//For getting file size
//https://developer.gnome.org/gio/stable/GFile.html#g-file-query-info
do_client_notify(g_strdup_printf("http://%s:%d/?token=%s&size=0&name=%s\n", destination, port, name, file_to_send));
do_client_notify(g_strdup_printf("http://%s:%d/?token=%s&size=0&name=%s\n", destination, port,
name, file_to_send));
return 0;
}

View File

@@ -7,7 +7,13 @@
#include "publish.h"
#include "server.h"
enum {
NOTIFY_USER, NOTIFY_FINISED, N_SIGNALS
};
static TeleportAppWindow *win;
static GApplication *application;
static gint signalIds [N_SIGNALS];
struct _TeleportApp
{
@@ -17,6 +23,32 @@ struct _TeleportApp
G_DEFINE_TYPE(TeleportApp, teleport_app, GTK_TYPE_APPLICATION);
static void create_user_notification (const char *file_name, const int file_size, const char * origin_device)
{
GNotification *notification = g_notification_new ("Teleport");
g_notification_set_body (notification, g_strdup_printf("%s is sending %s (%d Byte)", origin_device, file_name, file_size));
GIcon *icon = g_themed_icon_new ("dialog-information");
g_notification_set_icon (notification, icon);
g_notification_add_button (notification, "Decline", "app.reply-5-minutes");
g_notification_add_button (notification, "Save", "app.reply-5-minutes");
g_application_send_notification (application, NULL, notification);
g_object_unref (icon);
g_object_unref (notification);
}
static void create_finished_notification (const char *file_name, const int file_size, const char * origin_device)
{
GNotification *notification = g_notification_new ("Teleport");
g_notification_set_body (notification, g_strdup_printf("Transfer %s from %s is complete)", file_name, origin_device));
GIcon *icon = g_themed_icon_new ("dialog-information");
g_notification_set_icon (notification, icon);
g_notification_add_button (notification, "Open", "app.reply-5-minutes");
g_application_send_notification (application, NULL, notification);
g_object_unref (icon);
g_object_unref (notification);
}
gboolean mainLoopAddPeerCallback (gpointer name) {
update_remote_device_list(win, (char*)name);
return G_SOURCE_REMOVE;
@@ -35,6 +67,10 @@ void callback_remove_peer(GObject * instance, char * name, TeleportAppWindow * w
g_idle_add(mainLoopRemovePeerCallback, g_strdup(name));
}
void callback_notify_user(GObject * instance, char * name, TeleportAppWindow * win ) {
create_user_notification("icon.png", 2000, "Mark's laptop");
}
static void
teleport_app_init (TeleportApp *app)
{
@@ -52,6 +88,7 @@ teleport_app_activate (GApplication *app)
g_signal_connect (peerList, "addpeer", (GCallback)callback_add_peer, win);
g_signal_connect (peerList, "removepeer", (GCallback)callback_remove_peer, win);
g_signal_connect (app, "notify_user", (GCallback)callback_notify_user, win);
/*teleport_peer_add_peer(peerList, "julian", "192.168.0.1", 3000);
g_print("Data: %s\n", teleport_peer_get_name(peerList, 0, NULL));
g_print("Data: %s\n", teleport_peer_get_ip(peerList, 0, NULL));
@@ -60,14 +97,7 @@ teleport_app_activate (GApplication *app)
run_http_server();
run_avahi_publish_service("Angela's (self)");
run_avahi_service(peerList);
GNotification *notification = g_notification_new ("Hello world!");
g_notification_set_body (notification, "This is an example notification.");
GIcon *icon = g_themed_icon_new ("dialog-information");
g_notification_set_icon (notification, icon);
g_notification_add_button (notification, "5 minutes", "app.reply-5-minutes");
g_application_send_notification (app, NULL, notification);
g_object_unref (icon);
g_object_unref (notification);
application = app;
}
static void
@@ -96,6 +126,19 @@ teleport_app_class_init (TeleportAppClass *class)
{
G_APPLICATION_CLASS (class)->activate = teleport_app_activate;
G_APPLICATION_CLASS (class)->open = teleport_app_open;
signalIds[NOTIFY_USER] = g_signal_new ("notify_user",
G_TYPE_OBJECT,
G_SIGNAL_RUN_LAST | G_SIGNAL_NO_RECURSE | G_SIGNAL_NO_HOOKS,
0,
NULL /* accumulator */,
NULL /* accumulator data */,
NULL /* C marshaller */,
G_TYPE_NONE /* return_type */,
1,
G_TYPE_STRING);
}
TeleportApp *
@@ -106,3 +149,5 @@ teleport_app_new (void)
"flags", G_APPLICATION_HANDLES_OPEN,
NULL);
}