@loopback/repository
Version:
Define and implement a common set of interfaces for interacting with databases
62 lines (53 loc) • 1.47 kB
text/typescript
// Copyright IBM Corp. and LoopBack contributors 2017,2019. All Rights Reserved.
// Node module: @loopback/repository
// This file is licensed under the MIT License.
// License text available at https://opensource.org/licenses/MIT
import util from 'util';
import {Type} from './type';
/* eslint-disable @typescript-eslint/no-explicit-any */
/**
* Date type
*/
export class DateType implements Type<Date> {
readonly name = 'date';
isInstance(value: any) {
return value == null || value instanceof Date;
}
isCoercible(value: any): boolean {
// Please note new Date(...) allows the following
/*
> new Date('1')
2001-01-01T08:00:00.000Z
> new Date('0')
2000-01-01T08:00:00.000Z
> new Date(1)
1970-01-01T00:00:00.001Z
> new Date(0)
1970-01-01T00:00:00.000Z
> new Date(true)
1970-01-01T00:00:00.001Z
> new Date(false)
1970-01-01T00:00:00.000Z
*/
return value == null || !isNaN(new Date(value).getTime());
}
defaultValue() {
return new Date();
}
coerce(value: any) {
if (value == null) return value;
if (value instanceof Date) {
return value;
}
const d = new Date(value);
if (isNaN(d.getTime())) {
const msg = util.format('Invalid %s: %j', this.name, value);
throw new TypeError(msg);
}
return d;
}
serialize(value: Date | null | undefined) {
if (value == null) return value;
return value.toJSON();
}
}