2024-09-18 08:27:46 -07:00
|
|
|
/*
|
|
|
|
MIT License http://www.opensource.org/licenses/mit-license.php
|
|
|
|
*/
|
|
|
|
|
|
|
|
"use strict";
|
|
|
|
|
|
|
|
const { register } = require("./serialization");
|
|
|
|
|
|
|
|
/** @typedef {import("../serialization/ObjectMiddleware").Constructor} Constructor */
|
2024-11-04 11:06:36 -08:00
|
|
|
/** @typedef {import("../serialization/ObjectMiddleware").ObjectDeserializerContext} ObjectDeserializerContext */
|
|
|
|
/** @typedef {import("../serialization/ObjectMiddleware").ObjectSerializerContext} ObjectSerializerContext */
|
2024-09-18 08:27:46 -07:00
|
|
|
|
2024-11-04 11:06:36 -08:00
|
|
|
/** @typedef {{ serialize: (context: ObjectSerializerContext) => void, deserialize: (context: ObjectDeserializerContext) => void }} SerializableClass */
|
|
|
|
/**
|
|
|
|
* @template {SerializableClass} T
|
|
|
|
* @typedef {(new (...params: any[]) => T) & { deserialize?: (context: ObjectDeserializerContext) => T }} SerializableClassConstructor
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @template {SerializableClass} T
|
|
|
|
*/
|
2024-09-18 08:27:46 -07:00
|
|
|
class ClassSerializer {
|
2024-11-04 11:06:36 -08:00
|
|
|
/**
|
|
|
|
* @param {SerializableClassConstructor<T>} Constructor constructor
|
|
|
|
*/
|
2024-09-18 08:27:46 -07:00
|
|
|
constructor(Constructor) {
|
|
|
|
this.Constructor = Constructor;
|
|
|
|
}
|
|
|
|
|
2024-11-04 11:06:36 -08:00
|
|
|
/**
|
|
|
|
* @param {T} obj obj
|
|
|
|
* @param {ObjectSerializerContext} context context
|
|
|
|
*/
|
2024-09-18 08:27:46 -07:00
|
|
|
serialize(obj, context) {
|
|
|
|
obj.serialize(context);
|
|
|
|
}
|
|
|
|
|
2024-11-04 11:06:36 -08:00
|
|
|
/**
|
|
|
|
* @param {ObjectDeserializerContext} context context
|
|
|
|
* @returns {T} obj
|
|
|
|
*/
|
2024-09-18 08:27:46 -07:00
|
|
|
deserialize(context) {
|
|
|
|
if (typeof this.Constructor.deserialize === "function") {
|
|
|
|
return this.Constructor.deserialize(context);
|
|
|
|
}
|
|
|
|
const obj = new this.Constructor();
|
|
|
|
obj.deserialize(context);
|
|
|
|
return obj;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2024-11-04 11:06:36 -08:00
|
|
|
* @template {Constructor} T
|
|
|
|
* @param {T} Constructor the constructor
|
2024-09-18 08:27:46 -07:00
|
|
|
* @param {string} request the request which will be required when deserializing
|
|
|
|
* @param {string | null} [name] the name to make multiple serializer unique when sharing a request
|
|
|
|
*/
|
|
|
|
module.exports = (Constructor, request, name = null) => {
|
|
|
|
register(Constructor, request, name, new ClassSerializer(Constructor));
|
|
|
|
};
|