mirror of
https://github.com/netsurf-browser/netsurf
synced 2025-01-14 22:59:20 +03:00
49ce807e3c
A somewhat better implementation of referrers which no longer sends the referer if the URL schemes don't match. Things to do: 1) Preservation of referer across redirects (see comment in browser.c:284) 2) GUI templates/code for configuration of referer sending (simple on/off toggle only) 3) Make referer sending when fetching objects/stylesheets for a page pay attention to option_send_referer? 4) Handle the case where the referer is in the form of http://moo:foo@mysite.com/ (ie the login details embedded in the referer - not good). svn path=/import/netsurf/; revision=1297
99 lines
2.2 KiB
C
99 lines
2.2 KiB
C
/*
|
|
* This file is part of NetSurf, http://netsurf.sourceforge.net/
|
|
* Licensed under the GNU General Public License,
|
|
* http://www.opensource.org/licenses/gpl-license
|
|
* Copyright 2003 Rob Jackson <jacko@xms.ms>
|
|
*/
|
|
|
|
#include <stdbool.h>
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include "oslib/uri.h"
|
|
#include "oslib/wimp.h"
|
|
#include "netsurf/utils/config.h"
|
|
#include "netsurf/content/fetch.h"
|
|
#include "netsurf/desktop/browser.h"
|
|
#include "netsurf/riscos/theme.h"
|
|
#include "netsurf/desktop/gui.h"
|
|
#include "netsurf/riscos/gui.h"
|
|
#include "netsurf/riscos/url_protocol.h"
|
|
#include "netsurf/utils/log.h"
|
|
#include "netsurf/utils/utils.h"
|
|
|
|
#ifdef WITH_URI
|
|
|
|
void ro_uri_message_received(uri_full_message_process*);
|
|
bool ro_uri_launch(char *uri);
|
|
void ro_uri_bounce(uri_full_message_return_result*);
|
|
|
|
extern wimp_t task_handle;
|
|
|
|
|
|
void ro_uri_message_received(uri_full_message_process* uri_message)
|
|
{
|
|
uri_h uri_handle;
|
|
char* uri_requested;
|
|
int uri_length;
|
|
|
|
uri_handle = uri_message->handle;
|
|
|
|
if (!fetch_can_fetch(uri_message->uri)) return;
|
|
|
|
uri_message->your_ref = uri_message->my_ref;
|
|
uri_message->action = message_URI_PROCESS_ACK;
|
|
|
|
xwimp_send_message(wimp_USER_MESSAGE,
|
|
(wimp_message*)uri_message,
|
|
uri_message->sender);
|
|
|
|
xuri_request_uri(0, 0, 0, uri_handle, &uri_length);
|
|
uri_requested = xcalloc((unsigned int)uri_length, sizeof(char));
|
|
|
|
if (uri_requested == NULL)
|
|
return;
|
|
|
|
xuri_request_uri(0, uri_requested, uri_length, uri_handle, NULL);
|
|
|
|
browser_window_create(uri_requested, NULL, 0);
|
|
|
|
xfree(uri_requested);
|
|
}
|
|
|
|
bool ro_uri_launch(char *uri) {
|
|
|
|
uri_h uri_handle;
|
|
wimp_t handle_task;
|
|
uri_dispatch_flags returned;
|
|
os_error *e;
|
|
|
|
e = xuri_dispatch(uri_DISPATCH_INFORM_CALLER, uri, task_handle,
|
|
&returned, &handle_task, &uri_handle);
|
|
|
|
if (e || returned & 1) {
|
|
return false;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
void ro_uri_bounce(uri_full_message_return_result *message) {
|
|
|
|
char uri_buf[512];
|
|
os_error *e;
|
|
|
|
if ((message->flags & 1) == 0) return;
|
|
|
|
e = xuri_request_uri(0, uri_buf, sizeof uri_buf, message->handle, 0);
|
|
|
|
if (e) {
|
|
LOG(("xuri_request_uri: %d: %s", e->errnum, e->errmess));
|
|
return;
|
|
}
|
|
|
|
ro_url_load(uri_buf);
|
|
|
|
return;
|
|
}
|
|
#endif
|