smartstatus/ts/smartstatus.classes.http.3xx.ts

124 lines
4.2 KiB
TypeScript
Raw Normal View History

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
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
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
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
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
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
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
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
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);