@apache-arrow/esnext-cjs
Advanced tools
Comparing version 0.1.1 to 0.1.2
@@ -0,1 +1,12 @@ | ||
<a name="0.1.2"></a> | ||
## [0.1.2](https://github.com/graphistry/arrow/compare/v0.1.1...v0.1.2) (2017-09-06) | ||
### Bug Fixes | ||
* **DictionaryVector:** Add index and value methods to DictionaryVector ([a8341f5](https://github.com/graphistry/arrow/commit/a8341f5)) | ||
* **Table:** Add fromStruct method to Table ([e1c7852](https://github.com/graphistry/arrow/commit/e1c7852)) | ||
<a name="0.1.1"></a> | ||
@@ -2,0 +13,0 @@ ## [0.1.1](https://github.com/graphistry/arrow/compare/v0.1.0...v0.1.1) (2017-08-26) |
@@ -5,3 +5,3 @@ { | ||
"name": "@apache-arrow/esnext-cjs", | ||
"version": "0.1.1", | ||
"version": "0.1.2", | ||
"description": "Apache's columnar in-memory data format for big data analytics", | ||
@@ -8,0 +8,0 @@ "author": "Graphistry, Inc.", |
/// <reference types="node" /> | ||
import { StructVector } from './vector/struct'; | ||
import { Vector } from './vector/vector'; | ||
@@ -10,2 +11,3 @@ export declare class Table implements Iterable<Map<string, any>> { | ||
static from(...bytes: Array<Uint8Array | Buffer | string>): Table; | ||
static fromStruct(vector: StructVector): Table; | ||
constructor(columns: Vector<any>[]); | ||
@@ -12,0 +14,0 @@ [Symbol.iterator](): IterableIterator<Map<any, any>>; |
@@ -28,2 +28,5 @@ // Licensed to the Apache Software Foundation (ASF) under one | ||
} | ||
static fromStruct(vector) { | ||
return new Table(vector.vectors); | ||
} | ||
constructor(columns) { | ||
@@ -127,2 +130,2 @@ this._columns = columns || []; | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["table.ts"],"names":[],"mappings":"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","file":"table.js","sourcesContent":["// Licensed to the Apache Software Foundation (ASF) under one\n// or more contributor license agreements.  See the NOTICE file\n// distributed with this work for additional information\n// regarding copyright ownership.  The ASF licenses this file\n// to you under the Apache License, Version 2.0 (the\n// \"License\"); you may not use this file except in compliance\n// with the License.  You may obtain a copy of the License at\n//\n//   http://www.apache.org/licenses/LICENSE-2.0\n//\n// Unless required by applicable law or agreed to in writing,\n// software distributed under the License is distributed on an\n// \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n// KIND, either express or implied.  See the License for the\n// specific language governing permissions and limitations\n// under the License.\n\nimport { readBuffers } from './reader/arrow';\nimport { Vector, sliceToRangeArgs } from './vector/vector';\n\nexport class Table implements Iterable<Map<string, any>> {\n    public length: number;\n    protected _columns: Vector<any>[];\n    protected _columnsMap: { [k: string]: Vector<any> };\n    static from(...bytes: Array<Uint8Array | Buffer | string>) {\n        let columns: Vector<any>[];\n        for (let vectors of readBuffers(...bytes)) {\n            columns = !columns ? vectors : columns.map((v, i) => v.concat(vectors[i]));\n        }\n        return new Table(columns);\n    }\n    constructor(columns: Vector<any>[]) {\n        this._columns = columns || [];\n        this.length = Math.max(...this._columns.map((v) => v.length));\n        this._columnsMap = this._columns.reduce((map, vec) => {\n            return (map[vec.name] = vec) && map || map;\n        }, <any> {});\n    }\n    *[Symbol.iterator]() {\n        for (let cols = this._columns, i = -1, n = this.length; ++i < n;) {\n            yield rowAsMap(i, cols);\n        }\n    }\n    *rows(startRow?: number | boolean, endRow?: number | boolean, compact?: boolean) {\n        let start = startRow as number, end = endRow as number;\n        if (typeof startRow === 'boolean') {\n            compact = startRow;\n            start = end;\n            end = undefined;\n        } else if (typeof endRow === 'boolean') {\n            compact = endRow;\n            end = undefined;\n        }\n        let rowIndex = -1, { length } = this;\n        const [rowOffset, rowsTotal] = sliceToRangeArgs(length, start, end);\n        while (++rowIndex < rowsTotal) {\n            yield this.getRow((rowIndex + rowOffset) % length, compact);\n        }\n    }\n    *cols(startCol?: number, endCol?: number) {\n        for (const column of this._columns.slice(startCol, endCol)) {\n            yield column;\n        }\n    }\n    getRow(rowIndex: number, compact?: boolean) {\n        return (compact && rowAsArray || rowAsObject)(rowIndex, this._columns);\n    }\n    getCell(columnName: string, rowIndex: number) {\n        return this.getColumn(columnName).get(rowIndex);\n    }\n    getCellAt(columnIndex: number, rowIndex: number) {\n        return this.getColumnAt(columnIndex).get(rowIndex);\n    }\n    getColumn<T = any>(columnName: string) {\n        return this._columnsMap[columnName] as Vector<T>;\n    }\n    getColumnAt<T = any>(columnIndex: number) {\n        return this._columns[columnIndex] as Vector<T>;\n    }\n    toString({ index = false } = {}) {\n        const { length } = this;\n        if (length <= 0) { return ''; }\n        const maxColumnWidths = [];\n        const rows = new Array(length + 1);\n        rows[0] = this._columns.map((c) => c.name);\n        index && rows[0].unshift('Index');\n        for (let i = -1, n = rows.length - 1; ++i < n;) {\n            rows[i + 1] = this.getRow(i, true);\n            index && rows[i + 1].unshift(i);\n        }\n        // Pass one to convert to strings and count max column widths\n        for (let i = -1, n = rows.length; ++i < n;) {\n            const row = rows[i];\n            for (let j = -1, k = row.length; ++j < k;) {\n                const val = row[j] = `${row[j]}`;\n                maxColumnWidths[j] = !maxColumnWidths[j]\n                    ? val.length\n                    : Math.max(maxColumnWidths[j], val.length);\n            }\n        }\n        // Pass two to pad each one to max column width\n        for (let i = -1, n = rows.length; ++i < n;) {\n            const row = rows[i];\n            for (let j = -1, k = row.length; ++j < k;) {\n                row[j] = leftPad(row[j], ' ', maxColumnWidths[j]);\n            }\n            rows[i] = row.join(', ');\n        }\n        return rows.join('\\n');\n    }\n}\n\nTable.prototype.length = 0;\n\nfunction leftPad(str, fill, n) {\n    return (new Array(n + 1).join(fill) + str).slice(-1 * n);\n}\n\nfunction rowAsMap(row: number, columns: Vector<any>[]) {\n    return columns.reduce((map, vector) => map.set(vector.name, vector.get(row)), new Map());\n}\n\nfunction rowAsObject(rowIndex: number, columns: Vector<any>[]) {\n    return columns.reduce((row, vector) => (row[vector.name] = vector.get(rowIndex)) && row || row, Object.create(null));\n}\n\nfunction rowAsArray(rowIndex: number, columns: Vector<any>[]) {\n    return columns.reduce((row, vector, columnIndex) => (row[columnIndex] = vector.get(rowIndex)) && row || row, new Array(columns.length));\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["table.ts"],"names":[],"mappings":"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","file":"table.js","sourcesContent":["// Licensed to the Apache Software Foundation (ASF) under one\n// or more contributor license agreements.  See the NOTICE file\n// distributed with this work for additional information\n// regarding copyright ownership.  The ASF licenses this file\n// to you under the Apache License, Version 2.0 (the\n// \"License\"); you may not use this file except in compliance\n// with the License.  You may obtain a copy of the License at\n//\n//   http://www.apache.org/licenses/LICENSE-2.0\n//\n// Unless required by applicable law or agreed to in writing,\n// software distributed under the License is distributed on an\n// \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n// KIND, either express or implied.  See the License for the\n// specific language governing permissions and limitations\n// under the License.\n\nimport { readBuffers } from './reader/arrow';\nimport { StructVector } from './vector/struct';\nimport { Vector, sliceToRangeArgs } from './vector/vector';\n\nexport class Table implements Iterable<Map<string, any>> {\n    public length: number;\n    protected _columns: Vector<any>[];\n    protected _columnsMap: { [k: string]: Vector<any> };\n    static from(...bytes: Array<Uint8Array | Buffer | string>) {\n        let columns: Vector<any>[];\n        for (let vectors of readBuffers(...bytes)) {\n            columns = !columns ? vectors : columns.map((v, i) => v.concat(vectors[i]));\n        }\n        return new Table(columns);\n    }\n    static fromStruct(vector: StructVector) {\n        return new Table((<any> vector).vectors);\n    }\n    constructor(columns: Vector<any>[]) {\n        this._columns = columns || [];\n        this.length = Math.max(...this._columns.map((v) => v.length));\n        this._columnsMap = this._columns.reduce((map, vec) => {\n            return (map[vec.name] = vec) && map || map;\n        }, <any> {});\n    }\n    *[Symbol.iterator]() {\n        for (let cols = this._columns, i = -1, n = this.length; ++i < n;) {\n            yield rowAsMap(i, cols);\n        }\n    }\n    *rows(startRow?: number | boolean, endRow?: number | boolean, compact?: boolean) {\n        let start = startRow as number, end = endRow as number;\n        if (typeof startRow === 'boolean') {\n            compact = startRow;\n            start = end;\n            end = undefined;\n        } else if (typeof endRow === 'boolean') {\n            compact = endRow;\n            end = undefined;\n        }\n        let rowIndex = -1, { length } = this;\n        const [rowOffset, rowsTotal] = sliceToRangeArgs(length, start, end);\n        while (++rowIndex < rowsTotal) {\n            yield this.getRow((rowIndex + rowOffset) % length, compact);\n        }\n    }\n    *cols(startCol?: number, endCol?: number) {\n        for (const column of this._columns.slice(startCol, endCol)) {\n            yield column;\n        }\n    }\n    getRow(rowIndex: number, compact?: boolean) {\n        return (compact && rowAsArray || rowAsObject)(rowIndex, this._columns);\n    }\n    getCell(columnName: string, rowIndex: number) {\n        return this.getColumn(columnName).get(rowIndex);\n    }\n    getCellAt(columnIndex: number, rowIndex: number) {\n        return this.getColumnAt(columnIndex).get(rowIndex);\n    }\n    getColumn<T = any>(columnName: string) {\n        return this._columnsMap[columnName] as Vector<T>;\n    }\n    getColumnAt<T = any>(columnIndex: number) {\n        return this._columns[columnIndex] as Vector<T>;\n    }\n    toString({ index = false } = {}) {\n        const { length } = this;\n        if (length <= 0) { return ''; }\n        const maxColumnWidths = [];\n        const rows = new Array(length + 1);\n        rows[0] = this._columns.map((c) => c.name);\n        index && rows[0].unshift('Index');\n        for (let i = -1, n = rows.length - 1; ++i < n;) {\n            rows[i + 1] = this.getRow(i, true);\n            index && rows[i + 1].unshift(i);\n        }\n        // Pass one to convert to strings and count max column widths\n        for (let i = -1, n = rows.length; ++i < n;) {\n            const row = rows[i];\n            for (let j = -1, k = row.length; ++j < k;) {\n                const val = row[j] = `${row[j]}`;\n                maxColumnWidths[j] = !maxColumnWidths[j]\n                    ? val.length\n                    : Math.max(maxColumnWidths[j], val.length);\n            }\n        }\n        // Pass two to pad each one to max column width\n        for (let i = -1, n = rows.length; ++i < n;) {\n            const row = rows[i];\n            for (let j = -1, k = row.length; ++j < k;) {\n                row[j] = leftPad(row[j], ' ', maxColumnWidths[j]);\n            }\n            rows[i] = row.join(', ');\n        }\n        return rows.join('\\n');\n    }\n}\n\nTable.prototype.length = 0;\n\nfunction leftPad(str, fill, n) {\n    return (new Array(n + 1).join(fill) + str).slice(-1 * n);\n}\n\nfunction rowAsMap(row: number, columns: Vector<any>[]) {\n    return columns.reduce((map, vector) => map.set(vector.name, vector.get(row)), new Map());\n}\n\nfunction rowAsObject(rowIndex: number, columns: Vector<any>[]) {\n    return columns.reduce((row, vector) => (row[vector.name] = vector.get(rowIndex)) && row || row, Object.create(null));\n}\n\nfunction rowAsArray(rowIndex: number, columns: Vector<any>[]) {\n    return columns.reduce((row, vector, columnIndex) => (row[columnIndex] = vector.get(rowIndex)) && row || row, new Array(columns.length));\n}\n"]} |
import { Vector } from './vector'; | ||
export declare class DictionaryVector<T> extends Vector<T> { | ||
protected index: Vector<number>; | ||
protected dictionary: Vector<T>; | ||
protected data: Vector<T>; | ||
protected keys: Vector<number>; | ||
constructor(index: Vector<number>, dictionary: Vector<T>); | ||
index(index: number): number; | ||
value(index: number): T; | ||
get(index: number): T; | ||
@@ -7,0 +9,0 @@ concat(vector: DictionaryVector<T>): any; |
@@ -22,16 +22,22 @@ // Licensed to the Apache Software Foundation (ASF) under one | ||
super(); | ||
this.index = index; | ||
this.dictionary = dictionary; | ||
this.keys = index; | ||
this.data = dictionary; | ||
this.length = index && index.length || 0; | ||
} | ||
index(index) { | ||
return this.keys.get(index); | ||
} | ||
value(index) { | ||
return this.data.get(index); | ||
} | ||
get(index) { | ||
return this.dictionary.get(this.index.get(index)); | ||
return this.value(this.index(index)); | ||
} | ||
concat(vector) { | ||
return DictionaryVector.from(this, this.length + vector.length, this.index.concat(vector.index), this.dictionary); | ||
return DictionaryVector.from(this, this.length + vector.length, this.keys.concat(vector.keys), this.data); | ||
} | ||
*[Symbol.iterator]() { | ||
let { dictionary } = this; | ||
for (const loc of this.index) { | ||
yield dictionary.get(loc); | ||
let { data } = this; | ||
for (const loc of this.keys) { | ||
yield data.get(loc); | ||
} | ||
@@ -42,2 +48,2 @@ } | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInZlY3Rvci9kaWN0aW9uYXJ5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLDZEQUE2RDtBQUM3RCwrREFBK0Q7QUFDL0Qsd0RBQXdEO0FBQ3hELDZEQUE2RDtBQUM3RCxvREFBb0Q7QUFDcEQsNkRBQTZEO0FBQzdELDZEQUE2RDtBQUM3RCxFQUFFO0FBQ0YsK0NBQStDO0FBQy9DLEVBQUU7QUFDRiw2REFBNkQ7QUFDN0QsOERBQThEO0FBQzlELHlEQUF5RDtBQUN6RCw0REFBNEQ7QUFDNUQsMERBQTBEO0FBQzFELHFCQUFxQjs7QUFFckIscUNBQWtDO0FBRWxDLHNCQUFpQyxTQUFRLGVBQVM7SUFHOUMsWUFBWSxLQUFxQixFQUFFLFVBQXFCO1FBQ3BELEtBQUssRUFBRSxDQUFDO1FBQ1IsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7UUFDbkIsSUFBSSxDQUFDLFVBQVUsR0FBRyxVQUFVLENBQUM7UUFDN0IsSUFBSSxDQUFDLE1BQU0sR0FBRyxLQUFLLElBQUksS0FBSyxDQUFDLE1BQU0sSUFBSSxDQUFDLENBQUM7SUFDN0MsQ0FBQztJQUNELEdBQUcsQ0FBQyxLQUFhO1FBQ2IsTUFBTSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7SUFDdEQsQ0FBQztJQUNELE1BQU0sQ0FBQyxNQUEyQjtRQUM5QixNQUFNLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLElBQUksRUFDN0IsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUMsTUFBTSxFQUMzQixJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEVBQy9CLElBQUksQ0FBQyxVQUFVLENBQ2xCLENBQUM7SUFDTixDQUFDO0lBQ0QsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUM7UUFDZCxJQUFJLEVBQUUsVUFBVSxFQUFFLEdBQUcsSUFBSSxDQUFDO1FBQzFCLEdBQUcsQ0FBQyxDQUFDLE1BQU0sR0FBRyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO1lBQzNCLE1BQU0sVUFBVSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUM5QixDQUFDO0lBQ0wsQ0FBQztDQUNKO0FBekJELDRDQXlCQyIsImZpbGUiOiJ2ZWN0b3IvZGljdGlvbmFyeS5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8vIExpY2Vuc2VkIHRvIHRoZSBBcGFjaGUgU29mdHdhcmUgRm91bmRhdGlvbiAoQVNGKSB1bmRlciBvbmVcbi8vIG9yIG1vcmUgY29udHJpYnV0b3IgbGljZW5zZSBhZ3JlZW1lbnRzLiAgU2VlIHRoZSBOT1RJQ0UgZmlsZVxuLy8gZGlzdHJpYnV0ZWQgd2l0aCB0aGlzIHdvcmsgZm9yIGFkZGl0aW9uYWwgaW5mb3JtYXRpb25cbi8vIHJlZ2FyZGluZyBjb3B5cmlnaHQgb3duZXJzaGlwLiAgVGhlIEFTRiBsaWNlbnNlcyB0aGlzIGZpbGVcbi8vIHRvIHlvdSB1bmRlciB0aGUgQXBhY2hlIExpY2Vuc2UsIFZlcnNpb24gMi4wICh0aGVcbi8vIFwiTGljZW5zZVwiKTsgeW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZVxuLy8gd2l0aCB0aGUgTGljZW5zZS4gIFlvdSBtYXkgb2J0YWluIGEgY29weSBvZiB0aGUgTGljZW5zZSBhdFxuLy9cbi8vICAgaHR0cDovL3d3dy5hcGFjaGUub3JnL2xpY2Vuc2VzL0xJQ0VOU0UtMi4wXG4vL1xuLy8gVW5sZXNzIHJlcXVpcmVkIGJ5IGFwcGxpY2FibGUgbGF3IG9yIGFncmVlZCB0byBpbiB3cml0aW5nLFxuLy8gc29mdHdhcmUgZGlzdHJpYnV0ZWQgdW5kZXIgdGhlIExpY2Vuc2UgaXMgZGlzdHJpYnV0ZWQgb24gYW5cbi8vIFwiQVMgSVNcIiBCQVNJUywgV0lUSE9VVCBXQVJSQU5USUVTIE9SIENPTkRJVElPTlMgT0YgQU5ZXG4vLyBLSU5ELCBlaXRoZXIgZXhwcmVzcyBvciBpbXBsaWVkLiAgU2VlIHRoZSBMaWNlbnNlIGZvciB0aGVcbi8vIHNwZWNpZmljIGxhbmd1YWdlIGdvdmVybmluZyBwZXJtaXNzaW9ucyBhbmQgbGltaXRhdGlvbnNcbi8vIHVuZGVyIHRoZSBMaWNlbnNlLlxuXG5pbXBvcnQgeyBWZWN0b3IgfSBmcm9tICcuL3ZlY3Rvcic7XG5cbmV4cG9ydCBjbGFzcyBEaWN0aW9uYXJ5VmVjdG9yPFQ+IGV4dGVuZHMgVmVjdG9yPFQ+IHtcbiAgICBwcm90ZWN0ZWQgaW5kZXg6IFZlY3RvcjxudW1iZXI+O1xuICAgIHByb3RlY3RlZCBkaWN0aW9uYXJ5OiBWZWN0b3I8VD47XG4gICAgY29uc3RydWN0b3IoaW5kZXg6IFZlY3RvcjxudW1iZXI+LCBkaWN0aW9uYXJ5OiBWZWN0b3I8VD4pIHtcbiAgICAgICAgc3VwZXIoKTtcbiAgICAgICAgdGhpcy5pbmRleCA9IGluZGV4O1xuICAgICAgICB0aGlzLmRpY3Rpb25hcnkgPSBkaWN0aW9uYXJ5O1xuICAgICAgICB0aGlzLmxlbmd0aCA9IGluZGV4ICYmIGluZGV4Lmxlbmd0aCB8fCAwO1xuICAgIH1cbiAgICBnZXQoaW5kZXg6IG51bWJlcikge1xuICAgICAgICByZXR1cm4gdGhpcy5kaWN0aW9uYXJ5LmdldCh0aGlzLmluZGV4LmdldChpbmRleCkpO1xuICAgIH1cbiAgICBjb25jYXQodmVjdG9yOiBEaWN0aW9uYXJ5VmVjdG9yPFQ+KSB7XG4gICAgICAgIHJldHVybiBEaWN0aW9uYXJ5VmVjdG9yLmZyb20odGhpcyxcbiAgICAgICAgICAgIHRoaXMubGVuZ3RoICsgdmVjdG9yLmxlbmd0aCxcbiAgICAgICAgICAgIHRoaXMuaW5kZXguY29uY2F0KHZlY3Rvci5pbmRleCksXG4gICAgICAgICAgICB0aGlzLmRpY3Rpb25hcnlcbiAgICAgICAgKTtcbiAgICB9XG4gICAgKltTeW1ib2wuaXRlcmF0b3JdKCkge1xuICAgICAgICBsZXQgeyBkaWN0aW9uYXJ5IH0gPSB0aGlzO1xuICAgICAgICBmb3IgKGNvbnN0IGxvYyBvZiB0aGlzLmluZGV4KSB7XG4gICAgICAgICAgICB5aWVsZCBkaWN0aW9uYXJ5LmdldChsb2MpO1xuICAgICAgICB9XG4gICAgfVxufSJdfQ== | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInZlY3Rvci9kaWN0aW9uYXJ5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLDZEQUE2RDtBQUM3RCwrREFBK0Q7QUFDL0Qsd0RBQXdEO0FBQ3hELDZEQUE2RDtBQUM3RCxvREFBb0Q7QUFDcEQsNkRBQTZEO0FBQzdELDZEQUE2RDtBQUM3RCxFQUFFO0FBQ0YsK0NBQStDO0FBQy9DLEVBQUU7QUFDRiw2REFBNkQ7QUFDN0QsOERBQThEO0FBQzlELHlEQUF5RDtBQUN6RCw0REFBNEQ7QUFDNUQsMERBQTBEO0FBQzFELHFCQUFxQjs7QUFFckIscUNBQWtDO0FBRWxDLHNCQUFpQyxTQUFRLGVBQVM7SUFHOUMsWUFBWSxLQUFxQixFQUFFLFVBQXFCO1FBQ3BELEtBQUssRUFBRSxDQUFDO1FBQ1IsSUFBSSxDQUFDLElBQUksR0FBRyxLQUFLLENBQUM7UUFDbEIsSUFBSSxDQUFDLElBQUksR0FBRyxVQUFVLENBQUM7UUFDdkIsSUFBSSxDQUFDLE1BQU0sR0FBRyxLQUFLLElBQUksS0FBSyxDQUFDLE1BQU0sSUFBSSxDQUFDLENBQUM7SUFDN0MsQ0FBQztJQUNELEtBQUssQ0FBQyxLQUFhO1FBQ2YsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2hDLENBQUM7SUFDRCxLQUFLLENBQUMsS0FBYTtRQUNmLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNoQyxDQUFDO0lBQ0QsR0FBRyxDQUFDLEtBQWE7UUFDYixNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7SUFDekMsQ0FBQztJQUNELE1BQU0sQ0FBQyxNQUEyQjtRQUM5QixNQUFNLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLElBQUksRUFDN0IsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUMsTUFBTSxFQUMzQixJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEVBQzdCLElBQUksQ0FBQyxJQUFJLENBQ1osQ0FBQztJQUNOLENBQUM7SUFDRCxDQUFDLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQztRQUNkLElBQUksRUFBRSxJQUFJLEVBQUUsR0FBRyxJQUFJLENBQUM7UUFDcEIsR0FBRyxDQUFDLENBQUMsTUFBTSxHQUFHLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7WUFDMUIsTUFBTSxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ3hCLENBQUM7SUFDTCxDQUFDO0NBQ0o7QUEvQkQsNENBK0JDIiwiZmlsZSI6InZlY3Rvci9kaWN0aW9uYXJ5LmpzIiwic291cmNlc0NvbnRlbnQiOlsiLy8gTGljZW5zZWQgdG8gdGhlIEFwYWNoZSBTb2Z0d2FyZSBGb3VuZGF0aW9uIChBU0YpIHVuZGVyIG9uZVxuLy8gb3IgbW9yZSBjb250cmlidXRvciBsaWNlbnNlIGFncmVlbWVudHMuICBTZWUgdGhlIE5PVElDRSBmaWxlXG4vLyBkaXN0cmlidXRlZCB3aXRoIHRoaXMgd29yayBmb3IgYWRkaXRpb25hbCBpbmZvcm1hdGlvblxuLy8gcmVnYXJkaW5nIGNvcHlyaWdodCBvd25lcnNoaXAuICBUaGUgQVNGIGxpY2Vuc2VzIHRoaXMgZmlsZVxuLy8gdG8geW91IHVuZGVyIHRoZSBBcGFjaGUgTGljZW5zZSwgVmVyc2lvbiAyLjAgKHRoZVxuLy8gXCJMaWNlbnNlXCIpOyB5b3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlXG4vLyB3aXRoIHRoZSBMaWNlbnNlLiAgWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4vL1xuLy8gICBodHRwOi8vd3d3LmFwYWNoZS5vcmcvbGljZW5zZXMvTElDRU5TRS0yLjBcbi8vXG4vLyBVbmxlc3MgcmVxdWlyZWQgYnkgYXBwbGljYWJsZSBsYXcgb3IgYWdyZWVkIHRvIGluIHdyaXRpbmcsXG4vLyBzb2Z0d2FyZSBkaXN0cmlidXRlZCB1bmRlciB0aGUgTGljZW5zZSBpcyBkaXN0cmlidXRlZCBvbiBhblxuLy8gXCJBUyBJU1wiIEJBU0lTLCBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTllcbi8vIEtJTkQsIGVpdGhlciBleHByZXNzIG9yIGltcGxpZWQuICBTZWUgdGhlIExpY2Vuc2UgZm9yIHRoZVxuLy8gc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zIGFuZCBsaW1pdGF0aW9uc1xuLy8gdW5kZXIgdGhlIExpY2Vuc2UuXG5cbmltcG9ydCB7IFZlY3RvciB9IGZyb20gJy4vdmVjdG9yJztcblxuZXhwb3J0IGNsYXNzIERpY3Rpb25hcnlWZWN0b3I8VD4gZXh0ZW5kcyBWZWN0b3I8VD4ge1xuICAgIHByb3RlY3RlZCBkYXRhOiBWZWN0b3I8VD47XG4gICAgcHJvdGVjdGVkIGtleXM6IFZlY3RvcjxudW1iZXI+O1xuICAgIGNvbnN0cnVjdG9yKGluZGV4OiBWZWN0b3I8bnVtYmVyPiwgZGljdGlvbmFyeTogVmVjdG9yPFQ+KSB7XG4gICAgICAgIHN1cGVyKCk7XG4gICAgICAgIHRoaXMua2V5cyA9IGluZGV4O1xuICAgICAgICB0aGlzLmRhdGEgPSBkaWN0aW9uYXJ5O1xuICAgICAgICB0aGlzLmxlbmd0aCA9IGluZGV4ICYmIGluZGV4Lmxlbmd0aCB8fCAwO1xuICAgIH1cbiAgICBpbmRleChpbmRleDogbnVtYmVyKSB7XG4gICAgICAgIHJldHVybiB0aGlzLmtleXMuZ2V0KGluZGV4KTtcbiAgICB9XG4gICAgdmFsdWUoaW5kZXg6IG51bWJlcikge1xuICAgICAgICByZXR1cm4gdGhpcy5kYXRhLmdldChpbmRleCk7XG4gICAgfVxuICAgIGdldChpbmRleDogbnVtYmVyKSB7XG4gICAgICAgIHJldHVybiB0aGlzLnZhbHVlKHRoaXMuaW5kZXgoaW5kZXgpKTtcbiAgICB9XG4gICAgY29uY2F0KHZlY3RvcjogRGljdGlvbmFyeVZlY3RvcjxUPikge1xuICAgICAgICByZXR1cm4gRGljdGlvbmFyeVZlY3Rvci5mcm9tKHRoaXMsXG4gICAgICAgICAgICB0aGlzLmxlbmd0aCArIHZlY3Rvci5sZW5ndGgsXG4gICAgICAgICAgICB0aGlzLmtleXMuY29uY2F0KHZlY3Rvci5rZXlzKSxcbiAgICAgICAgICAgIHRoaXMuZGF0YVxuICAgICAgICApO1xuICAgIH1cbiAgICAqW1N5bWJvbC5pdGVyYXRvcl0oKSB7XG4gICAgICAgIGxldCB7IGRhdGEgfSA9IHRoaXM7XG4gICAgICAgIGZvciAoY29uc3QgbG9jIG9mIHRoaXMua2V5cykge1xuICAgICAgICAgICAgeWllbGQgZGF0YS5nZXQobG9jKTtcbiAgICAgICAgfVxuICAgIH1cbn1cbiJdfQ== |
680352
8602