Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@aws-sdk/sha256-tree-hash

Package Overview
Dependencies
Maintainers
5
Versions
164
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@aws-sdk/sha256-tree-hash - npm Package Compare versions

Comparing version 1.0.0-gamma.8 to 1.0.0-rc.1

11

CHANGELOG.md

@@ -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 @@

117

dist/cjs/index.js
"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 @@ },

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc