feat(http): add content-type override support for http request (#10211)
This commit is contained in:
parent
d455942389
commit
bdb59129d0
|
@ -90,20 +90,41 @@ export class Request extends Body {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
this._body = requestOptions.body;
|
this._body = requestOptions.body;
|
||||||
this.contentType = this.detectContentType();
|
|
||||||
this.method = normalizeMethodName(requestOptions.method);
|
this.method = normalizeMethodName(requestOptions.method);
|
||||||
// TODO(jeffbcross): implement behavior
|
// TODO(jeffbcross): implement behavior
|
||||||
// Defaults to 'omit', consistent with browser
|
// Defaults to 'omit', consistent with browser
|
||||||
// TODO(jeffbcross): implement behavior
|
// TODO(jeffbcross): implement behavior
|
||||||
this.headers = new Headers(requestOptions.headers);
|
this.headers = new Headers(requestOptions.headers);
|
||||||
|
this.contentType = this.detectContentType();
|
||||||
this.withCredentials = requestOptions.withCredentials;
|
this.withCredentials = requestOptions.withCredentials;
|
||||||
this.responseType = requestOptions.responseType;
|
this.responseType = requestOptions.responseType;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the content type enum based on header options.
|
||||||
|
*/
|
||||||
|
detectContentType(): ContentType {
|
||||||
|
switch (this.headers.get('content-type')) {
|
||||||
|
case 'application/json':
|
||||||
|
return ContentType.JSON;
|
||||||
|
case 'application/x-www-form-urlencoded':
|
||||||
|
return ContentType.FORM;
|
||||||
|
case 'multipart/form-data':
|
||||||
|
return ContentType.FORM_DATA;
|
||||||
|
case 'text/plain':
|
||||||
|
case 'text/html':
|
||||||
|
return ContentType.TEXT;
|
||||||
|
case 'application/octet-stream':
|
||||||
|
return ContentType.BLOB;
|
||||||
|
default:
|
||||||
|
return this.detectContentTypeFromBody();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the content type of request's body based on its type.
|
* Returns the content type of request's body based on its type.
|
||||||
*/
|
*/
|
||||||
detectContentType() {
|
detectContentTypeFromBody(): ContentType {
|
||||||
if (this._body == null) {
|
if (this._body == null) {
|
||||||
return ContentType.NONE;
|
return ContentType.NONE;
|
||||||
} else if (this._body instanceof URLSearchParams) {
|
} else if (this._body instanceof URLSearchParams) {
|
||||||
|
|
|
@ -0,0 +1,81 @@
|
||||||
|
/**
|
||||||
|
* @license
|
||||||
|
* Copyright Google Inc. All Rights Reserved.
|
||||||
|
*
|
||||||
|
* Use of this source code is governed by an MIT-style license that can be
|
||||||
|
* found in the LICENSE file at https://angular.io/license
|
||||||
|
*/
|
||||||
|
|
||||||
|
import {describe, expect, it} from '@angular/core/testing/testing_internal';
|
||||||
|
|
||||||
|
import {RequestOptions} from '../src/base_request_options';
|
||||||
|
import {ContentType} from '../src/enums';
|
||||||
|
import {Headers} from '../src/headers';
|
||||||
|
import {Request} from '../src/static_request';
|
||||||
|
|
||||||
|
export function main() {
|
||||||
|
describe('Request', () => {
|
||||||
|
describe('detectContentType', () => {
|
||||||
|
it('should return ContentType.NONE', () => {
|
||||||
|
const req = new Request(new RequestOptions({url: 'test', method: 'GET', body: null}));
|
||||||
|
|
||||||
|
expect(req.detectContentType()).toEqual(ContentType.NONE);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should return ContentType.JSON', () => {
|
||||||
|
const req = new Request(new RequestOptions({
|
||||||
|
url: 'test',
|
||||||
|
method: 'GET',
|
||||||
|
body: null,
|
||||||
|
headers: new Headers({'content-type': 'application/json'})
|
||||||
|
}));
|
||||||
|
|
||||||
|
expect(req.detectContentType()).toEqual(ContentType.JSON);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should return ContentType.FORM', () => {
|
||||||
|
const req = new Request(new RequestOptions({
|
||||||
|
url: 'test',
|
||||||
|
method: 'GET',
|
||||||
|
body: null,
|
||||||
|
headers: new Headers({'content-type': 'application/x-www-form-urlencoded'})
|
||||||
|
}));
|
||||||
|
|
||||||
|
expect(req.detectContentType()).toEqual(ContentType.FORM);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should return ContentType.FORM_DATA', () => {
|
||||||
|
const req = new Request(new RequestOptions({
|
||||||
|
url: 'test',
|
||||||
|
method: 'GET',
|
||||||
|
body: null,
|
||||||
|
headers: new Headers({'content-type': 'multipart/form-data'})
|
||||||
|
}));
|
||||||
|
|
||||||
|
expect(req.detectContentType()).toEqual(ContentType.FORM_DATA);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should return ContentType.TEXT', () => {
|
||||||
|
const req = new Request(new RequestOptions({
|
||||||
|
url: 'test',
|
||||||
|
method: 'GET',
|
||||||
|
body: null,
|
||||||
|
headers: new Headers({'content-type': 'text/plain'})
|
||||||
|
}));
|
||||||
|
|
||||||
|
expect(req.detectContentType()).toEqual(ContentType.TEXT);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should return ContentType.BLOB', () => {
|
||||||
|
const req = new Request(new RequestOptions({
|
||||||
|
url: 'test',
|
||||||
|
method: 'GET',
|
||||||
|
body: null,
|
||||||
|
headers: new Headers({'content-type': 'application/octet-stream'})
|
||||||
|
}));
|
||||||
|
|
||||||
|
expect(req.detectContentType()).toEqual(ContentType.BLOB);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
|
@ -125,6 +125,7 @@ export declare class Request extends Body {
|
||||||
withCredentials: boolean;
|
withCredentials: boolean;
|
||||||
constructor(requestOptions: RequestArgs);
|
constructor(requestOptions: RequestArgs);
|
||||||
detectContentType(): ContentType;
|
detectContentType(): ContentType;
|
||||||
|
detectContentTypeFromBody(): ContentType;
|
||||||
getBody(): any;
|
getBody(): any;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue