Atari: Move to new HTTP auth API.

This commit is contained in:
Michael Drake 2018-08-14 11:34:30 +01:00 committed by Michael Drake
parent c55a31aa11
commit 66a97b863c
3 changed files with 35 additions and 22 deletions

View File

@ -767,23 +767,30 @@ static void gui_set_clipboard(const char *buffer, size_t length,
} }
static void gui_401login_open(nsurl *url, const char *realm, static void gui_401login_open(nsurl *url, const char *realm,
nserror (*cb)(bool proceed, void *pw), void *cbpw) const char *username, const char *password,
nserror (*cb)(const char *username,
const char *password,
void *pw),
void *cbpw)
{ {
bool bres; bool bres;
char * out = NULL; char * u_out = NULL;
bres = login_form_do( url, (char*)realm, &out); char * p_out = NULL;
bres = login_form_do(url, (char*)realm, &u_out, &p_out);
if (bres) { if (bres) {
NSLOG(netsurf, INFO, "url: %s, realm: %s, auth: %s\n", NSLOG(netsurf, INFO, "url: %s, realm: %s, auth: %s\n",
nsurl_access(url), realm, out); nsurl_access(url), realm, out);
urldb_set_auth_details(url, realm, out);
}
if (out != NULL) {
free( out );
} }
if (cb != NULL) { if (cb != NULL) {
cb(bres, cbpw); cb(u_out, p_out, cbpw);
}
if (u_out != NULL) {
free(u_out);
}
if (p_out != NULL) {
free(p_out);
} }
} }
static nserror static nserror

View File

@ -34,7 +34,7 @@
#include "atari/res/netsurf.rsh" #include "atari/res/netsurf.rsh"
bool login_form_do(nsurl * url, char * realm, char ** out) bool login_form_do(nsurl * url, char * realm, char ** u_out char ** p_out)
{ {
char user[255]; char user[255];
char pass[255]; char pass[255];
@ -45,8 +45,6 @@ bool login_form_do(nsurl * url, char * realm, char ** out)
user[0] = 0; user[0] = 0;
pass[0] = 0; pass[0] = 0;
// TODO: use auth details for predefined login data
// auth = urldb_get_auth_details(url, realm);
tree = gemtk_obj_get_tree(LOGIN); tree = gemtk_obj_get_tree(LOGIN);
assert(tree != NULL); assert(tree != NULL);
@ -57,10 +55,18 @@ bool login_form_do(nsurl * url, char * realm, char ** out)
get_string(tree, LOGIN_TB_USER, user); get_string(tree, LOGIN_TB_USER, user);
get_string(tree, LOGIN_TB_PASSWORD, pass); get_string(tree, LOGIN_TB_PASSWORD, pass);
int size = strlen((char*)&user) + strlen((char*)&pass) + 2 ; int size = strlen((char*)&user) + strlen((char*)&pass) + 2 ;
*out = malloc(size); *u_out = malloc(strlen((char*)&user) + 1);
snprintf(*out, size, "%s:%s", user, pass); *p_out = malloc(strlen((char*)&pass) + 1);
if (u_out == NULL || p_out == NULL) {
free(*u_out);
free(*p_out);
return false;
}
memcpy(*u_out, (char*)&user, strlen((char*)&user) + 1);
memcpy(*p_out, (char*)&pass, strlen((char*)&pass) + 1);
} else { } else {
*out = NULL; *u_out = NULL;
*p_out = NULL;
} }
return((exit_obj == LOGIN_BT_LOGIN)); return((exit_obj == LOGIN_BT_LOGIN));
} }

View File

@ -21,6 +21,6 @@
#include "utils/nsurl.h" #include "utils/nsurl.h"
bool login_form_do( nsurl * host, char * realm, char **cbpw ); bool login_form_do(nsurl * url, char * realm, char ** u_out char ** p_out);
#endif #endif