mirror of https://github.com/adamdruppe/arsd.git
moving to my function
This commit is contained in:
parent
958cfbea74
commit
5458c04325
39
http2.d
39
http2.d
|
@ -63,7 +63,7 @@ static import arsd.core;
|
||||||
|
|
||||||
// FIXME: I think I want to disable sigpipe here too.
|
// FIXME: I think I want to disable sigpipe here too.
|
||||||
|
|
||||||
import std.uri : encodeComponent;
|
import arsd.core : encodeUriComponent, decodeUriComponent;
|
||||||
|
|
||||||
debug(arsd_http2_verbose) debug=arsd_http2;
|
debug(arsd_http2_verbose) debug=arsd_http2;
|
||||||
|
|
||||||
|
@ -159,9 +159,9 @@ HttpRequest post(string url, string[string] req) {
|
||||||
foreach(k, v; req) {
|
foreach(k, v; req) {
|
||||||
if(bdata.length)
|
if(bdata.length)
|
||||||
bdata ~= cast(ubyte[]) "&";
|
bdata ~= cast(ubyte[]) "&";
|
||||||
bdata ~= cast(ubyte[]) encodeComponent(k);
|
bdata ~= cast(ubyte[]) encodeUriComponent(k);
|
||||||
bdata ~= cast(ubyte[]) "=";
|
bdata ~= cast(ubyte[]) "=";
|
||||||
bdata ~= cast(ubyte[]) encodeComponent(v);
|
bdata ~= cast(ubyte[]) encodeUriComponent(v);
|
||||||
}
|
}
|
||||||
auto request = client.request(Uri(url), HttpVerb.POST, bdata, "application/x-www-form-urlencoded");
|
auto request = client.request(Uri(url), HttpVerb.POST, bdata, "application/x-www-form-urlencoded");
|
||||||
return request;
|
return request;
|
||||||
|
@ -195,15 +195,13 @@ string get(string url, string[string] cookies = null) {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static import std.uri;
|
|
||||||
|
|
||||||
string post(string url, string[string] args, string[string] cookies = null) {
|
string post(string url, string[string] args, string[string] cookies = null) {
|
||||||
string content;
|
string content;
|
||||||
|
|
||||||
foreach(name, arg; args) {
|
foreach(name, arg; args) {
|
||||||
if(content.length)
|
if(content.length)
|
||||||
content ~= "&";
|
content ~= "&";
|
||||||
content ~= std.uri.encode(name) ~ "=" ~ std.uri.encode(arg);
|
content ~= encodeUriComponent(name) ~ "=" ~ encodeUriComponent(arg);
|
||||||
}
|
}
|
||||||
|
|
||||||
auto hr = httpRequest("POST", url, cast(ubyte[]) content, cookies, ["Content-Type: application/x-www-form-urlencoded"]);
|
auto hr = httpRequest("POST", url, cast(ubyte[]) content, cookies, ["Content-Type: application/x-www-form-urlencoded"]);
|
||||||
|
@ -564,6 +562,21 @@ struct CookieHeader {
|
||||||
string name;
|
string name;
|
||||||
string value;
|
string value;
|
||||||
string[string] attributes;
|
string[string] attributes;
|
||||||
|
|
||||||
|
// max-age
|
||||||
|
// expires
|
||||||
|
// httponly
|
||||||
|
// secure
|
||||||
|
// samesite
|
||||||
|
// path
|
||||||
|
// domain
|
||||||
|
// partitioned ?
|
||||||
|
|
||||||
|
// also want cookiejar features here with settings to save session cookies or not
|
||||||
|
|
||||||
|
// storing in file: http://kb.mozillazine.org/Cookies.txt (second arg in practice true if first arg starts with . it seems)
|
||||||
|
// or better yet sqlite: http://kb.mozillazine.org/Cookies.sqlite
|
||||||
|
// should be able to import/export from either upon request
|
||||||
}
|
}
|
||||||
|
|
||||||
import std.string;
|
import std.string;
|
||||||
|
@ -1197,8 +1210,7 @@ class HttpRequest {
|
||||||
if(type.length == 0)
|
if(type.length == 0)
|
||||||
type = "text/plain";
|
type = "text/plain";
|
||||||
|
|
||||||
import std.uri;
|
auto bdata = cast(ubyte[]) decodeUriComponent(data);
|
||||||
auto bdata = cast(ubyte[]) decodeComponent(data);
|
|
||||||
|
|
||||||
if(type.indexOf(";base64") != -1) {
|
if(type.indexOf(";base64") != -1) {
|
||||||
import std.base64;
|
import std.base64;
|
||||||
|
@ -4238,20 +4250,19 @@ class HttpApiClient() {
|
||||||
|
|
||||||
///
|
///
|
||||||
string toUri() {
|
string toUri() {
|
||||||
import std.uri;
|
|
||||||
string result;
|
string result;
|
||||||
foreach(idx, part; pathParts) {
|
foreach(idx, part; pathParts) {
|
||||||
if(idx)
|
if(idx)
|
||||||
result ~= "/";
|
result ~= "/";
|
||||||
result ~= encodeComponent(part);
|
result ~= encodeUriComponent(part);
|
||||||
}
|
}
|
||||||
result ~= "?";
|
result ~= "?";
|
||||||
foreach(idx, part; queryParts) {
|
foreach(idx, part; queryParts) {
|
||||||
if(idx)
|
if(idx)
|
||||||
result ~= "&";
|
result ~= "&";
|
||||||
result ~= encodeComponent(part[0]);
|
result ~= encodeUriComponent(part[0]);
|
||||||
result ~= "=";
|
result ~= "=";
|
||||||
result ~= encodeComponent(part[1]);
|
result ~= encodeUriComponent(part[1]);
|
||||||
}
|
}
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
|
@ -4292,10 +4303,10 @@ class HttpApiClient() {
|
||||||
static if(idx % 2 == 0) {
|
static if(idx % 2 == 0) {
|
||||||
if(answer.length)
|
if(answer.length)
|
||||||
answer ~= "&";
|
answer ~= "&";
|
||||||
answer ~= encodeComponent(val); // it had better be a string! lol
|
answer ~= encodeUriComponent(val); // it had better be a string! lol
|
||||||
answer ~= "=";
|
answer ~= "=";
|
||||||
} else {
|
} else {
|
||||||
answer ~= encodeComponent(to!string(val));
|
answer ~= encodeUriComponent(to!string(val));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue