import { RJSFSchema, StrictRJSFSchema } from './types'; /** JS has no built-in hashing function, so rolling our own * based on Java's hashing fn: * http://www.java2s.com/example/nodejs-utility-method/string-hash/hashcode-4dc2b.html * * @param string - The string for which to get the hash * @returns - The resulting hash of the string in hex format */ function hashString(string: string): string { let hash = 0; for (let i = 0; i < string.length; i += 1) { const chr = string.charCodeAt(i); hash = (hash << 5) - hash + chr; hash = hash & hash; // Convert to 32bit integer } return hash.toString(16); } /** Stringifies the schema and returns the hash of the resulting string. Sorts schema fields * in consistent order before stringify to prevent different hash ids for the same schema. * * @param schema - The schema for which the hash is desired * @returns - The string obtained from the hash of the stringified schema */ export default function hashForSchema(schema: S) { const allKeys = new Set(); // solution source: https://stackoverflow.com/questions/16167581/sort-object-properties-and-json-stringify/53593328#53593328 JSON.stringify(schema, (key, value) => (allKeys.add(key), value)); return hashString(JSON.stringify(schema, Array.from(allKeys).sort())); }