1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950 |
- /**
- * @author n1474335 [n1474335@gmail.com]
- * @copyright Crown Copyright 2016
- * @license Apache-2.0
- */
- import Operation from "../Operation.mjs";
- import Utils from "../Utils.mjs";
- /**
- * Fletcher-8 Checksum operation
- */
- class Fletcher8Checksum extends Operation {
- /**
- * Fletcher8Checksum constructor
- */
- constructor() {
- super();
- this.name = "Fletcher-8 Checksum";
- this.module = "Crypto";
- this.description = "The Fletcher checksum is an algorithm for computing a position-dependent checksum devised by John Gould Fletcher at Lawrence Livermore Labs in the late 1970s.<br><br>The objective of the Fletcher checksum was to provide error-detection properties approaching those of a cyclic redundancy check but with the lower computational effort associated with summation techniques.";
- this.infoURL = "https://wikipedia.org/wiki/Fletcher%27s_checksum";
- this.inputType = "ArrayBuffer";
- this.outputType = "string";
- this.args = [];
- }
- /**
- * @param {ArrayBuffer} input
- * @param {Object[]} args
- * @returns {string}
- */
- run(input, args) {
- let a = 0,
- b = 0;
- input = new Uint8Array(input);
- for (let i = 0; i < input.length; i++) {
- a = (a + input[i]) % 0xf;
- b = (b + a) % 0xf;
- }
- return Utils.hex(((b << 4) | a) >>> 0, 2);
- }
- }
- export default Fletcher8Checksum;
|