Skip to content
Snippets Groups Projects
Select Git revision
  • 613f9cfb6ab88fb8986de882a2b53c4488616fec
  • master default protected
  • 1.31
  • 4.34.1
  • 4.34.0
  • 4.33.1
  • 4.33.0
  • 4.32.2
  • 4.32.1
  • 4.32.0
  • 4.31.0
  • 4.30.1
  • 4.30.0
  • 4.29.1
  • 4.29.0
  • 4.28.0
  • 4.27.0
  • 4.26.0
  • 4.25.5
  • 4.25.4
  • 4.25.3
  • 4.25.2
  • 4.25.1
23 results

abstract.mjs

Blame
  • abstract.mjs 1.36 KiB
    /**
     * Copyright schukai GmbH and contributors 2023. All Rights Reserved.
     * Node module: @schukai/monster
     * This file is licensed under the AGPLv3 License.
     * License text available at https://www.gnu.org/licenses/agpl-3.0.en.html
     */
    
    import { Base } from "../types/base.mjs";
    import { instanceSymbol } from "../constants.mjs";
    
    export { AbstractConstraint };
    
    /**
     * Constraints are used to define conditions that must be met by the value of a variable.
     *
     * The uniform API of the constraints allows chains to be formed.
     *
     * The abstract constraint defines the api for all constraints. mainly the method isValid() is defined.
     *
     * Derived classes must implement the method isValid().
     *
     * @license AGPLv3
     * @since 1.3.0
     * @copyright schukai GmbH
     * @memberOf Monster.Constraints
     * @summary The abstract constraint
     */
    class AbstractConstraint extends Base {
        /**
         *
         */
        constructor() {
            super();
        }
    
        /**
         * this method must return a promise containing the result of the check.
         *
         * @param {*} value
         * @returns {Promise}
         */
        isValid(value) {
            return Promise.reject(value);
        }
    
        /**
         * This method is called by the `instanceof` operator.
         * @returns {symbol}
         * @since 2.1.0
         */
        static get [instanceSymbol]() {
            return Symbol.for("@schukai/monster/constraints/abstract-constraint");
        }
    }