2024-12-25 14:23:42 +01:00
|
|
|
import { HttpStatus, type TStatusGroup } from './smartstatus.classes.http.js';
|
2017-04-11 11:30:03 +02:00
|
|
|
|
2019-01-02 02:08:12 +01:00
|
|
|
export class Status300 extends HttpStatus {
|
2017-04-11 11:30:03 +02:00
|
|
|
constructor() {
|
|
|
|
super({
|
|
|
|
code: 300,
|
|
|
|
text: ' Multiple Choices',
|
|
|
|
description: `Indicates multiple options for the resource from which the client may choose
|
|
|
|
(via agent-driven content negotiation).
|
|
|
|
For example, this code could be used to present multiple video format options,
|
2021-08-16 15:36:41 +02:00
|
|
|
to list files with different filename extensions, or to suggest word-sense disambiguation.`,
|
2019-01-02 01:00:53 +01:00
|
|
|
});
|
2017-04-11 11:30:03 +02:00
|
|
|
}
|
|
|
|
}
|
2019-01-02 02:08:12 +01:00
|
|
|
HttpStatus.addStatus('300', Status300);
|
2017-04-11 11:30:03 +02:00
|
|
|
|
2019-01-02 02:08:12 +01:00
|
|
|
// tslint:disable-next-line: max-classes-per-file
|
|
|
|
export class Status301 extends HttpStatus {
|
2017-04-11 11:30:03 +02:00
|
|
|
constructor() {
|
|
|
|
super({
|
|
|
|
code: 301,
|
|
|
|
text: 'Moved Permanently',
|
2021-08-16 15:36:41 +02:00
|
|
|
description: `This and all future requests should be directed to the given URI.`,
|
2019-01-02 01:00:53 +01:00
|
|
|
});
|
2017-04-11 11:30:03 +02:00
|
|
|
}
|
|
|
|
}
|
2019-01-02 02:08:12 +01:00
|
|
|
HttpStatus.addStatus('301', Status301);
|
2017-04-11 11:30:03 +02:00
|
|
|
|
2019-01-02 02:08:12 +01:00
|
|
|
// tslint:disable-next-line: max-classes-per-file
|
|
|
|
export class Status302 extends HttpStatus {
|
2017-04-11 11:30:03 +02:00
|
|
|
constructor() {
|
|
|
|
super({
|
|
|
|
code: 302,
|
|
|
|
text: 'Found',
|
|
|
|
description: `This is an example of industry practice contradicting the standard.
|
|
|
|
The HTTP/1.0 specification (RFC 1945) required the client to perform a temporary redirect
|
|
|
|
(the original describing phrase was "Moved Temporarily"),
|
|
|
|
[20] but popular browsers implemented 302 with the functionality of a 303 See Other.
|
|
|
|
Therefore, HTTP/1.1 added status codes 303 and 307 to distinguish between the two behaviours.[21]
|
2021-08-16 15:36:41 +02:00
|
|
|
However, some Web applications and frameworks use the 302 status code as if it were the 303.`,
|
2019-01-02 01:00:53 +01:00
|
|
|
});
|
2017-04-11 11:30:03 +02:00
|
|
|
}
|
|
|
|
}
|
2019-01-02 02:08:12 +01:00
|
|
|
HttpStatus.addStatus('302', Status302);
|
2017-04-11 11:30:03 +02:00
|
|
|
|
2019-01-02 02:08:12 +01:00
|
|
|
// tslint:disable-next-line: max-classes-per-file
|
|
|
|
export class Status303 extends HttpStatus {
|
2017-04-11 11:30:03 +02:00
|
|
|
constructor() {
|
|
|
|
super({
|
|
|
|
code: 303,
|
|
|
|
text: 'See Other',
|
|
|
|
description: `The response to the request can be found under another URI using a GET method.
|
|
|
|
When received in response to a POST (or PUT/DELETE),
|
|
|
|
the client should presume that the server has received the data and should issue a redirect
|
2021-08-16 15:36:41 +02:00
|
|
|
with a separate GET message.`,
|
2019-01-02 01:00:53 +01:00
|
|
|
});
|
2017-04-11 11:30:03 +02:00
|
|
|
}
|
|
|
|
}
|
2019-01-02 02:08:12 +01:00
|
|
|
HttpStatus.addStatus('303', Status303);
|
2017-04-11 11:30:03 +02:00
|
|
|
|
2019-01-02 02:08:12 +01:00
|
|
|
// tslint:disable-next-line: max-classes-per-file
|
|
|
|
export class Status304 extends HttpStatus {
|
2017-04-11 11:30:03 +02:00
|
|
|
constructor() {
|
|
|
|
super({
|
|
|
|
code: 304,
|
|
|
|
text: 'Not Modified',
|
|
|
|
description: `Indicates that the resource has not been modified
|
|
|
|
since the version specified by the request headers If-Modified-Since or If-None-Match.
|
|
|
|
In such case, there is no need to retransmit the resource since the client
|
2021-08-16 15:36:41 +02:00
|
|
|
still has a previously-downloaded copy.`,
|
2019-01-02 01:00:53 +01:00
|
|
|
});
|
2017-04-11 11:30:03 +02:00
|
|
|
}
|
|
|
|
}
|
2019-01-02 02:08:12 +01:00
|
|
|
HttpStatus.addStatus('304', Status304);
|
2017-04-11 11:30:03 +02:00
|
|
|
|
2019-01-02 02:08:12 +01:00
|
|
|
// tslint:disable-next-line: max-classes-per-file
|
|
|
|
export class Status305 extends HttpStatus {
|
2017-04-11 11:30:03 +02:00
|
|
|
constructor() {
|
|
|
|
super({
|
|
|
|
code: 305,
|
|
|
|
text: 'Use Proxy',
|
|
|
|
description: `The requested resource is available only through a proxy,
|
|
|
|
the address for which is provided in the response. Many HTTP clients (such as Mozilla[25]
|
|
|
|
and Internet Explorer) do not correctly handle responses with this status code,
|
2021-08-16 15:36:41 +02:00
|
|
|
primarily for security reasons.`,
|
2019-01-02 01:00:53 +01:00
|
|
|
});
|
2017-04-11 11:30:03 +02:00
|
|
|
}
|
|
|
|
}
|
2019-01-02 02:08:12 +01:00
|
|
|
HttpStatus.addStatus('305', Status305);
|
2017-04-11 11:30:03 +02:00
|
|
|
|
2019-01-02 02:08:12 +01:00
|
|
|
// tslint:disable-next-line: max-classes-per-file
|
|
|
|
export class Status306 extends HttpStatus {
|
2017-04-11 11:30:03 +02:00
|
|
|
constructor() {
|
|
|
|
super({
|
|
|
|
code: 306,
|
|
|
|
text: 'Switch Proxy',
|
2021-08-16 15:36:41 +02:00
|
|
|
description: `No longer used. Originally meant "Subsequent requests should use the specified proxy."`,
|
2019-01-02 01:00:53 +01:00
|
|
|
});
|
2017-04-11 11:30:03 +02:00
|
|
|
}
|
|
|
|
}
|
2019-01-02 02:08:12 +01:00
|
|
|
HttpStatus.addStatus('306', Status306);
|
2017-04-11 11:30:03 +02:00
|
|
|
|
2019-01-02 02:08:12 +01:00
|
|
|
// tslint:disable-next-line: max-classes-per-file
|
|
|
|
export class Status307 extends HttpStatus {
|
2017-04-11 11:30:03 +02:00
|
|
|
constructor() {
|
|
|
|
super({
|
|
|
|
code: 307,
|
|
|
|
text: 'Temporary Redirect',
|
|
|
|
description: `In this case, the request should be repeated with another URI;
|
|
|
|
however, future requests should still use the original URI.
|
|
|
|
In contrast to how 302 was historically implemented,
|
|
|
|
the request method is not allowed to be changed when reissuing the original request.
|
2021-08-16 15:36:41 +02:00
|
|
|
For example, a POST request should be repeated using another POST request.`,
|
2019-01-02 01:00:53 +01:00
|
|
|
});
|
2017-04-11 11:30:03 +02:00
|
|
|
}
|
|
|
|
}
|
2019-01-02 02:08:12 +01:00
|
|
|
HttpStatus.addStatus('307', Status307);
|
2017-04-11 11:30:03 +02:00
|
|
|
|
2019-01-02 02:08:12 +01:00
|
|
|
// tslint:disable-next-line: max-classes-per-file
|
|
|
|
export class Status308 extends HttpStatus {
|
2017-04-11 11:30:03 +02:00
|
|
|
constructor() {
|
|
|
|
super({
|
|
|
|
code: 308,
|
|
|
|
text: 'Permanent Redirect',
|
|
|
|
description: `The request and all future requests should be repeated using another URI.
|
|
|
|
307 and 308 parallel the behaviors of 302 and 301, but do not allow the HTTP method to change.
|
2021-08-16 15:36:41 +02:00
|
|
|
So, for example, submitting a form to a permanently redirected resource may continue smoothly.`,
|
2019-01-02 01:00:53 +01:00
|
|
|
});
|
2017-04-11 11:30:03 +02:00
|
|
|
}
|
|
|
|
}
|
2019-01-02 02:08:12 +01:00
|
|
|
HttpStatus.addStatus('308', Status308);
|