UNPKG

graphql-scalars

Version:

A collection of scalar types not included in base GraphQL.

98 lines (97 loc) 3.91 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.GraphQLDateTime = exports.GraphQLDateTimeConfig = void 0; /** * Copyright (c) 2017, Dirk-Jan Rutten * All rights reserved. * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. * */ const graphql_1 = require("graphql"); const error_js_1 = require("../../error.js"); const formatter_js_1 = require("./formatter.js"); // eslint-disable-line const validator_js_1 = require("./validator.js"); exports.GraphQLDateTimeConfig = { name: 'DateTime', description: 'A date-time string at UTC, such as 2007-12-03T10:15:30Z, ' + 'compliant with the `date-time` format outlined in section 5.6 of ' + 'the RFC 3339 profile of the ISO 8601 standard for representation ' + 'of dates and times using the Gregorian calendar.', serialize(value) { if (value instanceof Date) { if ((0, validator_js_1.validateJSDate)(value)) { return value; } throw (0, error_js_1.createGraphQLError)('DateTime cannot represent an invalid Date instance'); } else if (typeof value === 'string') { if ((0, validator_js_1.validateDateTime)(value)) { return (0, formatter_js_1.parseDateTime)(value); } throw (0, error_js_1.createGraphQLError)(`DateTime cannot represent an invalid date-time-string ${value}.`); } else if (typeof value === 'number') { try { return new Date(value); } catch (_a) { throw (0, error_js_1.createGraphQLError)('DateTime cannot represent an invalid Unix timestamp ' + value); } } else { throw (0, error_js_1.createGraphQLError)('DateTime cannot be serialized from a non string, ' + 'non numeric or non Date type ' + JSON.stringify(value)); } }, parseValue(value) { if (value instanceof Date) { if ((0, validator_js_1.validateJSDate)(value)) { return value; } throw (0, error_js_1.createGraphQLError)('DateTime cannot represent an invalid Date instance'); } if (typeof value === 'string') { if ((0, validator_js_1.validateDateTime)(value)) { return (0, formatter_js_1.parseDateTime)(value); } throw (0, error_js_1.createGraphQLError)(`DateTime cannot represent an invalid date-time-string ${value}.`); } throw (0, error_js_1.createGraphQLError)(`DateTime cannot represent non string or Date type ${JSON.stringify(value)}`); }, parseLiteral(ast) { if (ast.kind !== graphql_1.Kind.STRING) { throw (0, error_js_1.createGraphQLError)(`DateTime cannot represent non string or Date type ${'value' in ast && ast.value}`, { nodes: ast, }); } const { value } = ast; if ((0, validator_js_1.validateDateTime)(value)) { return (0, formatter_js_1.parseDateTime)(value); } throw (0, error_js_1.createGraphQLError)(`DateTime cannot represent an invalid date-time-string ${String(value)}.`, { nodes: ast }); }, extensions: { codegenScalarType: 'Date | string', jsonSchema: { type: 'string', format: 'date-time', }, }, }; /** * An RFC 3339 compliant date-time scalar. * * Input: * This scalar takes an RFC 3339 date-time string as input and * parses it to a javascript Date. * * Output: * This scalar serializes javascript Dates, * RFC 3339 date-time strings and unix timestamps * to RFC 3339 UTC date-time strings. */ exports.GraphQLDateTime = new graphql_1.GraphQLScalarType(exports.GraphQLDateTimeConfig);