import { HttpStatus, type TStatusGroup } from './smartstatus.classes.http.js'; export class Status400 extends HttpStatus { constructor() { super({ code: 400, text: 'Bad Request', description: `The server cannot or will not process the request due to an apparent client error (e.g., malformed request syntax, too large size, invalid request message framing, or deceptive request routing).`, }); } } HttpStatus.addStatus('400', Status400); export class Status401 extends HttpStatus { constructor() { super({ code: 401, text: 'Unauthorized', description: `Similar to 403 Forbidden, but specifically for use when authentication is required and has failed or has not yet been provided. The response must include a WWW-Authenticate header field containing a challenge applicable to the requested resource. See Basic access authentication and Digest access authentication.[32] 401 semantically means "unauthenticated",[33] i.e. the user does not have the necessary credentials. Note: Some sites issue HTTP 401 when an IP address is banned from the website (usually the website domain) and that specific address is refused permission to access a website.`, }); } } HttpStatus.addStatus('401', Status401); export class Status402 extends HttpStatus { constructor() { super({ code: 402, text: 'Payment Required', description: `The request was valid, but the server is refusing action. The user might not have the necessary permissions for a resource.`, }); } } HttpStatus.addStatus('402', Status402); export class Status403 extends HttpStatus { constructor() { super({ code: 403, text: 'Forbidden', description: `The request was valid, but the server is refusing action. The user might not have the necessary permissions for a resource.`, }); } } HttpStatus.addStatus('403', Status403); export class Status404 extends HttpStatus { constructor() { super({ code: 404, text: 'Not Found', description: `The requested resource could not be found but may be available in the future. Subsequent requests by the client are permissible.`, }); } } HttpStatus.addStatus('404', Status404); export class Status429 extends HttpStatus { constructor() { super({ code: 429, text: 'Too Many Requests', description: `The user has sent too many requests in a given amount of time. Intended for use with rate-limiting schemes.`, }); } } HttpStatus.addStatus('429', Status429);