Tidy up unexpected error handling
This commit is contained in:
@@ -55,11 +55,11 @@ export enum ErrorCode {
|
||||
}
|
||||
|
||||
/** An error with a numeric code that can be used to identify the type of error. */
|
||||
export class CodedError {
|
||||
export class CodedError extends Error {
|
||||
public readonly errCode: ErrorCode;
|
||||
public readonly message: string;
|
||||
|
||||
public constructor( errCode: ErrorCode ) {
|
||||
public constructor( errCode: ErrorCode, message?: string ) {
|
||||
super( message );
|
||||
this.errCode = errCode;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -219,12 +219,7 @@ export const getWateringData = async function( req: express.Request, res: expres
|
||||
try {
|
||||
coordinates = await resolveCoordinates( location );
|
||||
} catch ( err ) {
|
||||
let codedError: CodedError = makeCodedError( err );
|
||||
if ( codedError.errCode === ErrorCode.UnexpectedError ) {
|
||||
console.error( `An unexpected error occurred during location resolution for "${ req.url }": `, err );
|
||||
}
|
||||
|
||||
sendWateringError( res, codedError );
|
||||
sendWateringError( res, makeCodedError( err ) );
|
||||
return;
|
||||
}
|
||||
|
||||
@@ -283,12 +278,7 @@ export const getWateringData = async function( req: express.Request, res: expres
|
||||
adjustmentOptions, coordinates, weatherProvider, pws
|
||||
);
|
||||
} catch ( err ) {
|
||||
let codedError: CodedError = makeCodedError( err );
|
||||
if ( codedError.errCode === ErrorCode.UnexpectedError ) {
|
||||
console.error( `An unexpected error occurred during watering scale calculation for "${ req.url }": `, err );
|
||||
}
|
||||
|
||||
sendWateringError( res, codedError );
|
||||
sendWateringError( res, makeCodedError( err ) );
|
||||
return;
|
||||
}
|
||||
|
||||
@@ -303,12 +293,7 @@ export const getWateringData = async function( req: express.Request, res: expres
|
||||
try {
|
||||
wateringData = await weatherProvider.getWateringData( coordinates );
|
||||
} catch ( err ) {
|
||||
let codedError: CodedError = makeCodedError( err );
|
||||
if ( codedError.errCode === ErrorCode.UnexpectedError ) {
|
||||
console.error( `An unexpected error occurred during restriction checks for "${ req.url }": `, err );
|
||||
}
|
||||
|
||||
sendWateringError( res, codedError );
|
||||
sendWateringError( res, makeCodedError( err ) );
|
||||
return;
|
||||
}
|
||||
}
|
||||
@@ -339,6 +324,10 @@ export const getWateringData = async function( req: express.Request, res: expres
|
||||
* @param useJson Indicates if the response body should use a JSON format instead of a format similar to URL query strings.
|
||||
*/
|
||||
function sendWateringError( res: express.Response, error: CodedError, useJson: boolean = false ) {
|
||||
if ( error.errCode === ErrorCode.UnexpectedError ) {
|
||||
console.error( `An unexpected error occurred:`, error );
|
||||
}
|
||||
|
||||
sendWateringData( res, { errCode: error.errCode, scale: 100 } );
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user