@aws-sdk/sha256-tree-hash
Advanced tools
Comparing version 1.0.0-gamma.8 to 1.0.0-rc.1
@@ -6,2 +6,13 @@ # Change Log | ||
# [1.0.0-rc.1](https://github.com/aws/aws-sdk-js-v3/compare/v1.0.0-gamma.11...v1.0.0-rc.1) (2020-10-19) | ||
### Features | ||
* ready for release candidate ([#1578](https://github.com/aws/aws-sdk-js-v3/issues/1578)) ([519f66c](https://github.com/aws/aws-sdk-js-v3/commit/519f66c6388b91d0bd750a511e6d1af56196835e)) | ||
# [1.0.0-gamma.8](https://github.com/aws/aws-sdk-js-v3/compare/@aws-sdk/sha256-tree-hash@1.0.0-gamma.7...@aws-sdk/sha256-tree-hash@1.0.0-gamma.8) (2020-10-07) | ||
@@ -8,0 +19,0 @@ |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.TreeHash = void 0; | ||
var tslib_1 = require("tslib"); | ||
var MiB = 1048576; | ||
const MiB = 1048576; | ||
/** | ||
* A Hash that will calculate a Sha256 tree hash. | ||
*/ | ||
var TreeHash = /** @class */ (function () { | ||
class TreeHash { | ||
/** | ||
@@ -14,3 +13,3 @@ * Initializes a TreeHash. | ||
*/ | ||
function TreeHash(Sha256, fromUtf8) { | ||
constructor(Sha256, fromUtf8) { | ||
this.Sha256 = Sha256; | ||
@@ -26,9 +25,9 @@ this.fromUtf8 = fromUtf8; | ||
*/ | ||
TreeHash.prototype.hashBuffer = function () { | ||
hashBuffer() { | ||
if (!this.buffer) { | ||
return; | ||
} | ||
var remainingSize = this.buffer.byteLength; | ||
let remainingSize = this.buffer.byteLength; | ||
while (remainingSize >= MiB) { | ||
var hash = new this.Sha256(); | ||
const hash = new this.Sha256(); | ||
hash.update(this.buffer.subarray(0, MiB)); | ||
@@ -39,3 +38,3 @@ this.collectedHashDigests.push(hash.digest()); | ||
} | ||
}; | ||
} | ||
/** | ||
@@ -45,4 +44,4 @@ * Updates the tree hash with byte data. | ||
*/ | ||
TreeHash.prototype.update = function (data) { | ||
var chunk = this.convertToBuffer(data); | ||
update(data) { | ||
const chunk = this.convertToBuffer(data); | ||
if (!this.buffer) { | ||
@@ -53,4 +52,4 @@ this.buffer = chunk; | ||
// determine size of both pieces | ||
var totalSize = this.buffer.byteLength + chunk.byteLength; | ||
var tempBuffer = new Uint8Array(totalSize); | ||
const totalSize = this.buffer.byteLength + chunk.byteLength; | ||
const tempBuffer = new Uint8Array(totalSize); | ||
tempBuffer.set(this.buffer); | ||
@@ -62,57 +61,40 @@ tempBuffer.set(chunk, this.buffer.byteLength); | ||
this.hashBuffer(); | ||
}; | ||
} | ||
/** | ||
* Calculates the digest for the tree hash. | ||
*/ | ||
TreeHash.prototype.digest = function () { | ||
return tslib_1.__awaiter(this, void 0, void 0, function () { | ||
var collectedHashDigests, smallHash, higherLevelHashDigests, i, _a, digest1, digest2, chunk, hash; | ||
return tslib_1.__generator(this, function (_b) { | ||
switch (_b.label) { | ||
case 0: | ||
collectedHashDigests = this.collectedHashDigests; | ||
// remove the reference to collected hashes to free up space | ||
this.collectedHashDigests = []; | ||
// loop through collected hashes | ||
if (this.buffer && this.buffer.byteLength > 0) { | ||
smallHash = new this.Sha256(); | ||
smallHash.update(this.buffer); | ||
collectedHashDigests.push(smallHash.digest()); | ||
// remove the remaining buffer | ||
this.buffer = void 0; | ||
} | ||
_b.label = 1; | ||
case 1: | ||
if (!(collectedHashDigests.length > 1)) return [3 /*break*/, 7]; | ||
higherLevelHashDigests = []; | ||
i = 0; | ||
_b.label = 2; | ||
case 2: | ||
if (!(i < collectedHashDigests.length)) return [3 /*break*/, 6]; | ||
if (!(i + 1 < collectedHashDigests.length)) return [3 /*break*/, 4]; | ||
return [4 /*yield*/, Promise.all([collectedHashDigests[i], collectedHashDigests[i + 1]])]; | ||
case 3: | ||
_a = tslib_1.__read.apply(void 0, [_b.sent(), 2]), digest1 = _a[0], digest2 = _a[1]; | ||
chunk = new Uint8Array(digest1.byteLength + digest2.byteLength); | ||
chunk.set(digest1); | ||
chunk.set(digest2, digest1.byteLength); | ||
hash = new this.Sha256(); | ||
hash.update(chunk); | ||
higherLevelHashDigests.push(hash.digest()); | ||
return [3 /*break*/, 5]; | ||
case 4: | ||
// move a lone hash up a level | ||
higherLevelHashDigests.push(collectedHashDigests[i]); | ||
_b.label = 5; | ||
case 5: | ||
i += 2; | ||
return [3 /*break*/, 2]; | ||
case 6: | ||
collectedHashDigests = higherLevelHashDigests; | ||
return [3 /*break*/, 1]; | ||
case 7: return [2 /*return*/, collectedHashDigests[0]]; | ||
async digest() { | ||
let collectedHashDigests = this.collectedHashDigests; | ||
// remove the reference to collected hashes to free up space | ||
this.collectedHashDigests = []; | ||
// loop through collected hashes | ||
if (this.buffer && this.buffer.byteLength > 0) { | ||
const smallHash = new this.Sha256(); | ||
smallHash.update(this.buffer); | ||
collectedHashDigests.push(smallHash.digest()); | ||
// remove the remaining buffer | ||
this.buffer = void 0; | ||
} | ||
while (collectedHashDigests.length > 1) { | ||
const higherLevelHashDigests = []; | ||
for (let i = 0; i < collectedHashDigests.length; i += 2) { | ||
if (i + 1 < collectedHashDigests.length) { | ||
// concatenate the pair of hashes | ||
const [digest1, digest2] = await Promise.all([collectedHashDigests[i], collectedHashDigests[i + 1]]); | ||
const chunk = new Uint8Array(digest1.byteLength + digest2.byteLength); | ||
chunk.set(digest1); | ||
chunk.set(digest2, digest1.byteLength); | ||
const hash = new this.Sha256(); | ||
hash.update(chunk); | ||
higherLevelHashDigests.push(hash.digest()); | ||
} | ||
}); | ||
}); | ||
}; | ||
else { | ||
// move a lone hash up a level | ||
higherLevelHashDigests.push(collectedHashDigests[i]); | ||
} | ||
} | ||
collectedHashDigests = higherLevelHashDigests; | ||
} | ||
return collectedHashDigests[0]; | ||
} | ||
/** | ||
@@ -122,3 +104,3 @@ * Converts source data into a Uint8Array. | ||
*/ | ||
TreeHash.prototype.convertToBuffer = function (data) { | ||
convertToBuffer(data) { | ||
if (typeof data === "string") { | ||
@@ -131,6 +113,5 @@ return this.fromUtf8(data); | ||
return new Uint8Array(data); | ||
}; | ||
return TreeHash; | ||
}()); | ||
} | ||
} | ||
exports.TreeHash = TreeHash; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { Decoder, Hash, HashConstructor, SourceData } from \"@aws-sdk/types\";\n\nconst MiB = 1048576;\n\n/**\n * A Hash that will calculate a Sha256 tree hash.\n */\nexport class TreeHash implements Hash {\n  private buffer?: Uint8Array;\n  private collectedHashDigests: Promise<Uint8Array>[] = [];\n\n  /**\n   * Initializes a TreeHash.\n   * @param Sha256 A Sha256 hash constructor.\n   */\n  constructor(private readonly Sha256: HashConstructor, private readonly fromUtf8: Decoder) {}\n\n  /**\n   * Generates Sha256 hashes from 1 MiB chunks of the\n   * internal buffer.\n   * Will set the internal buffer to any bytes remaining\n   * that is less than 1 MiB.\n   */\n  private hashBuffer() {\n    if (!this.buffer) {\n      return;\n    }\n\n    let remainingSize = this.buffer.byteLength;\n    while (remainingSize >= MiB) {\n      const hash = new this.Sha256();\n      hash.update(this.buffer.subarray(0, MiB));\n      this.collectedHashDigests.push(hash.digest());\n\n      this.buffer = this.buffer.subarray(MiB);\n      remainingSize = this.buffer.byteLength;\n    }\n  }\n\n  /**\n   * Updates the tree hash with byte data.\n   * @param chunk Byte data to apply to the tree hash.\n   */\n  public update(data: SourceData) {\n    const chunk = this.convertToBuffer(data);\n    if (!this.buffer) {\n      this.buffer = chunk;\n    } else {\n      // determine size of both pieces\n      const totalSize = this.buffer.byteLength + chunk.byteLength;\n      const tempBuffer = new Uint8Array(totalSize);\n\n      tempBuffer.set(this.buffer);\n      tempBuffer.set(chunk, this.buffer.byteLength);\n      this.buffer = tempBuffer;\n    }\n\n    // hasBuffer will set this.buffer with remaining data\n    this.hashBuffer();\n  }\n\n  /**\n   * Calculates the digest for the tree hash.\n   */\n  public async digest(): Promise<Uint8Array> {\n    let collectedHashDigests = this.collectedHashDigests;\n    // remove the reference to collected hashes to free up space\n    this.collectedHashDigests = [];\n\n    // loop through collected hashes\n    if (this.buffer && this.buffer.byteLength > 0) {\n      const smallHash = new this.Sha256();\n      smallHash.update(this.buffer);\n      collectedHashDigests.push(smallHash.digest());\n      // remove the remaining buffer\n      this.buffer = void 0;\n    }\n\n    while (collectedHashDigests.length > 1) {\n      const higherLevelHashDigests: Promise<Uint8Array>[] = [];\n      for (let i = 0; i < collectedHashDigests.length; i += 2) {\n        if (i + 1 < collectedHashDigests.length) {\n          // concatenate the pair of hashes\n          const [digest1, digest2] = await Promise.all([collectedHashDigests[i], collectedHashDigests[i + 1]]);\n\n          const chunk = new Uint8Array(digest1.byteLength + digest2.byteLength);\n          chunk.set(digest1);\n          chunk.set(digest2, digest1.byteLength);\n\n          const hash = new this.Sha256();\n          hash.update(chunk);\n          higherLevelHashDigests.push(hash.digest());\n        } else {\n          // move a lone hash up a level\n          higherLevelHashDigests.push(collectedHashDigests[i]);\n        }\n      }\n      collectedHashDigests = higherLevelHashDigests;\n    }\n\n    return collectedHashDigests[0];\n  }\n\n  /**\n   * Converts source data into a Uint8Array.\n   * @param data Data to convert to a Uint8Array.\n   */\n  private convertToBuffer(data: SourceData): Uint8Array {\n    if (typeof data === \"string\") {\n      return this.fromUtf8(data);\n    }\n\n    if (ArrayBuffer.isView(data)) {\n      return new Uint8Array(data.buffer, data.byteOffset, data.byteLength / Uint8Array.BYTES_PER_ELEMENT);\n    }\n\n    return new Uint8Array(data);\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { Decoder, Hash, HashConstructor, SourceData } from \"@aws-sdk/types\";\n\nconst MiB = 1048576;\n\n/**\n * A Hash that will calculate a Sha256 tree hash.\n */\nexport class TreeHash implements Hash {\n  private buffer?: Uint8Array;\n  private collectedHashDigests: Promise<Uint8Array>[] = [];\n\n  /**\n   * Initializes a TreeHash.\n   * @param Sha256 A Sha256 hash constructor.\n   */\n  constructor(private readonly Sha256: HashConstructor, private readonly fromUtf8: Decoder) {}\n\n  /**\n   * Generates Sha256 hashes from 1 MiB chunks of the\n   * internal buffer.\n   * Will set the internal buffer to any bytes remaining\n   * that is less than 1 MiB.\n   */\n  private hashBuffer() {\n    if (!this.buffer) {\n      return;\n    }\n\n    let remainingSize = this.buffer.byteLength;\n    while (remainingSize >= MiB) {\n      const hash = new this.Sha256();\n      hash.update(this.buffer.subarray(0, MiB));\n      this.collectedHashDigests.push(hash.digest());\n\n      this.buffer = this.buffer.subarray(MiB);\n      remainingSize = this.buffer.byteLength;\n    }\n  }\n\n  /**\n   * Updates the tree hash with byte data.\n   * @param chunk Byte data to apply to the tree hash.\n   */\n  public update(data: SourceData) {\n    const chunk = this.convertToBuffer(data);\n    if (!this.buffer) {\n      this.buffer = chunk;\n    } else {\n      // determine size of both pieces\n      const totalSize = this.buffer.byteLength + chunk.byteLength;\n      const tempBuffer = new Uint8Array(totalSize);\n\n      tempBuffer.set(this.buffer);\n      tempBuffer.set(chunk, this.buffer.byteLength);\n      this.buffer = tempBuffer;\n    }\n\n    // hasBuffer will set this.buffer with remaining data\n    this.hashBuffer();\n  }\n\n  /**\n   * Calculates the digest for the tree hash.\n   */\n  public async digest(): Promise<Uint8Array> {\n    let collectedHashDigests = this.collectedHashDigests;\n    // remove the reference to collected hashes to free up space\n    this.collectedHashDigests = [];\n\n    // loop through collected hashes\n    if (this.buffer && this.buffer.byteLength > 0) {\n      const smallHash = new this.Sha256();\n      smallHash.update(this.buffer);\n      collectedHashDigests.push(smallHash.digest());\n      // remove the remaining buffer\n      this.buffer = void 0;\n    }\n\n    while (collectedHashDigests.length > 1) {\n      const higherLevelHashDigests: Promise<Uint8Array>[] = [];\n      for (let i = 0; i < collectedHashDigests.length; i += 2) {\n        if (i + 1 < collectedHashDigests.length) {\n          // concatenate the pair of hashes\n          const [digest1, digest2] = await Promise.all([collectedHashDigests[i], collectedHashDigests[i + 1]]);\n\n          const chunk = new Uint8Array(digest1.byteLength + digest2.byteLength);\n          chunk.set(digest1);\n          chunk.set(digest2, digest1.byteLength);\n\n          const hash = new this.Sha256();\n          hash.update(chunk);\n          higherLevelHashDigests.push(hash.digest());\n        } else {\n          // move a lone hash up a level\n          higherLevelHashDigests.push(collectedHashDigests[i]);\n        }\n      }\n      collectedHashDigests = higherLevelHashDigests;\n    }\n\n    return collectedHashDigests[0];\n  }\n\n  /**\n   * Converts source data into a Uint8Array.\n   * @param data Data to convert to a Uint8Array.\n   */\n  private convertToBuffer(data: SourceData): Uint8Array {\n    if (typeof data === \"string\") {\n      return this.fromUtf8(data);\n    }\n\n    if (ArrayBuffer.isView(data)) {\n      return new Uint8Array(data.buffer, data.byteOffset, data.byteLength / Uint8Array.BYTES_PER_ELEMENT);\n    }\n\n    return new Uint8Array(data);\n  }\n}\n"]} |
{ | ||
"name": "@aws-sdk/sha256-tree-hash", | ||
"version": "1.0.0-gamma.8", | ||
"version": "1.0.0-rc.1", | ||
"scripts": { | ||
@@ -21,3 +21,3 @@ "prepublishOnly": "yarn build:cjs && yarn build:es", | ||
"dependencies": { | ||
"@aws-sdk/types": "1.0.0-gamma.7", | ||
"@aws-sdk/types": "1.0.0-rc.1", | ||
"tslib": "^1.8.0" | ||
@@ -27,8 +27,11 @@ }, | ||
"@aws-crypto/sha256-js": "^1.0.0-alpha.0", | ||
"@aws-sdk/util-hex-encoding": "1.0.0-gamma.7", | ||
"@aws-sdk/util-utf8-node": "1.0.0-gamma.7", | ||
"@aws-sdk/util-hex-encoding": "1.0.0-rc.1", | ||
"@aws-sdk/util-utf8-node": "1.0.0-rc.1", | ||
"@types/jest": "^26.0.4", | ||
"jest": "^26.1.0", | ||
"typescript": "~4.0.2" | ||
}, | ||
"engines": { | ||
"node": ">= 10.0.0" | ||
} | ||
} |
{ | ||
"compilerOptions": { | ||
"declaration": true, | ||
"strict": true, | ||
"sourceMap": false, | ||
"downlevelIteration": true, | ||
"importHelpers": true, | ||
"noEmitHelpers": true, | ||
"lib": ["dom", "es5", "es2015.promise", "es2015.collection", "es2015.iterable", "es2015.symbol.wellknown"], | ||
"rootDir": "./src", | ||
"outDir": "./dist/cjs", | ||
"inlineSourceMap": true, | ||
"inlineSources": true, | ||
"baseUrl": "." | ||
@@ -15,0 +6,0 @@ }, |
{ | ||
"compilerOptions": { | ||
"declaration": true, | ||
"strict": true, | ||
"sourceMap": false, | ||
"downlevelIteration": true, | ||
"importHelpers": true, | ||
"noEmitHelpers": true, | ||
"lib": ["dom", "es5", "es2015.promise", "es2015.collection", "es2015.iterable", "es2015.symbol.wellknown"], | ||
"rootDir": "./src", | ||
"outDir": "./dist/es", | ||
"inlineSourceMap": true, | ||
"inlineSources": true, | ||
"baseUrl": "." | ||
@@ -15,0 +7,0 @@ }, |
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
68709
424
+ Added@aws-sdk/types@1.0.0-rc.1(transitive)
- Removed@aws-sdk/types@1.0.0-gamma.7(transitive)
Updated@aws-sdk/types@1.0.0-rc.1