12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346 |
- var forge = require('./forge');
- require('./tls');
- require('./util');
- var http = module.exports = forge.http = forge.http || {};
- var cat = 'forge.http';
- var _normalize = function(name) {
- return name.toLowerCase().replace(/(^.)|(-.)/g,
- function(a) {return a.toUpperCase();});
- };
- var _getStorageId = function(client) {
-
-
-
- return 'forge.http.' +
- client.url.protocol.slice(0, -1) + '.' +
- client.url.hostname + '.' +
- client.url.port;
- };
- var _loadCookies = function(client) {
- if(client.persistCookies) {
- try {
- var cookies = forge.util.getItem(
- client.socketPool.flashApi,
- _getStorageId(client), 'cookies');
- client.cookies = cookies || {};
- } catch(ex) {
-
-
-
-
- }
- }
- };
- var _saveCookies = function(client) {
- if(client.persistCookies) {
- try {
- forge.util.setItem(
- client.socketPool.flashApi,
- _getStorageId(client), 'cookies', client.cookies);
- } catch(ex) {
-
-
-
-
- }
- }
-
- _loadCookies(client);
- };
- var _clearCookies = function(client) {
- if(client.persistCookies) {
- try {
-
- forge.util.clearItems(
- client.socketPool.flashApi,
- _getStorageId(client));
- } catch(ex) {
-
-
-
-
- }
- }
- };
- var _doRequest = function(client, socket) {
- if(socket.isConnected()) {
-
- socket.options.request.connectTime = +new Date();
- socket.connected({
- type: 'connect',
- id: socket.id
- });
- } else {
-
- socket.options.request.connectTime = +new Date();
- socket.connect({
- host: client.url.hostname,
- port: client.url.port,
- policyPort: client.policyPort,
- policyUrl: client.policyUrl
- });
- }
- };
- var _handleNextRequest = function(client, socket) {
-
- socket.buffer.clear();
-
- var pending = null;
- while(pending === null && client.requests.length > 0) {
- pending = client.requests.shift();
- if(pending.request.aborted) {
- pending = null;
- }
- }
-
- if(pending === null) {
- if(socket.options !== null) {
- socket.options = null;
- }
- client.idle.push(socket);
- } else {
-
- socket.retries = 1;
- socket.options = pending;
- _doRequest(client, socket);
- }
- };
- var _initSocket = function(client, socket, tlsOptions) {
-
- socket.options = null;
-
- socket.connected = function(e) {
-
- if(socket.options === null) {
- _handleNextRequest(client, socket);
- } else {
-
- var request = socket.options.request;
- request.connectTime = +new Date() - request.connectTime;
- e.socket = socket;
- socket.options.connected(e);
- if(request.aborted) {
- socket.close();
- } else {
- var out = request.toString();
- if(request.body) {
- out += request.body;
- }
- request.time = +new Date();
- socket.send(out);
- request.time = +new Date() - request.time;
- socket.options.response.time = +new Date();
- socket.sending = true;
- }
- }
- };
- socket.closed = function(e) {
- if(socket.sending) {
- socket.sending = false;
- if(socket.retries > 0) {
- --socket.retries;
- _doRequest(client, socket);
- } else {
-
- socket.error({
- id: socket.id,
- type: 'ioError',
- message: 'Connection closed during send. Broken pipe.',
- bytesAvailable: 0
- });
- }
- } else {
-
- var response = socket.options.response;
- if(response.readBodyUntilClose) {
- response.time = +new Date() - response.time;
- response.bodyReceived = true;
- socket.options.bodyReady({
- request: socket.options.request,
- response: response,
- socket: socket
- });
- }
- socket.options.closed(e);
- _handleNextRequest(client, socket);
- }
- };
- socket.data = function(e) {
- socket.sending = false;
- var request = socket.options.request;
- if(request.aborted) {
- socket.close();
- } else {
-
- var response = socket.options.response;
- var bytes = socket.receive(e.bytesAvailable);
- if(bytes !== null) {
-
- socket.buffer.putBytes(bytes);
- if(!response.headerReceived) {
- response.readHeader(socket.buffer);
- if(response.headerReceived) {
- socket.options.headerReady({
- request: socket.options.request,
- response: response,
- socket: socket
- });
- }
- }
- if(response.headerReceived && !response.bodyReceived) {
- response.readBody(socket.buffer);
- }
- if(response.bodyReceived) {
- socket.options.bodyReady({
- request: socket.options.request,
- response: response,
- socket: socket
- });
-
- var value = response.getField('Connection') || '';
- if(value.indexOf('close') != -1 ||
- (response.version === 'HTTP/1.0' &&
- response.getField('Keep-Alive') === null)) {
- socket.close();
- } else {
- _handleNextRequest(client, socket);
- }
- }
- }
- }
- };
- socket.error = function(e) {
-
- socket.options.error({
- type: e.type,
- message: e.message,
- request: socket.options.request,
- response: socket.options.response,
- socket: socket
- });
- socket.close();
- };
-
- if(tlsOptions) {
- socket = forge.tls.wrapSocket({
- sessionId: null,
- sessionCache: {},
- caStore: tlsOptions.caStore,
- cipherSuites: tlsOptions.cipherSuites,
- socket: socket,
- virtualHost: tlsOptions.virtualHost,
- verify: tlsOptions.verify,
- getCertificate: tlsOptions.getCertificate,
- getPrivateKey: tlsOptions.getPrivateKey,
- getSignature: tlsOptions.getSignature,
- deflate: tlsOptions.deflate || null,
- inflate: tlsOptions.inflate || null
- });
- socket.options = null;
- socket.buffer = forge.util.createBuffer();
- client.sockets.push(socket);
- if(tlsOptions.prime) {
-
-
- socket.connect({
- host: client.url.hostname,
- port: client.url.port,
- policyPort: client.policyPort,
- policyUrl: client.policyUrl
- });
- } else {
-
- client.idle.push(socket);
- }
- } else {
-
- socket.buffer = forge.util.createBuffer();
- client.sockets.push(socket);
- client.idle.push(socket);
- }
- };
- var _hasCookieExpired = function(cookie) {
- var rval = false;
- if(cookie.maxAge !== -1) {
- var now = _getUtcTime(new Date());
- var expires = cookie.created + cookie.maxAge;
- if(expires <= now) {
- rval = true;
- }
- }
- return rval;
- };
- var _writeCookies = function(client, request) {
- var expired = [];
- var url = client.url;
- var cookies = client.cookies;
- for(var name in cookies) {
-
- var paths = cookies[name];
- for(var p in paths) {
- var cookie = paths[p];
- if(_hasCookieExpired(cookie)) {
-
- expired.push(cookie);
- } else if(request.path.indexOf(cookie.path) === 0) {
-
- request.addCookie(cookie);
- }
- }
- }
-
- for(var i = 0; i < expired.length; ++i) {
- var cookie = expired[i];
- client.removeCookie(cookie.name, cookie.path);
- }
- };
- var _readCookies = function(client, response) {
- var cookies = response.getCookies();
- for(var i = 0; i < cookies.length; ++i) {
- try {
- client.setCookie(cookies[i]);
- } catch(ex) {
-
- }
- }
- };
- http.createClient = function(options) {
-
- var caStore = null;
- if(options.caCerts) {
- caStore = forge.pki.createCaStore(options.caCerts);
- }
-
- options.url = (options.url ||
- window.location.protocol + '//' + window.location.host);
- var url;
- try {
- url = new URL(options.url);
- } catch(e) {
- var error = new Error('Invalid url.');
- error.details = {url: options.url};
- throw error;
- }
-
- options.connections = options.connections || 1;
-
- var sp = options.socketPool;
- var client = {
-
- url: url,
-
- socketPool: sp,
-
- policyPort: options.policyPort,
-
- policyUrl: options.policyUrl,
-
- requests: [],
-
- sockets: [],
-
- idle: [],
-
- secure: (url.protocol === 'https:'),
-
-
- cookies: {},
-
- persistCookies: (typeof(options.persistCookies) === 'undefined') ?
- true : options.persistCookies
- };
-
- _loadCookies(client);
-
- var _defaultCertificateVerify = function(c, verified, depth, certs) {
- if(depth === 0 && verified === true) {
-
- var cn = certs[depth].subject.getField('CN');
- if(cn === null || client.url.hostname !== cn.value) {
- verified = {
- message: 'Certificate common name does not match url host.'
- };
- }
- }
- return verified;
- };
-
- var tlsOptions = null;
- if(client.secure) {
- tlsOptions = {
- caStore: caStore,
- cipherSuites: options.cipherSuites || null,
- virtualHost: options.virtualHost || url.hostname,
- verify: options.verify || _defaultCertificateVerify,
- getCertificate: options.getCertificate || null,
- getPrivateKey: options.getPrivateKey || null,
- getSignature: options.getSignature || null,
- prime: options.primeTlsSockets || false
- };
-
- if(sp.flashApi !== null) {
- tlsOptions.deflate = function(bytes) {
-
- return forge.util.deflate(sp.flashApi, bytes, true);
- };
- tlsOptions.inflate = function(bytes) {
- return forge.util.inflate(sp.flashApi, bytes, true);
- };
- }
- }
-
- for(var i = 0; i < options.connections; ++i) {
- _initSocket(client, sp.createSocket(), tlsOptions);
- }
-
- client.send = function(options) {
-
- if(options.request.getField('Host') === null) {
- options.request.setField('Host', client.url.origin);
- }
-
- var opts = {};
- opts.request = options.request;
- opts.connected = options.connected || function() {};
- opts.closed = options.close || function() {};
- opts.headerReady = function(e) {
-
- _readCookies(client, e.response);
- if(options.headerReady) {
- options.headerReady(e);
- }
- };
- opts.bodyReady = options.bodyReady || function() {};
- opts.error = options.error || function() {};
-
- opts.response = http.createResponse();
- opts.response.time = 0;
- opts.response.flashApi = client.socketPool.flashApi;
- opts.request.flashApi = client.socketPool.flashApi;
-
- opts.request.abort = function() {
-
- opts.request.aborted = true;
- opts.connected = function() {};
- opts.closed = function() {};
- opts.headerReady = function() {};
- opts.bodyReady = function() {};
- opts.error = function() {};
- };
-
- _writeCookies(client, opts.request);
-
- if(client.idle.length === 0) {
- client.requests.push(opts);
- } else {
-
- var socket = null;
- var len = client.idle.length;
- for(var i = 0; socket === null && i < len; ++i) {
- socket = client.idle[i];
- if(socket.isConnected()) {
- client.idle.splice(i, 1);
- } else {
- socket = null;
- }
- }
-
- if(socket === null) {
- socket = client.idle.pop();
- }
- socket.options = opts;
- _doRequest(client, socket);
- }
- };
-
- client.destroy = function() {
-
- client.requests = [];
- for(var i = 0; i < client.sockets.length; ++i) {
- client.sockets[i].close();
- client.sockets[i].destroy();
- }
- client.socketPool = null;
- client.sockets = [];
- client.idle = [];
- };
-
- client.setCookie = function(cookie) {
- var rval;
- if(typeof(cookie.name) !== 'undefined') {
- if(cookie.value === null || typeof(cookie.value) === 'undefined' ||
- cookie.value === '') {
-
- rval = client.removeCookie(cookie.name, cookie.path);
- } else {
-
- cookie.comment = cookie.comment || '';
- cookie.maxAge = cookie.maxAge || 0;
- cookie.secure = (typeof(cookie.secure) === 'undefined') ?
- true : cookie.secure;
- cookie.httpOnly = cookie.httpOnly || true;
- cookie.path = cookie.path || '/';
- cookie.domain = cookie.domain || null;
- cookie.version = cookie.version || null;
- cookie.created = _getUtcTime(new Date());
-
- if(cookie.secure !== client.secure) {
- var error = new Error('Http client url scheme is incompatible ' +
- 'with cookie secure flag.');
- error.url = client.url;
- error.cookie = cookie;
- throw error;
- }
-
- if(!http.withinCookieDomain(client.url, cookie)) {
- var error = new Error('Http client url scheme is incompatible ' +
- 'with cookie secure flag.');
- error.url = client.url;
- error.cookie = cookie;
- throw error;
- }
-
- if(!(cookie.name in client.cookies)) {
- client.cookies[cookie.name] = {};
- }
- client.cookies[cookie.name][cookie.path] = cookie;
- rval = true;
-
- _saveCookies(client);
- }
- }
- return rval;
- };
-
- client.getCookie = function(name, path) {
- var rval = null;
- if(name in client.cookies) {
- var paths = client.cookies[name];
-
- if(path) {
- if(path in paths) {
- rval = paths[path];
- }
- } else {
-
- for(var p in paths) {
- rval = paths[p];
- break;
- }
- }
- }
- return rval;
- };
-
- client.removeCookie = function(name, path) {
- var rval = false;
- if(name in client.cookies) {
-
- if(path) {
- var paths = client.cookies[name];
- if(path in paths) {
- rval = true;
- delete client.cookies[name][path];
-
- var empty = true;
- for(var i in client.cookies[name]) {
- empty = false;
- break;
- }
- if(empty) {
- delete client.cookies[name];
- }
- }
- } else {
-
- rval = true;
- delete client.cookies[name];
- }
- }
- if(rval) {
-
- _saveCookies(client);
- }
- return rval;
- };
-
- client.clearCookies = function() {
- client.cookies = {};
- _clearCookies(client);
- };
- if(forge.log) {
- forge.log.debug('forge.http', 'created client', options);
- }
- return client;
- };
- var _trimString = function(str) {
- return str.replace(/^\s*/, '').replace(/\s*$/, '');
- };
- var _createHeader = function() {
- var header = {
- fields: {},
- setField: function(name, value) {
-
- header.fields[_normalize(name)] = [_trimString('' + value)];
- },
- appendField: function(name, value) {
- name = _normalize(name);
- if(!(name in header.fields)) {
- header.fields[name] = [];
- }
- header.fields[name].push(_trimString('' + value));
- },
- getField: function(name, index) {
- var rval = null;
- name = _normalize(name);
- if(name in header.fields) {
- index = index || 0;
- rval = header.fields[name][index];
- }
- return rval;
- }
- };
- return header;
- };
- var _getUtcTime = function(d) {
- var utc = +d + d.getTimezoneOffset() * 60000;
- return Math.floor(+new Date() / 1000);
- };
- http.createRequest = function(options) {
- options = options || {};
- var request = _createHeader();
- request.version = options.version || 'HTTP/1.1';
- request.method = options.method || null;
- request.path = options.path || null;
- request.body = options.body || null;
- request.bodyDeflated = false;
- request.flashApi = null;
-
- var headers = options.headers || [];
- if(!forge.util.isArray(headers)) {
- headers = [headers];
- }
- for(var i = 0; i < headers.length; ++i) {
- for(var name in headers[i]) {
- request.appendField(name, headers[i][name]);
- }
- }
-
- request.addCookie = function(cookie) {
- var value = '';
- var field = request.getField('Cookie');
- if(field !== null) {
-
- value = field + '; ';
- }
-
- var now = _getUtcTime(new Date());
-
- value += cookie.name + '=' + cookie.value;
- request.setField('Cookie', value);
- };
-
- request.toString = function() {
-
-
- if(request.getField('User-Agent') === null) {
- request.setField('User-Agent', 'forge.http 1.0');
- }
- if(request.getField('Accept') === null) {
- request.setField('Accept', '*/*');
- }
- if(request.getField('Connection') === null) {
- request.setField('Connection', 'keep-alive');
- request.setField('Keep-Alive', '115');
- }
-
- if(request.flashApi !== null &&
- request.getField('Accept-Encoding') === null) {
- request.setField('Accept-Encoding', 'deflate');
- }
-
- if(request.flashApi !== null && request.body !== null &&
- request.getField('Content-Encoding') === null &&
- !request.bodyDeflated && request.body.length > 100) {
-
- request.body = forge.util.deflate(request.flashApi, request.body);
- request.bodyDeflated = true;
- request.setField('Content-Encoding', 'deflate');
- request.setField('Content-Length', request.body.length);
- } else if(request.body !== null) {
-
- request.setField('Content-Length', request.body.length);
- }
-
- var rval =
- request.method.toUpperCase() + ' ' + request.path + ' ' +
- request.version + '\r\n';
-
- for(var name in request.fields) {
- var fields = request.fields[name];
- for(var i = 0; i < fields.length; ++i) {
- rval += name + ': ' + fields[i] + '\r\n';
- }
- }
-
- rval += '\r\n';
- return rval;
- };
- return request;
- };
- http.createResponse = function() {
-
- var _first = true;
- var _chunkSize = 0;
- var _chunksFinished = false;
-
- var response = _createHeader();
- response.version = null;
- response.code = 0;
- response.message = null;
- response.body = null;
- response.headerReceived = false;
- response.bodyReceived = false;
- response.flashApi = null;
-
- var _readCrlf = function(b) {
- var line = null;
- var i = b.data.indexOf('\r\n', b.read);
- if(i != -1) {
-
- line = b.getBytes(i - b.read);
- b.getBytes(2);
- }
- return line;
- };
-
- var _parseHeader = function(line) {
- var tmp = line.indexOf(':');
- var name = line.substring(0, tmp++);
- response.appendField(
- name, (tmp < line.length) ? line.substring(tmp) : '');
- };
-
- response.readHeader = function(b) {
-
- var line = '';
- while(!response.headerReceived && line !== null) {
- line = _readCrlf(b);
- if(line !== null) {
-
- if(_first) {
- _first = false;
- var tmp = line.split(' ');
- if(tmp.length >= 3) {
- response.version = tmp[0];
- response.code = parseInt(tmp[1], 10);
- response.message = tmp.slice(2).join(' ');
- } else {
-
- var error = new Error('Invalid http response header.');
- error.details = {'line': line};
- throw error;
- }
- } else if(line.length === 0) {
-
- response.headerReceived = true;
- } else {
- _parseHeader(line);
- }
- }
- }
- return response.headerReceived;
- };
-
- var _readChunkedBody = function(b) {
-
-
- var line = '';
- while(line !== null && b.length() > 0) {
-
- if(_chunkSize > 0) {
-
-
- if(_chunkSize + 2 > b.length()) {
- break;
- }
-
- response.body += b.getBytes(_chunkSize);
- b.getBytes(2);
- _chunkSize = 0;
- } else if(!_chunksFinished) {
-
- line = _readCrlf(b);
- if(line !== null) {
-
- _chunkSize = parseInt(line.split(';', 1)[0], 16);
- _chunksFinished = (_chunkSize === 0);
- }
- } else {
-
- line = _readCrlf(b);
- while(line !== null) {
- if(line.length > 0) {
-
- _parseHeader(line);
-
- line = _readCrlf(b);
- } else {
-
- response.bodyReceived = true;
- line = null;
- }
- }
- }
- }
- return response.bodyReceived;
- };
-
- response.readBody = function(b) {
- var contentLength = response.getField('Content-Length');
- var transferEncoding = response.getField('Transfer-Encoding');
- if(contentLength !== null) {
- contentLength = parseInt(contentLength);
- }
-
- if(contentLength !== null && contentLength >= 0) {
- response.body = response.body || '';
- response.body += b.getBytes(contentLength);
- response.bodyReceived = (response.body.length === contentLength);
- } else if(transferEncoding !== null) {
-
- if(transferEncoding.indexOf('chunked') != -1) {
- response.body = response.body || '';
- _readChunkedBody(b);
- } else {
- var error = new Error('Unknown Transfer-Encoding.');
- error.details = {'transferEncoding': transferEncoding};
- throw error;
- }
- } else if((contentLength !== null && contentLength < 0) ||
- (contentLength === null &&
- response.getField('Content-Type') !== null)) {
-
- response.body = response.body || '';
- response.body += b.getBytes();
- response.readBodyUntilClose = true;
- } else {
-
- response.body = null;
- response.bodyReceived = true;
- }
- if(response.bodyReceived) {
- response.time = +new Date() - response.time;
- }
- if(response.flashApi !== null &&
- response.bodyReceived && response.body !== null &&
- response.getField('Content-Encoding') === 'deflate') {
-
- response.body = forge.util.inflate(
- response.flashApi, response.body);
- }
- return response.bodyReceived;
- };
-
- response.getCookies = function() {
- var rval = [];
-
- if('Set-Cookie' in response.fields) {
- var field = response.fields['Set-Cookie'];
-
- var now = +new Date() / 1000;
-
- var regex = /\s*([^=]*)=?([^;]*)(;|$)/g;
-
-
-
- for(var i = 0; i < field.length; ++i) {
- var fv = field[i];
- var m;
- regex.lastIndex = 0;
- var first = true;
- var cookie = {};
- do {
- m = regex.exec(fv);
- if(m !== null) {
- var name = _trimString(m[1]);
- var value = _trimString(m[2]);
-
- if(first) {
- cookie.name = name;
- cookie.value = value;
- first = false;
- } else {
-
- name = name.toLowerCase();
- switch(name) {
- case 'expires':
-
- value = value.replace(/-/g, ' ');
- var secs = Date.parse(value) / 1000;
- cookie.maxAge = Math.max(0, secs - now);
- break;
- case 'max-age':
- cookie.maxAge = parseInt(value, 10);
- break;
- case 'secure':
- cookie.secure = true;
- break;
- case 'httponly':
- cookie.httpOnly = true;
- break;
- default:
- if(name !== '') {
- cookie[name] = value;
- }
- }
- }
- }
- } while(m !== null && m[0] !== '');
- rval.push(cookie);
- }
- }
- return rval;
- };
-
- response.toString = function() {
-
-
- var rval =
- response.version + ' ' + response.code + ' ' + response.message + '\r\n';
-
- for(var name in response.fields) {
- var fields = response.fields[name];
- for(var i = 0; i < fields.length; ++i) {
- rval += name + ': ' + fields[i] + '\r\n';
- }
- }
-
- rval += '\r\n';
- return rval;
- };
- return response;
- };
- http.withinCookieDomain = function(url, cookie) {
- var rval = false;
-
- var domain = (cookie === null || typeof cookie === 'string') ?
- cookie : cookie.domain;
-
- if(domain === null) {
- rval = true;
- } else if(domain.charAt(0) === '.') {
-
-
- if(typeof url === 'string') {
- url = new URL(url);
- }
-
- var host = '.' + url.hostname;
-
- var idx = host.lastIndexOf(domain);
- if(idx !== -1 && (idx + domain.length === host.length)) {
- rval = true;
- }
- }
- return rval;
- };
|