Comparing version 0.0.9 to 1.0.0
@@ -6,2 +6,3 @@ "use strict"; | ||
}); | ||
exports.default = void 0; | ||
var Helpers; | ||
@@ -13,2 +14,5 @@ | ||
exports.default = Helpers; | ||
var _default = Helpers; | ||
exports.default = _default; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhlbHBlcnMvaW5kZXguY29mZmVlIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLElBQUEsT0FBQTs7QUFBQSxPQUFBLEdBQVUsVUFBQSxHQUFBLEVBQUE7U0FBUyxFO0FBQVQsQ0FBVjs7ZUFFZSxPIiwic291cmNlc0NvbnRlbnQiOlsiSGVscGVycyA9IChBV1MpIC0+IHt9XG5cbmV4cG9ydCBkZWZhdWx0IEhlbHBlcnNcbiJdLCJzb3VyY2VSb290IjoiIn0= | ||
//# sourceURL=helpers/index.coffee |
@@ -6,18 +6,13 @@ "use strict"; | ||
}); | ||
exports.default = void 0; | ||
var _lifted = require("./lifted"); | ||
var _liftAll = _interopRequireDefault(require("./lift-all")); | ||
var _lifted2 = _interopRequireDefault(_lifted); | ||
var _primitives = _interopRequireDefault(require("./primitives")); | ||
var _primitives = require("./primitives"); | ||
var _primitives2 = _interopRequireDefault(_primitives); | ||
var _helpers = require("./helpers"); | ||
var _helpers2 = _interopRequireDefault(_helpers); | ||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | ||
//import Engine from "./engine" | ||
// Sundog | ||
// Base is a super thin wrapper around the AWS SDK, lifting each service module so you may use them with promises rather than callbacks. | ||
// Primatives is a slightly higher level wrapper - still promise based - to give the SDK a more functional flavor. | ||
var start; | ||
@@ -30,3 +25,3 @@ | ||
get: function () { | ||
return (0, _lifted2.default)(engine); | ||
return (0, _liftAll.default)(engine); | ||
} | ||
@@ -37,10 +32,4 @@ }, | ||
get: function () { | ||
return (0, _primitives2.default)(this._AWS); | ||
return (0, _primitives.default)(this._AWS); | ||
} | ||
}, | ||
Helpers: { | ||
enumerable: true, | ||
get: function () { | ||
return (0, _helpers2.default)(this.AWS); | ||
} | ||
} | ||
@@ -50,2 +39,5 @@ }); | ||
exports.default = start; | ||
var _default = start; | ||
exports.default = _default; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LmNvZmZlZSJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBSUE7O0FBQ0E7Ozs7QUFMQTs7O0FBQUEsSUFBQSxLQUFBOztBQU9BLEtBQUEsR0FBUSxVQUFBLE1BQUEsRUFBQTtTQUNOLE1BQU0sQ0FBTixnQkFBQSxDQUFBLEVBQUEsRUFDRTtBQUFBLElBQUEsSUFBQSxFQUNFO0FBQUEsTUFBQSxVQUFBLEVBQUEsSUFBQTtBQUNBLE1BQUEsR0FBQSxFQUFLLFlBQUE7ZUFBRyxzQkFBQSxNQUFBLEM7QUFBSDtBQURMLEtBREY7QUFHQSxJQUFBLEdBQUEsRUFDRTtBQUFBLE1BQUEsVUFBQSxFQUFBLElBQUE7QUFDQSxNQUFBLEdBQUEsRUFBSyxZQUFBO2VBQUcseUJBQVcsS0FBWCxJQUFBLEM7QUFBSDtBQURMO0FBSkYsR0FERixDO0FBRE0sQ0FBUjs7ZUFTZSxLIiwic291cmNlc0NvbnRlbnQiOlsiIyBTdW5kb2dcbiMgQmFzZSBpcyBhIHN1cGVyIHRoaW4gd3JhcHBlciBhcm91bmQgdGhlIEFXUyBTREssIGxpZnRpbmcgZWFjaCBzZXJ2aWNlIG1vZHVsZSBzbyB5b3UgbWF5IHVzZSB0aGVtIHdpdGggcHJvbWlzZXMgcmF0aGVyIHRoYW4gY2FsbGJhY2tzLlxuIyBQcmltYXRpdmVzIGlzIGEgc2xpZ2h0bHkgaGlnaGVyIGxldmVsIHdyYXBwZXIgLSBzdGlsbCBwcm9taXNlIGJhc2VkIC0gdG8gZ2l2ZSB0aGUgU0RLIGEgbW9yZSBmdW5jdGlvbmFsIGZsYXZvci5cblxuaW1wb3J0IEJhc2UgZnJvbSBcIi4vbGlmdC1hbGxcIlxuaW1wb3J0IFByaW1hdGl2ZXMgZnJvbSBcIi4vcHJpbWl0aXZlc1wiXG5cbnN0YXJ0ID0gKGVuZ2luZSkgLT5cbiAgT2JqZWN0LmRlZmluZVByb3BlcnRpZXMge30sXG4gICAgX0FXUzpcbiAgICAgIGVudW1lcmFibGU6IHRydWVcbiAgICAgIGdldDogLT4gQmFzZSBlbmdpbmVcbiAgICBBV1M6XG4gICAgICBlbnVtZXJhYmxlOiB0cnVlXG4gICAgICBnZXQ6IC0+IFByaW1hdGl2ZXMgQF9BV1NcblxuZXhwb3J0IGRlZmF1bHQgc3RhcnRcbiJdLCJzb3VyY2VSb290IjoiIn0= | ||
//# sourceURL=index.coffee |
@@ -6,138 +6,162 @@ "use strict"; | ||
}); | ||
exports.default = void 0; | ||
var _fairmont = require("fairmont"); | ||
var _pandaParchment = require("panda-parchment"); | ||
function _asyncToGenerator(fn) { return function () { var gen = fn.apply(this, arguments); return new Promise(function (resolve, reject) { function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { return Promise.resolve(value).then(function (value) { step("next", value); }, function (err) { step("throw", err); }); } } return step("next"); }); }; } | ||
var _pandaRiver = require("panda-river"); | ||
var _utils = require("./utils"); | ||
var _lift = require("../lift"); | ||
// Primitives for the service Cognito. The base entity is the "user". Methods that act on other entities, like pools or clients are prefixed as such. | ||
var cognitoPrimative; | ||
var cognitoPrimitive; | ||
cognitoPrimative = function (_AWS) { | ||
var clientGet, clientHead, clientList, cog, poolGet, poolHead, poolList; | ||
cog = _AWS.CognitoIdentityServiceProvider; | ||
poolList = (() => { | ||
var _ref = _asyncToGenerator(function* (current = [], token) { | ||
var NextToken, UserPools, params; | ||
params = { | ||
MaxResults: 60 | ||
}; | ||
if (token) { | ||
params.NextToken = token; | ||
} | ||
({ UserPools, NextToken } = yield cog.listUserPools(params)); | ||
current = (0, _fairmont.cat)(current, UserPools); | ||
if (NextToken) { | ||
return yield poolList(current, NextToken); | ||
} else { | ||
return current; | ||
} | ||
}); | ||
cognitoPrimitive = function (SDK) { | ||
var clientGet, clientHead, clientList, poolGet, poolHead, poolList; | ||
return function poolList() { | ||
return _ref.apply(this, arguments); | ||
}; | ||
})(); | ||
poolHead = (() => { | ||
var _ref2 = _asyncToGenerator(function* (name) { | ||
var pool; | ||
[pool] = (0, _fairmont.collect)((0, _fairmont.where)({ | ||
Name: name | ||
}, (yield poolList()))); | ||
if (pool) { | ||
return pool; | ||
} else { | ||
return false; | ||
} | ||
}); | ||
(function (configuration) { | ||
var cog; | ||
return cog = (0, _lift.applyConfiguration)(configuration, SDK.CognitoIdentityServiceProvider); | ||
}); | ||
return function poolHead(_x) { | ||
return _ref2.apply(this, arguments); | ||
poolList = async function (current = [], token) { | ||
var NextToken, UserPools, params; | ||
params = { | ||
MaxResults: 60 | ||
}; | ||
})(); | ||
poolGet = (() => { | ||
var _ref3 = _asyncToGenerator(function* (name) { | ||
var Id, UserPool; | ||
({ Id } = yield poolHead(name)); | ||
if (!Id) { | ||
return false; | ||
} else { | ||
({ UserPool } = yield cog.describeUserPool({ | ||
UserPoolId: Id | ||
})); | ||
return UserPool; | ||
} | ||
}); | ||
return function poolGet(_x2) { | ||
return _ref3.apply(this, arguments); | ||
}; | ||
})(); | ||
clientList = (() => { | ||
var _ref4 = _asyncToGenerator(function* (UserPoolId, current = [], token) { | ||
var NextToken, UserPoolClients, params; | ||
params = { | ||
UserPoolId, | ||
MaxResults: 60 | ||
}; | ||
if (token) { | ||
params.NextToken = token; | ||
} | ||
({ UserPoolClients, NextToken } = yield cog.listUserPoolClients(params)); | ||
current = (0, _fairmont.cat)(current, UserPoolClients); | ||
if (NextToken) { | ||
return yield clientList(UserPoolId, current, NextToken); | ||
} else { | ||
return current; | ||
} | ||
}); | ||
if (token) { | ||
params.NextToken = token; | ||
} | ||
return function clientList(_x3) { | ||
return _ref4.apply(this, arguments); | ||
({ | ||
UserPools, | ||
NextToken | ||
} = await cog.listUserPools(params)); | ||
current = (0, _pandaParchment.cat)(current, UserPools); | ||
if (NextToken) { | ||
return await poolList(current, NextToken); | ||
} else { | ||
return current; | ||
} | ||
}; | ||
poolHead = async function (name) { | ||
var pool; | ||
[pool] = (0, _pandaRiver.collect)((0, _utils.where)({ | ||
Name: name | ||
}, (await poolList()))); | ||
if (pool) { | ||
return pool; | ||
} else { | ||
return false; | ||
} | ||
}; | ||
poolGet = async function (name) { | ||
var Id, UserPool; | ||
({ | ||
Id | ||
} = await poolHead(name)); | ||
if (!Id) { | ||
return false; | ||
} else { | ||
({ | ||
UserPool | ||
} = await cog.describeUserPool({ | ||
UserPoolId: Id | ||
})); | ||
return UserPool; | ||
} | ||
}; | ||
clientList = async function (UserPoolId, current = [], token) { | ||
var NextToken, UserPoolClients, params; | ||
params = { | ||
UserPoolId, | ||
MaxResults: 60 | ||
}; | ||
})(); | ||
clientHead = (() => { | ||
var _ref5 = _asyncToGenerator(function* (UserPoolOverload, ClientName) { | ||
var Id, UserPoolName, client; | ||
if (ClientName) { | ||
Id = UserPoolOverload; | ||
} else { | ||
ClientName = UserPoolName = UserPoolOverload; | ||
({ Id } = yield poolHead(UserPoolName)); | ||
} | ||
if (!Id) { | ||
return false; | ||
} else { | ||
[client] = (0, _fairmont.collect)((0, _fairmont.where)({ ClientName }, (yield clientList(Id)))); | ||
if (client) { | ||
return client; | ||
} else { | ||
return false; | ||
} | ||
} | ||
}); | ||
return function clientHead(_x4, _x5) { | ||
return _ref5.apply(this, arguments); | ||
}; | ||
})(); | ||
clientGet = (() => { | ||
var _ref6 = _asyncToGenerator(function* (userPoolName, clientName) { | ||
var ClientId, UserPoolClient, UserPoolId; | ||
clientName || (clientName = userPoolName); | ||
({ UserPoolId, ClientId } = yield clientHead(userPoolName, clientName)); | ||
if (ClientId) { | ||
({ UserPoolClient } = yield cog.describeUserPoolClient({ UserPoolId, ClientId })); | ||
return UserPoolClient; | ||
if (token) { | ||
params.NextToken = token; | ||
} | ||
({ | ||
UserPoolClients, | ||
NextToken | ||
} = await cog.listUserPoolClients(params)); | ||
current = (0, _pandaParchment.cat)(current, UserPoolClients); | ||
if (NextToken) { | ||
return await clientList(UserPoolId, current, NextToken); | ||
} else { | ||
return current; | ||
} | ||
}; | ||
clientHead = async function (UserPoolOverload, ClientName) { | ||
var Id, UserPoolName, client; | ||
if (ClientName) { | ||
Id = UserPoolOverload; | ||
} else { | ||
ClientName = UserPoolName = UserPoolOverload; | ||
({ | ||
Id | ||
} = await poolHead(UserPoolName)); | ||
} | ||
if (!Id) { | ||
return false; | ||
} else { | ||
[client] = (0, _pandaRiver.collect)((0, _utils.where)({ | ||
ClientName | ||
}, (await clientList(Id)))); | ||
if (client) { | ||
return client; | ||
} else { | ||
return false; | ||
} | ||
}); | ||
} | ||
}; | ||
return function clientGet(_x6, _x7) { | ||
return _ref6.apply(this, arguments); | ||
}; | ||
})(); | ||
return { poolList, poolHead, poolGet, clientList, clientHead, clientGet }; | ||
clientGet = async function (userPoolName, clientName) { | ||
var ClientId, UserPoolClient, UserPoolId; | ||
clientName || (clientName = userPoolName); | ||
({ | ||
UserPoolId, | ||
ClientId | ||
} = await clientHead(userPoolName, clientName)); | ||
if (ClientId) { | ||
({ | ||
UserPoolClient | ||
} = await cog.describeUserPoolClient({ | ||
UserPoolId, | ||
ClientId | ||
})); | ||
return UserPoolClient; | ||
} else { | ||
return false; | ||
} | ||
}; | ||
return { | ||
poolList, | ||
poolHead, | ||
poolGet, | ||
clientList, | ||
clientHead, | ||
clientGet | ||
}; | ||
}; | ||
exports.default = cognitoPrimative; | ||
var _default = cognitoPrimitive; | ||
exports.default = _default; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInByaW1pdGl2ZXMvY29nbml0by5jb2ZmZWUiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUVBOztBQUNBOztBQUNBOztBQUNBOztBQUxBO0FBQUEsSUFBQSxnQkFBQTs7QUFPQSxnQkFBQSxHQUFtQixVQUFBLEdBQUEsRUFBQTtBQUNqQixNQUFBLFNBQUEsRUFBQSxVQUFBLEVBQUEsVUFBQSxFQUFBLE9BQUEsRUFBQSxRQUFBLEVBQUEsUUFBQTs7QUFBQSxHQUFBLFVBQUEsYUFBQSxFQUFBO0FBQ0UsUUFBQSxHQUFBO1dBQUEsR0FBQSxHQUFNLDhCQUFBLGFBQUEsRUFBa0MsR0FBRyxDQUFyQyw4QkFBQSxDO0FBRFIsR0FBQTs7QUFHQSxFQUFBLFFBQUEsR0FBVyxnQkFBQyxPQUFBLEdBQUQsRUFBQSxFQUFBLEtBQUEsRUFBQTtBQUNULFFBQUEsU0FBQSxFQUFBLFNBQUEsRUFBQSxNQUFBO0FBQUEsSUFBQSxNQUFBLEdBQVM7QUFBQSxNQUFBLFVBQUEsRUFBWTtBQUFaLEtBQVQ7O0FBQ0EsUUFBQSxLQUFBLEVBQUE7QUFBQSxNQUFBLE1BQU0sQ0FBTixTQUFBLEdBQUEsS0FBQTs7O0FBQ0EsS0FBQTtBQUFBLE1BQUEsU0FBQTtBQUFBLE1BQUE7QUFBQSxRQUF5QixNQUFNLEdBQUcsQ0FBSCxhQUFBLENBQS9CLE1BQStCLENBQS9CO0FBQ0EsSUFBQSxPQUFBLEdBQVUseUJBQUEsT0FBQSxFQUFBLFNBQUEsQ0FBVjs7QUFDQSxRQUFBLFNBQUEsRUFBQTtBQUNFLGFBQUEsTUFBTSxRQUFBLENBQUEsT0FBQSxFQURSLFNBQ1EsQ0FBTjtBQURGLEtBQUEsTUFBQTthQUFBLE87O0FBTFMsR0FBWDs7QUFVQSxFQUFBLFFBQUEsR0FBVyxnQkFBQSxJQUFBLEVBQUE7QUFDVCxRQUFBLElBQUE7QUFBQSxLQUFBLElBQUEsSUFBUyx5QkFBUSxrQkFBTTtBQUFBLE1BQUEsSUFBQSxFQUFNO0FBQU4sS0FBTixHQUFrQixNQUFNLFFBQWhDLEVBQVEsRUFBUixD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ZSBzZXJ2aWNlIENvZ25pdG8uICBUaGUgYmFzZSBlbnRpdHkgaXMgdGhlIFwidXNlclwiLiAgTWV0aG9kcyB0aGF0IGFjdCBvbiBvdGhlciBlbnRpdGllcywgbGlrZSBwb29scyBvciBjbGllbnRzIGFyZSBwcmVmaXhlZCBhcyBzdWNoLlxuXG5pbXBvcnQge2NhdH0gZnJvbSBcInBhbmRhLXBhcmNobWVudFwiXG5pbXBvcnQge2NvbGxlY3R9IGZyb20gXCJwYW5kYS1yaXZlclwiXG5pbXBvcnQge3doZXJlfSBmcm9tIFwiLi91dGlsc1wiXG5pbXBvcnQge2FwcGx5Q29uZmlndXJhdGlvbn0gZnJvbSBcIi4uL2xpZnRcIlxuXG5jb2duaXRvUHJpbWl0aXZlID0gKFNESykgLT5cbiAgKGNvbmZpZ3VyYXRpb24pIC0+XG4gICAgY29nID0gYXBwbHlDb25maWd1cmF0aW9uIGNvbmZpZ3VyYXRpb24sIFNESy5Db2duaXRvSWRlbnRpdHlTZXJ2aWNlUHJvdmlkZXJcblxuICBwb29sTGlzdCA9IChjdXJyZW50PVtdLCB0b2tlbikgLT5cbiAgICBwYXJhbXMgPSBNYXhSZXN1bHRzOiA2MFxuICAgIHBhcmFtcy5OZXh0VG9rZW4gPSB0b2tlbiBpZiB0b2tlblxuICAgIHtVc2VyUG9vbHMsIE5leHRUb2tlbn0gPSBhd2FpdCBjb2cubGlzdFVzZXJQb29scyBwYXJhbXNcbiAgICBjdXJyZW50ID0gY2F0IGN1cnJlbnQsIFVzZXJQb29sc1xuICAgIGlmIE5leHRUb2tlblxuICAgICAgYXdhaXQgcG9vbExpc3QgY3VycmVudCwgTmV4dFRva2VuXG4gICAgZWxzZVxuICAgICAgY3VycmVudFxuXG4gIHBvb2xIZWFkID0gKG5hbWUpIC0+XG4gICAgW3Bvb2xdID0gY29sbGVjdCB3aGVyZSBOYW1lOiBuYW1lLCBhd2FpdCBwb29sTGlzdCgpXG4gICAgaWYgcG9vbCB0aGVuIHBvb2wgZWxzZSBmYWxzZVxuXG4gIHBvb2xHZXQgPSAobmFtZSkgLT5cbiAgICB7SWR9ID0gYXdhaXQgcG9vbEhlYWQgbmFtZVxuICAgIGlmICFJZFxuICAgICAgcmV0dXJuIGZhbHNlXG4gICAgZWxzZVxuICAgICAge1VzZXJQb29sfSA9IGF3YWl0IGNvZy5kZXNjcmliZVVzZXJQb29sIFVzZXJQb29sSWQ6IElkXG4gICAgICBVc2VyUG9vbFxuXG4gIGNsaWVudExpc3QgPSAoVXNlclBvb2xJZCwgY3VycmVudD1bXSwgdG9rZW4pIC0+XG4gICAgcGFyYW1zID0ge1xuICAgICAgVXNlclBvb2xJZFxuICAgICAgTWF4UmVzdWx0czogNjBcbiAgICB9XG4gICAgcGFyYW1zLk5leHRUb2tlbiA9IHRva2VuIGlmIHRva2VuXG4gICAge1VzZXJQb29sQ2xpZW50cywgTmV4dFRva2VufSA9IGF3YWl0IGNvZy5saXN0VXNlclBvb2xDbGllbnRzIHBhcmFtc1xuICAgIGN1cnJlbnQgPSBjYXQgY3VycmVudCwgVXNlclBvb2xDbGllbnRzXG4gICAgaWYgTmV4dFRva2VuXG4gICAgICBhd2FpdCBjbGllbnRMaXN0IFVzZXJQb29sSWQsIGN1cnJlbnQsIE5leHRUb2tlblxuICAgIGVsc2VcbiAgICAgIGN1cnJlbnRcblxuICBjbGllbnRIZWFkID0gKFVzZXJQb29sT3ZlcmxvYWQsIENsaWVudE5hbWUpIC0+XG4gICAgaWYgQ2xpZW50TmFtZVxuICAgICAgSWQgPSBVc2VyUG9vbE92ZXJsb2FkXG4gICAgZWxzZVxuICAgICAgQ2xpZW50TmFtZSA9IFVzZXJQb29sTmFtZSA9IFVzZXJQb29sT3ZlcmxvYWRcbiAgICAgIHtJZH0gPSBhd2FpdCBwb29sSGVhZCBVc2VyUG9vbE5hbWVcblxuICAgIGlmICFJZFxuICAgICAgcmV0dXJuIGZhbHNlXG4gICAgZWxzZVxuICAgICAgW2NsaWVudF0gPSBjb2xsZWN0IHdoZXJlIHtDbGllbnROYW1lfSwgYXdhaXQgY2xpZW50TGlzdChJZClcbiAgICAgIGlmIGNsaWVudCB0aGVuIGNsaWVudCBlbHNlIGZhbHNlXG5cbiAgY2xpZW50R2V0ID0gKHVzZXJQb29sTmFtZSwgY2xpZW50TmFtZSkgLT5cbiAgICBjbGllbnROYW1lIHx8PSB1c2VyUG9vbE5hbWVcbiAgICB7VXNlclBvb2xJZCwgQ2xpZW50SWR9ID0gYXdhaXQgY2xpZW50SGVhZCB1c2VyUG9vbE5hbWUsIGNsaWVudE5hbWVcbiAgICBpZiBDbGllbnRJZFxuICAgICAge1VzZXJQb29sQ2xpZW50fSA9IGF3YWl0IGNvZy5kZXNjcmliZVVzZXJQb29sQ2xpZW50IHtVc2VyUG9vbElkLCBDbGllbnRJZH1cbiAgICAgIFVzZXJQb29sQ2xpZW50XG4gICAgZWxzZVxuICAgICAgZmFsc2VcblxuXG4gIHtwb29sTGlzdCwgcG9vbEhlYWQsIHBvb2xHZXQsIGNsaWVudExpc3QsIGNsaWVudEhlYWQsIGNsaWVudEdldH1cblxuXG5leHBvcnQgZGVmYXVsdCBjb2duaXRvUHJpbWl0aXZlXG4iXSwic291cmNlUm9vdCI6IiJ9 | ||
//# sourceURL=primitives/cognito.coffee |
@@ -6,8 +6,15 @@ "use strict"; | ||
}); | ||
exports.default = void 0; | ||
var _fairmont = require("fairmont"); | ||
var _pandaGarden = require("panda-garden"); | ||
var _pandaParchment = require("panda-parchment"); | ||
var _pandaGenerics = require("panda-generics"); | ||
var _pandaRiver = require("panda-river"); | ||
var _utils = require("./utils"); | ||
function _asyncToGenerator(fn) { return function () { var gen = fn.apply(this, arguments); return new Promise(function (resolve, reject) { function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { return Promise.resolve(value).then(function (value) { step("next", value); }, function (err) { step("throw", err); }); } } return step("next"); }); }; } | ||
var _lift = require("../lift"); | ||
@@ -18,18 +25,20 @@ // Primitives for the service DynamoDB. | ||
// prefixed "table*", whereas item methods will have no prefix. | ||
var dynamodbPrimative, | ||
var dynamodbPrimitive, | ||
indexOf = [].indexOf; | ||
dynamodbPrimative = function (_AWS) { | ||
var _areIndexesReady, _catCurrent, _delimiter, _isTableReady, _mark, _parseConditional, _parseName, _parseQuery, _qv, _setupCurrent, _transform, db, del, get, keysFilter, parse, put, query, qv, scan, tableCreate, tableDel, tableEmpty, tableGet, tableUpdate, tableWaitForDeleted, tableWaitForReady, to, update; | ||
({ | ||
DynamoDB: db | ||
} = _AWS); | ||
//=========================================================================== | ||
// Tables | ||
//=========================================================================== | ||
tableGet = (() => { | ||
var _ref = _asyncToGenerator(function* (name) { | ||
dynamodbPrimitive = function (SDK) { | ||
return function (configuration) { | ||
var _areIndexesReady, _catCurrent, _delimiter, _isTableReady, _mark, _parseConditional, _parseName, _parseQuery, _qv, _setupCurrent, _transform, db, del, get, keysFilter, parse, put, query, qv, scan, tableCreate, tableDel, tableEmpty, tableGet, tableUpdate, tableWaitForDeleted, tableWaitForReady, to, update; | ||
db = (0, _lift.applyConfiguration)(configuration, SDK.DynamoDB); //=========================================================================== | ||
// Tables | ||
//=========================================================================== | ||
tableGet = async function (name) { | ||
var Table, e; | ||
try { | ||
({ Table } = yield db.describeTable({ | ||
({ | ||
Table | ||
} = await db.describeTable({ | ||
TableName: name | ||
@@ -42,10 +51,5 @@ })); | ||
} | ||
}); | ||
}; | ||
return function tableGet(_x) { | ||
return _ref.apply(this, arguments); | ||
}; | ||
})(); | ||
tableCreate = (() => { | ||
var _ref2 = _asyncToGenerator(function* (name, keys, attributes, throughput, options = {}) { | ||
tableCreate = async function (name, keys, attributes, throughput, options = {}) { | ||
var TableDescription, p; | ||
@@ -58,12 +62,9 @@ p = { | ||
}; | ||
({ TableDescription } = yield db.createTable((0, _fairmont.merge)(p, options))); | ||
({ | ||
TableDescription | ||
} = await db.createTable((0, _pandaParchment.merge)(p, options))); | ||
return TableDescription; | ||
}); | ||
}; | ||
return function tableCreate(_x2, _x3, _x4, _x5) { | ||
return _ref2.apply(this, arguments); | ||
}; | ||
})(); | ||
tableUpdate = (() => { | ||
var _ref3 = _asyncToGenerator(function* (name, attributes, throughput, options = {}) { | ||
tableUpdate = async function (name, attributes, throughput, options = {}) { | ||
var TableDescription, p; | ||
@@ -74,18 +75,18 @@ p = { | ||
}; | ||
if (throughput) { | ||
p.ProvisionedThroughput = throughput; | ||
} | ||
({ TableDescription } = yield db.updateTable((0, _fairmont.merge)(p, options))); | ||
({ | ||
TableDescription | ||
} = await db.updateTable((0, _pandaParchment.merge)(p, options))); | ||
return TableDescription; | ||
}); | ||
}; | ||
return function tableUpdate(_x6, _x7, _x8) { | ||
return _ref3.apply(this, arguments); | ||
}; | ||
})(); | ||
tableDel = (() => { | ||
var _ref4 = _asyncToGenerator(function* (name) { | ||
tableDel = async function (name) { | ||
var e; | ||
try { | ||
return yield db.deleteTable({ | ||
return await db.deleteTable({ | ||
TableName: name | ||
@@ -97,17 +98,16 @@ }); | ||
} | ||
}); | ||
}; | ||
return function tableDel(_x9) { | ||
return _ref4.apply(this, arguments); | ||
}; | ||
})(); | ||
_isTableReady = (() => { | ||
var _ref5 = _asyncToGenerator(function* (name) { | ||
_isTableReady = async function (name) { | ||
var TableStatus; | ||
while (true) { | ||
({ TableStatus } = yield tableGet(name)); | ||
({ | ||
TableStatus | ||
} = await tableGet(name)); | ||
if (!TableStatus) { | ||
throw new Error(`Cannot find table ${name}`); | ||
} else if (TableStatus !== "ACTIVE") { | ||
yield (0, _fairmont.sleep)(5000); | ||
await (0, _pandaParchment.sleep)(5000); | ||
} else { | ||
@@ -117,252 +117,277 @@ return true; | ||
} | ||
}); | ||
}; | ||
return function _isTableReady(_x10) { | ||
return _ref5.apply(this, arguments); | ||
}; | ||
})(); | ||
_areIndexesReady = (() => { | ||
var _ref6 = _asyncToGenerator(function* (name) { | ||
_areIndexesReady = async function (name) { | ||
var indexes, statuses; | ||
while (true) { | ||
({ | ||
GlobalSecondaryIndexes: indexes | ||
} = yield tableGet(name)); | ||
} = await tableGet(name)); | ||
if (!indexes) { | ||
return true; | ||
} | ||
statuses = (0, _fairmont.collect)((0, _fairmont.project)("IndexStatus", indexes)); | ||
if ((0, _fairmont.empty)((0, _fairmont.difference)(statuses, ["ACTIVE"]))) { | ||
statuses = (0, _pandaRiver.collect)((0, _pandaRiver.project)("IndexStatus", indexes)); | ||
if ((0, _pandaParchment.empty)((0, _pandaParchment.difference)(statuses, ["ACTIVE"]))) { | ||
return true; | ||
} else { | ||
yield (0, _fairmont.sleep)(5000); | ||
await (0, _pandaParchment.sleep)(5000); | ||
} | ||
} | ||
}); | ||
}; // The optional second parameter allows the developer to also wait on all global secondary indexes to also be ready. | ||
return function _areIndexesReady(_x11) { | ||
return _ref6.apply(this, arguments); | ||
}; | ||
})(); | ||
// The optional second parameter allows the developer to also wait on all global secondary indexes to also be ready. | ||
tableWaitForReady = (() => { | ||
var _ref7 = _asyncToGenerator(function* (name, indexWait) { | ||
tableWaitForReady = async function (name, indexWait) { | ||
var checks; | ||
checks = [_isTableReady(name)]; | ||
if (indexWait) { | ||
checks.push(_areIndexesReady(name)); | ||
} | ||
return yield Promise.all(checks); | ||
}); | ||
return function tableWaitForReady(_x12, _x13) { | ||
return _ref7.apply(this, arguments); | ||
return await Promise.all(checks); | ||
}; | ||
})(); | ||
tableWaitForDeleted = (() => { | ||
var _ref8 = _asyncToGenerator(function* (name) { | ||
tableWaitForDeleted = async function (name) { | ||
var TableStatus; | ||
while (true) { | ||
({ TableStatus } = yield tableGet(name)); | ||
({ | ||
TableStatus | ||
} = await tableGet(name)); | ||
if (!TableStatus) { | ||
return true; | ||
} else { | ||
yield (0, _fairmont.sleep)(5000); | ||
await (0, _pandaParchment.sleep)(5000); | ||
} | ||
} | ||
}; // TODO: make this more efficient by throttling to X connections at once. AWS | ||
// only supports N requests per second from an account, and I don't want this | ||
// to violate that limit, but we can do better than one at a time. | ||
keysFilter = (0, _pandaGarden.curry)(function (keys, item) { | ||
var f; | ||
f = function (key) { | ||
return indexOf.call(keys, key) >= 0; | ||
}; | ||
return (0, _pandaParchment.pick)(f, item); | ||
}); | ||
return function tableWaitForDeleted(_x14) { | ||
return _ref8.apply(this, arguments); | ||
}; | ||
})(); | ||
// TODO: make this more efficient by throttling to X connections at once. AWS | ||
// only supports N requests per second from an account, and I don't want this | ||
// to violate that limit, but we can do better than one at a time. | ||
keysFilter = (0, _fairmont.curry)(function (keys, item) { | ||
var f; | ||
f = function (key) { | ||
return indexOf.call(keys, key) >= 0; | ||
}; | ||
return (0, _fairmont.pick)(f, item); | ||
}); | ||
tableEmpty = (() => { | ||
var _ref9 = _asyncToGenerator(function* (name) { | ||
tableEmpty = async function (name) { | ||
var Items, KeySchema, filter, i, j, len, results1; | ||
({ KeySchema } = yield tableGet(name)); | ||
filter = keysFilter((0, _fairmont.collect)((0, _fairmont.project)("AttributeName", KeySchema))); | ||
({ Items } = yield scan(name)); | ||
({ | ||
KeySchema | ||
} = await tableGet(name)); | ||
filter = keysFilter((0, _pandaRiver.collect)((0, _pandaRiver.project)("AttributeName", KeySchema))); | ||
({ | ||
Items | ||
} = await scan(name)); | ||
results1 = []; | ||
for (j = 0, len = Items.length; j < len; j++) { | ||
i = Items[j]; | ||
results1.push((yield del(name, filter(i)))); | ||
results1.push((await del(name, filter(i)))); | ||
} | ||
return results1; | ||
}); | ||
}; //=========================================================================== | ||
// Type Helpers | ||
//=========================================================================== | ||
// DynamoDB includes type information mapped into its data strctures. | ||
// It expects data to be input that way, and includes it when fetched. | ||
// These helpers write and parse that type system. | ||
return function tableEmpty(_x15) { | ||
return _ref9.apply(this, arguments); | ||
}; | ||
})(); | ||
//=========================================================================== | ||
// Type Helpers | ||
//=========================================================================== | ||
// DynamoDB includes type information mapped into its data strctures. | ||
// It expects data to be input that way, and includes it when fetched. | ||
// These helpers write and parse that type system. | ||
_transform = function (f) { | ||
return function (x) { | ||
var k, out, v; | ||
if ((0, _fairmont.isObject)(x)) { | ||
out = {}; | ||
for (k in x) { | ||
v = x[k]; | ||
out[k] = _mark("anyonymousDynamodbValue", f(v)); | ||
_transform = function (f) { | ||
return function (x) { | ||
var k, out, v; | ||
if ((0, _pandaParchment.isObject)(x)) { | ||
out = {}; | ||
for (k in x) { | ||
v = x[k]; | ||
out[k] = _mark("anyonymousDynamodbValue", f(v)); | ||
} | ||
return _mark("namedDynamodbValue", out); | ||
} else { | ||
return _mark("anyonymousDynamodbValue", f(x)); | ||
} | ||
return _mark("namedDynamodbValue", out); | ||
} else { | ||
return _mark("anyonymousDynamodbValue", f(x)); | ||
} | ||
}; | ||
}; | ||
}; | ||
_mark = function (name, object) { | ||
return Object.defineProperty(object, "name", { | ||
value: name | ||
}); | ||
}; | ||
to = { | ||
S: _transform(function (s) { | ||
return { | ||
S: s.toString() | ||
}; | ||
}), | ||
N: _transform(function (n) { | ||
return { | ||
N: n.toString() | ||
}; | ||
}), | ||
B: _transform(function (b) { | ||
return { | ||
B: b.toString("base64") | ||
}; | ||
}), | ||
SS: _transform(function (a) { | ||
var i; | ||
return { | ||
SS: function () { | ||
var j, len, results1; | ||
results1 = []; | ||
for (j = 0, len = a.length; j < len; j++) { | ||
i = a[j]; | ||
results1.push(i.toString()); | ||
} | ||
return results1; | ||
}() | ||
}; | ||
}), | ||
NS: _transform(function (a) { | ||
var i; | ||
return { | ||
NS: function () { | ||
var j, len, results1; | ||
results1 = []; | ||
for (j = 0, len = a.length; j < len; j++) { | ||
i = a[j]; | ||
results1.push(i.toString()); | ||
} | ||
return results1; | ||
}() | ||
}; | ||
}), | ||
BS: _transform(function (a) { | ||
var i; | ||
return { | ||
BS: function () { | ||
var j, len, results1; | ||
results1 = []; | ||
for (j = 0, len = a.length; j < len; j++) { | ||
i = a[j]; | ||
results1.push(i.toString("base64")); | ||
} | ||
return results1; | ||
}() | ||
}; | ||
}), | ||
M: _transform(function (m) { | ||
return { | ||
M: m | ||
}; | ||
}), | ||
L: _transform(function (l) { | ||
return { | ||
L: l | ||
}; | ||
}), | ||
Null: _transform(function (n) { | ||
return { | ||
NULL: n | ||
}; | ||
}), | ||
Bool: _transform(function (b) { | ||
return { | ||
BOOL: b | ||
}; | ||
}) | ||
}; | ||
parse = function (attributes) { | ||
var dataType, i, name, result, typeObj, v; | ||
result = {}; | ||
for (name in attributes) { | ||
typeObj = attributes[name]; | ||
dataType = (0, _fairmont.first)((0, _fairmont.keys)(typeObj)); | ||
v = (0, _fairmont.first)((0, _fairmont.values)(typeObj)); | ||
result[name] = function () { | ||
var j, len, len1, q, results1, results2; | ||
switch (dataType) { | ||
case "S": | ||
case "SS": | ||
case "L": | ||
case "BOOL": | ||
return v; | ||
case "N": | ||
return new Number(v); | ||
case "B": | ||
return Buffer.from(v, "base64"); | ||
case "NS": | ||
_mark = function (name, object) { | ||
return Object.defineProperty(object, "name", { | ||
value: name | ||
}); | ||
}; | ||
to = { | ||
S: _transform(function (s) { | ||
return { | ||
S: s.toString() | ||
}; | ||
}), | ||
N: _transform(function (n) { | ||
return { | ||
N: n.toString() | ||
}; | ||
}), | ||
B: _transform(function (b) { | ||
return { | ||
B: b.toString("base64") | ||
}; | ||
}), | ||
SS: _transform(function (a) { | ||
var i; | ||
return { | ||
SS: function () { | ||
var j, len, results1; | ||
results1 = []; | ||
for (j = 0, len = v.length; j < len; j++) { | ||
i = v[j]; | ||
results1.push(new Number(i)); | ||
for (j = 0, len = a.length; j < len; j++) { | ||
i = a[j]; | ||
results1.push(i.toString()); | ||
} | ||
return results1; | ||
case "BS": | ||
results2 = []; | ||
for (q = 0, len1 = v.length; q < len1; q++) { | ||
i = v[q]; | ||
results2.push(Buffer.from(i, "base64")); | ||
}() | ||
}; | ||
}), | ||
NS: _transform(function (a) { | ||
var i; | ||
return { | ||
NS: function () { | ||
var j, len, results1; | ||
results1 = []; | ||
for (j = 0, len = a.length; j < len; j++) { | ||
i = a[j]; | ||
results1.push(i.toString()); | ||
} | ||
return results2; | ||
case "NULL": | ||
if (v) { | ||
return null; | ||
} else { | ||
return void 0; | ||
return results1; | ||
}() | ||
}; | ||
}), | ||
BS: _transform(function (a) { | ||
var i; | ||
return { | ||
BS: function () { | ||
var j, len, results1; | ||
results1 = []; | ||
for (j = 0, len = a.length; j < len; j++) { | ||
i = a[j]; | ||
results1.push(i.toString("base64")); | ||
} | ||
break; | ||
case "M": | ||
return parse(v); | ||
default: | ||
throw new Error(`Unable to parse object for DynamoDB attribute type. ${dataType}`); | ||
} | ||
}(); | ||
} | ||
return result; | ||
}; | ||
//=========================================================================== | ||
// Items | ||
//=========================================================================== | ||
get = (() => { | ||
var _ref10 = _asyncToGenerator(function* (name, key, options = {}) { | ||
return results1; | ||
}() | ||
}; | ||
}), | ||
M: _transform(function (m) { | ||
return { | ||
M: m | ||
}; | ||
}), | ||
L: _transform(function (l) { | ||
return { | ||
L: l | ||
}; | ||
}), | ||
Null: _transform(function (n) { | ||
return { | ||
NULL: n | ||
}; | ||
}), | ||
Bool: _transform(function (b) { | ||
return { | ||
BOOL: b | ||
}; | ||
}) | ||
}; | ||
parse = function (attributes) { | ||
var dataType, i, name, result, typeObj, v; | ||
result = {}; | ||
for (name in attributes) { | ||
typeObj = attributes[name]; | ||
dataType = (0, _pandaParchment.first)((0, _pandaParchment.keys)(typeObj)); | ||
v = (0, _pandaParchment.first)((0, _pandaParchment.values)(typeObj)); | ||
result[name] = function () { | ||
var j, len, len1, q, results1, results2; | ||
switch (dataType) { | ||
case "S": | ||
case "SS": | ||
case "L": | ||
case "BOOL": | ||
return v; | ||
case "N": | ||
return new Number(v); | ||
case "B": | ||
return Buffer.from(v, "base64"); | ||
case "NS": | ||
results1 = []; | ||
for (j = 0, len = v.length; j < len; j++) { | ||
i = v[j]; | ||
results1.push(new Number(i)); | ||
} | ||
return results1; | ||
case "BS": | ||
results2 = []; | ||
for (q = 0, len1 = v.length; q < len1; q++) { | ||
i = v[q]; | ||
results2.push(Buffer.from(i, "base64")); | ||
} | ||
return results2; | ||
case "NULL": | ||
if (v) { | ||
return null; | ||
} else { | ||
return void 0; | ||
} | ||
break; | ||
case "M": | ||
return parse(v); | ||
default: | ||
throw new Error(`Unable to parse object for DynamoDB attribute type. ${dataType}`); | ||
} | ||
}(); | ||
} | ||
return result; | ||
}; //=========================================================================== | ||
// Items | ||
//=========================================================================== | ||
get = async function (name, key, options = {}) { | ||
var ConsumedCapacity, Item, ReturnConsumedCapacity, p; | ||
({ ReturnConsumedCapacity } = options); | ||
({ | ||
ReturnConsumedCapacity | ||
} = options); | ||
p = { | ||
@@ -372,16 +397,18 @@ TableName: name, | ||
}; | ||
({ Item, ConsumedCapacity } = yield db.getItem((0, _fairmont.merge)(p, options))); | ||
({ | ||
Item, | ||
ConsumedCapacity | ||
} = await db.getItem((0, _pandaParchment.merge)(p, options))); | ||
if (ReturnConsumedCapacity) { | ||
return { Item, ConsumedCapacity }; | ||
return { | ||
Item, | ||
ConsumedCapacity | ||
}; | ||
} else { | ||
return Item; | ||
} | ||
}); | ||
}; | ||
return function get(_x16, _x17) { | ||
return _ref10.apply(this, arguments); | ||
}; | ||
})(); | ||
put = (() => { | ||
var _ref11 = _asyncToGenerator(function* (name, item, options = {}) { | ||
put = async function (name, item, options = {}) { | ||
var p; | ||
@@ -392,11 +419,6 @@ p = { | ||
}; | ||
return yield db.putItem((0, _fairmont.merge)(p, options)); | ||
}); | ||
return await db.putItem((0, _pandaParchment.merge)(p, options)); | ||
}; | ||
return function put(_x18, _x19) { | ||
return _ref11.apply(this, arguments); | ||
}; | ||
})(); | ||
del = (() => { | ||
var _ref12 = _asyncToGenerator(function* (name, key, options = {}) { | ||
del = async function (name, key, options = {}) { | ||
var p; | ||
@@ -407,132 +429,161 @@ p = { | ||
}; | ||
return yield db.deleteItem((0, _fairmont.merge)(p, options)); | ||
}); | ||
return await db.deleteItem((0, _pandaParchment.merge)(p, options)); | ||
}; //=========================================================================== | ||
// Queries and Scans against Tables and Indexes | ||
//=========================================================================== | ||
return function del(_x20, _x21) { | ||
return _ref12.apply(this, arguments); | ||
_delimiter = "<###SUNDOGDYNAMODB###>"; | ||
_setupCurrent = function () { | ||
return { | ||
Items: [], | ||
Count: 0, | ||
ScannedCount: 0, | ||
LastEvaluatedKey: false, | ||
ConsumedCapacity: [] | ||
}; | ||
}; | ||
})(); | ||
//=========================================================================== | ||
// Queries and Scans against Tables and Indexes | ||
//=========================================================================== | ||
_delimiter = "<###SUNDOGDYNAMODB###>"; | ||
_setupCurrent = function () { | ||
return { | ||
Items: [], | ||
Count: 0, | ||
ScannedCount: 0, | ||
LastEvaluatedKey: false, | ||
ConsumedCapacity: [] | ||
_catCurrent = function (current, results) { | ||
var ConsumedCapacity, Count, Items, LastEvaluatedKey, ScannedCount; | ||
({ | ||
Items, | ||
Count, | ||
ScannedCount, | ||
LastEvaluatedKey, | ||
ConsumedCapacity | ||
} = results); | ||
current.Items = (0, _pandaParchment.cat)(current.Items, Items); | ||
current.Count += Count; | ||
current.ScannedCount += ScannedCount; | ||
if (LastEvaluatedKey) { | ||
current.LastEvaluatedKey = LastEvaluatedKey; | ||
} | ||
current.ConsumedCapacity = current.ConsumedCapacity.push(ConsumedCapacity); | ||
return current; | ||
}; | ||
}; | ||
_catCurrent = function (current, results) { | ||
var ConsumedCapacity, Count, Items, LastEvaluatedKey, ScannedCount; | ||
({ Items, Count, ScannedCount, LastEvaluatedKey, ConsumedCapacity } = results); | ||
current.Items = (0, _fairmont.cat)(current.Items, Items); | ||
current.Count += Count; | ||
current.ScannedCount += ScannedCount; | ||
if (LastEvaluatedKey) { | ||
current.LastEvaluatedKey = LastEvaluatedKey; | ||
} | ||
current.ConsumedCapacity = current.ConsumedCapacity.push(ConsumedCapacity); | ||
return current; | ||
}; | ||
_parseName = function (name) { | ||
var parts; | ||
if (!name) { | ||
throw new Error("Must provide table name."); | ||
} | ||
parts = name.split(":"); | ||
if (parts.length > 1) { | ||
_parseName = function (name) { | ||
var parts; | ||
if (!name) { | ||
throw new Error("Must provide table name."); | ||
} | ||
parts = name.split(":"); | ||
if (parts.length > 1) { | ||
return { | ||
tableName: parts[0], | ||
indexName: parts[1] | ||
}; | ||
} else { | ||
return { | ||
tableName: name, | ||
indexName: false | ||
}; | ||
} | ||
}; | ||
_parseConditional = function (ex, count = 0) { | ||
var Values, re, result; | ||
if (!ex) { | ||
return { | ||
result: false, | ||
values: false, | ||
count | ||
}; | ||
} | ||
Values = {}; | ||
re = new RegExp(`${_delimiter}.+?${_delimiter}`, "g"); | ||
result = ex.replace(re, function (match) { | ||
var obj, placeholder; | ||
[, obj] = match.split(_delimiter); | ||
placeholder = `:param${count}`; | ||
count++; | ||
Values[placeholder] = JSON.parse(obj); | ||
return placeholder; // Return placeholder to the expression we are processing. | ||
}); | ||
return { | ||
tableName: parts[0], | ||
indexName: parts[1] | ||
result, | ||
values: Values, | ||
count | ||
}; | ||
} else { | ||
return { | ||
tableName: name, | ||
indexName: false | ||
}; | ||
} | ||
}; | ||
_parseConditional = function (ex, count = 0) { | ||
var Values, re, result; | ||
if (!ex) { | ||
return { | ||
result: false, | ||
values: false, | ||
}; | ||
_parseQuery = function (options, name, keyEx, filterEx) { | ||
var count, filter, filterValues, indexName, key, keyValues, out, tableName; | ||
({ | ||
tableName, | ||
indexName | ||
} = _parseName(name)); | ||
({ | ||
result: key, | ||
values: keyValues, | ||
count | ||
} = _parseConditional(keyEx)); | ||
({ | ||
result: filter, | ||
values: filterValues | ||
} = _parseConditional(filterEx, count)); | ||
out = options; | ||
out.TableName = tableName; | ||
if (indexName) { | ||
out.IndexName = indexName; | ||
} | ||
if (key) { | ||
out.KeyConditionExpression = key; | ||
} | ||
if (filter) { | ||
out.FilterExpression = filter; | ||
} | ||
if (keyValues || filterValues) { | ||
out.ExpressionAttributeValues = (0, _pandaParchment.merge)(keyValues || {}, filterValues || {}); | ||
} | ||
return out; | ||
}; // qv produces query strings with delimited values SunDog can parse. | ||
_qv = function (o) { | ||
var delimit; | ||
delimit = function (s) { | ||
return `${_delimiter}${s}${_delimiter}`; | ||
}; // Determine if this is a DynamoDB value, and whether is anyonymous or named. | ||
if (o.name === "anyonymousDynamodbValue") { | ||
return delimit(JSON.stringify(o)); | ||
} else if (o.name === "namedDynamodbValue") { | ||
return delimit(JSON.stringify((0, _pandaParchment.first)((0, _pandaParchment.values)(o)))); | ||
} else { | ||
throw new Error(`Unable to create stringified query value for unrecongied object ${JSON.stringify(o)}`); | ||
} | ||
}; | ||
qv = _pandaGenerics.Method.create(); | ||
_pandaGenerics.Method.define(qv, _pandaParchment.isFunction, function (f) { | ||
return function (x) { | ||
return _qv(f(x)); | ||
}; | ||
} | ||
Values = {}; | ||
re = new RegExp(`${_delimiter}.+?${_delimiter}`, "g"); | ||
result = ex.replace(re, function (match) { | ||
var obj, placeholder; | ||
[, obj] = match.split(_delimiter); | ||
placeholder = `:param${count}`; | ||
count++; | ||
Values[placeholder] = JSON.parse(obj); | ||
return placeholder; // Return placeholder to the expression we are processing. | ||
}); | ||
return { | ||
result, | ||
values: Values, | ||
count | ||
}; | ||
}; | ||
_parseQuery = function (options, name, keyEx, filterEx) { | ||
var count, filter, filterValues, indexName, key, keyValues, out, tableName; | ||
({ tableName, indexName } = _parseName(name)); | ||
({ | ||
result: key, | ||
values: keyValues, | ||
count | ||
} = _parseConditional(keyEx)); | ||
({ | ||
result: filter, | ||
values: filterValues | ||
} = _parseConditional(filterEx, count)); | ||
out = options; | ||
out.TableName = tableName; | ||
if (indexName) { | ||
out.IndexName = indexName; | ||
} | ||
if (key) { | ||
out.KeyConditionExpression = key; | ||
} | ||
if (filter) { | ||
out.FilterExpression = filter; | ||
} | ||
if (keyValues || filterValues) { | ||
out.ExpressionAttributeValues = (0, _fairmont.merge)(keyValues || {}, filterValues || {}); | ||
} | ||
return out; | ||
}; | ||
// qv produces query strings with delimited values SunDog can parse. | ||
_qv = function (o) { | ||
var delimit; | ||
delimit = function (s) { | ||
return `${_delimiter}${s}${_delimiter}`; | ||
}; | ||
// Determine if this is a DynamoDB value, and whether is anyonymous or named. | ||
if (o.name === "anyonymousDynamodbValue") { | ||
return delimit(JSON.stringify(o)); | ||
} else if (o.name === "namedDynamodbValue") { | ||
return delimit(JSON.stringify((0, _fairmont.first)((0, _fairmont.values)(o)))); | ||
} else { | ||
throw new Error(`Unable to create stringified query value for unrecongied object ${JSON.stringify(o)}`); | ||
} | ||
}; | ||
qv = _fairmont.Method.create(); | ||
_fairmont.Method.define(qv, _fairmont.isFunction, function (f) { | ||
return function (x) { | ||
return _qv(f(x)); | ||
}; | ||
}); | ||
_fairmont.Method.define(qv, _fairmont.isObject, function (o) { | ||
return _qv(o); | ||
}); | ||
update = (() => { | ||
var _ref13 = _asyncToGenerator(function* (name, key, updateEx, options = {}) { | ||
var p, result; | ||
_pandaGenerics.Method.define(qv, _pandaParchment.isObject, function (o) { | ||
return _qv(o); | ||
}); | ||
update = async function (name, key, updateEx, options = {}) { | ||
var _values, p, result; | ||
p = { | ||
@@ -542,75 +593,106 @@ TableName: name, | ||
}; | ||
({ result, values: _fairmont.values } = _parseConditional(updateEx)); | ||
({ | ||
result, | ||
values: _values | ||
} = _parseConditional(updateEx)); | ||
if (result) { | ||
options.UpdateExpression = result; | ||
} | ||
if (_fairmont.values) { | ||
options.ExpressionAttributeValues = _fairmont.values; | ||
if (_values) { | ||
options.ExpressionAttributeValues = _values; | ||
} | ||
return yield db.updateItem((0, _fairmont.merge)(p, options)); | ||
}); | ||
return function update(_x22, _x23, _x24) { | ||
return _ref13.apply(this, arguments); | ||
return await db.updateItem((0, _pandaParchment.merge)(p, options)); | ||
}; | ||
})(); | ||
query = (() => { | ||
var _ref14 = _asyncToGenerator(function* (name, keyEx, filterEx, options = {}, current) { | ||
query = async function (name, keyEx, filterEx, options = {}, current) { | ||
var p, results; | ||
if (!current) { | ||
current = _setupCurrent(); | ||
} | ||
if (!current.options) { | ||
current.options = options = _parseQuery(options, name, keyEx, filterEx); | ||
} else { | ||
({ options } = current); | ||
({ | ||
options | ||
} = current); | ||
} | ||
p = {}; | ||
if (current.LastEvaluatedKey) { | ||
p.ExclusiveStartKey = current.LastEvaluatedKey; | ||
} | ||
results = yield db.query((0, _fairmont.merge)(p, options)); | ||
results = await db.query((0, _pandaParchment.merge)(p, options)); | ||
current = _catCurrent(current, results); | ||
if (!results.LastEvaluatedKey || options.Limit) { | ||
return current; | ||
} else { | ||
return yield query(name, keyEx, filterEx, options, current); | ||
return await query(name, keyEx, filterEx, options, current); | ||
} | ||
}); | ||
}; | ||
return function query(_x25, _x26, _x27) { | ||
return _ref14.apply(this, arguments); | ||
}; | ||
})(); | ||
scan = (() => { | ||
var _ref15 = _asyncToGenerator(function* (name, filterEx, options = {}, current) { | ||
scan = async function (name, filterEx, options = {}, current) { | ||
var p, results; | ||
if (!current) { | ||
current = _setupCurrent(); | ||
} | ||
if (!current.options) { | ||
current.options = options = _parseQuery(options, name, false, filterEx); | ||
} else { | ||
({ options } = current); | ||
({ | ||
options | ||
} = current); | ||
} | ||
p = {}; | ||
if (current.LastEvaluatedKey) { | ||
p.ExclusiveStartKey = current.LastEvaluatedKey; | ||
} | ||
results = yield db.scan((0, _fairmont.merge)(p, options)); | ||
results = await db.scan((0, _pandaParchment.merge)(p, options)); | ||
current = _catCurrent(current, results); | ||
if (!results.LastEvaluatedKey || options.Limit) { | ||
return current; | ||
} else { | ||
return yield scan(name, filterEx, options, current); | ||
return await scan(name, filterEx, options, current); | ||
} | ||
}); | ||
}; | ||
return function scan(_x28, _x29) { | ||
return _ref15.apply(this, arguments); | ||
return { | ||
tableGet, | ||
tableCreate, | ||
tableUpdate, | ||
tableDel, | ||
tableWaitForReady, | ||
tableWaitForDeleted, | ||
tableEmpty, | ||
keysFilter, | ||
to, | ||
parse, | ||
merge: _pandaParchment.merge, | ||
get, | ||
put, | ||
del, | ||
qv, | ||
update, | ||
query, | ||
scan | ||
}; | ||
})(); | ||
return { tableGet, tableCreate, tableUpdate, tableDel, tableWaitForReady, tableWaitForDeleted, tableEmpty, keysFilter, to, parse, merge: _fairmont.merge, get, put, del, qv, update, query, scan }; | ||
}; | ||
}; | ||
exports.default = dynamodbPrimative; | ||
var _default = dynamodbPrimitive; | ||
exports.default = _default; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["primitives/dynamodb.coffee"],"names":[],"mappings":"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","sourcesContent":["# Primitives for the service DynamoDB.\n# The main entities are Tables and Items.\n# This follows the naming convention that methods that work on Tables will be\n# prefixed \"table*\", whereas item methods will have no prefix.\n\nimport {curry} from \"panda-garden\"\nimport {merge, sleep, empty, cat, difference, first, keys, values, isFunction, isObject, pick} from \"panda-parchment\"\nimport {Method} from \"panda-generics\"\nimport {collect, project} from \"panda-river\"\nimport {notFound} from \"./utils\"\nimport {applyConfiguration} from \"../lift\"\n\ndynamodbPrimitive = (SDK) ->\n  (configuration) ->\n    db = applyConfiguration configuration, SDK.DynamoDB\n\n    #===========================================================================\n    # Tables\n    #===========================================================================\n    tableGet = (name) ->\n      try\n        {Table} = await db.describeTable TableName: name\n        Table\n      catch e\n        notFound e, 400, \"ResourceNotFoundException\"\n\n    tableCreate = (name, keys, attributes, throughput, options={}) ->\n      p =\n        TableName: name\n        KeySchema: keys\n        AttributeDefinitions: attributes\n        ProvisionedThroughput: throughput\n\n      {TableDescription}= await db.createTable merge p, options\n      TableDescription\n\n    tableUpdate = (name, attributes, throughput, options={}) ->\n      p =\n        TableName: name\n        AttributeDefinitions: attributes\n      p.ProvisionedThroughput = throughput if throughput\n\n      {TableDescription}= await db.updateTable merge p, options\n      TableDescription\n\n    tableDel = (name) ->\n      try\n        await db.deleteTable TableName: name\n      catch e\n        notFound e\n\n\n    _isTableReady = (name) ->\n      while true\n        {TableStatus} = await tableGet name\n        if !TableStatus\n          throw new Error \"Cannot find table #{name}\"\n        else if TableStatus != \"ACTIVE\"\n          await sleep 5000\n        else\n          return true\n\n    _areIndexesReady = (name) ->\n      while true\n        {GlobalSecondaryIndexes: indexes} = await tableGet name\n        return true if !indexes\n        statuses = collect project \"IndexStatus\", indexes\n        if empty difference statuses, [\"ACTIVE\"]\n          return true\n        else\n          await sleep 5000\n\n    # The optional second parameter allows the developer to also wait on all global secondary indexes to also be ready.\n    tableWaitForReady = (name, indexWait) ->\n      checks = [_isTableReady name]\n      checks.push _areIndexesReady name if indexWait\n      await Promise.all checks\n\n    tableWaitForDeleted = (name) ->\n      while true\n        {TableStatus} = await tableGet name\n        if !TableStatus\n          return true\n        else\n          await sleep 5000\n\n    # TODO: make this more efficient by throttling to X connections at once. AWS\n    # only supports N requests per second from an account, and I don't want this\n    # to violate that limit, but we can do better than one at a time.\n    keysFilter = curry (keys, item) ->\n      f = (key) -> key in keys\n      pick f, item\n\n    tableEmpty = (name) ->\n      {KeySchema} = await tableGet name\n      filter = keysFilter collect project \"AttributeName\", KeySchema\n\n      {Items} = await scan name\n      await del name, filter(i) for i in Items\n\n    #===========================================================================\n    # Type Helpers\n    #===========================================================================\n    # DynamoDB includes type information mapped into its data strctures.\n    # It expects data to be input that way, and includes it when fetched.\n    # These helpers write and parse that type system.\n    _transform = (f) ->\n      (x) ->\n        if isObject x\n          out = {}\n          out[k] = _mark(\"anyonymousDynamodbValue\", f v) for k, v of x\n          _mark \"namedDynamodbValue\", out\n        else\n          _mark \"anyonymousDynamodbValue\", f x\n\n    _mark = (name, object) -> Object.defineProperty object, \"name\", value: name\n\n    to =\n      S: _transform (s) -> S: s.toString()\n      N: _transform (n) -> N: n.toString()\n      B: _transform (b) -> B: b.toString(\"base64\")\n      SS: _transform (a) -> SS: (i.toString() for i in a)\n      NS: _transform (a) -> NS: (i.toString() for i in a)\n      BS: _transform (a) -> BS: (i.toString(\"base64\") for i in a)\n      M: _transform (m) -> M: m\n      L: _transform (l) -> L: l\n      Null: _transform (n) -> NULL: n\n      Bool: _transform (b) -> BOOL: b\n\n    parse = (attributes) ->\n      result = {}\n      for name, typeObj of attributes\n        dataType = first keys typeObj\n        v = first values typeObj\n        result[name] = switch dataType\n          when \"S\", \"SS\", \"L\", \"BOOL\" then v\n          when \"N\" then new Number v\n          when \"B\" then Buffer.from v, \"base64\"\n          when \"NS\" then (new Number i for i in v)\n          when \"BS\" then (Buffer.from i, \"base64\" for i in v)\n          when \"NULL\"\n            if v then null else undefined\n          when \"M\" then parse v\n          else\n            throw new Error \"Unable to parse object for DynamoDB attribute type. #{dataType}\"\n      result\n\n\n    #===========================================================================\n    # Items\n    #===========================================================================\n    get = (name, key, options={}) ->\n      {ReturnConsumedCapacity} = options\n      p = {TableName: name, Key: key}\n      {Item, ConsumedCapacity} = await db.getItem merge p, options\n      if ReturnConsumedCapacity then {Item, ConsumedCapacity} else Item\n\n    put = (name, item, options={}) ->\n      p = {TableName: name, Item: item}\n      await db.putItem merge p, options\n\n    del = (name, key, options={}) ->\n      p = {TableName: name, Key: key}\n      await db.deleteItem merge p, options\n\n    #===========================================================================\n    # Queries and Scans against Tables and Indexes\n    #===========================================================================\n    _delimiter = \"<###SUNDOGDYNAMODB###>\"\n    _setupCurrent = ->\n      Items: []\n      Count: 0\n      ScannedCount: 0\n      LastEvaluatedKey: false\n      ConsumedCapacity: []\n\n    _catCurrent = (current, results) ->\n      {Items, Count, ScannedCount, LastEvaluatedKey, ConsumedCapacity} = results\n      current.Items = cat current.Items, Items\n      current.Count += Count\n      current.ScannedCount += ScannedCount\n      current.LastEvaluatedKey = LastEvaluatedKey if LastEvaluatedKey\n      current.ConsumedCapacity = current.ConsumedCapacity.push ConsumedCapacity\n      current\n\n    _parseName = (name) ->\n      throw new Error \"Must provide table name.\" if !name\n      parts = name.split \":\"\n      if parts.length > 1\n        {tableName: parts[0], indexName: parts[1]}\n      else\n        {tableName: name, indexName: false}\n\n    _parseConditional = (ex, count=0) ->\n      return {result:false, values:false, count} if !ex\n      Values = {}\n      re = new RegExp \"#{_delimiter}.+?#{_delimiter}\", \"g\"\n\n      result = ex.replace re, (match) ->\n        [, obj] = match.split _delimiter\n        placeholder = \":param#{count}\"\n        count++\n        Values[placeholder] = JSON.parse obj\n        placeholder # Return placeholder to the expression we are processing.\n\n      {result, values:Values, count}\n\n    _parseQuery = (options, name, keyEx, filterEx) ->\n      {tableName, indexName} = _parseName name\n      {result:key, values:keyValues, count} = _parseConditional keyEx\n      {result:filter, values:filterValues} = _parseConditional filterEx, count\n\n      out = options\n      out.TableName = tableName\n      out.IndexName = indexName if indexName\n      out.KeyConditionExpression = key if key\n      out.FilterExpression = filter if filter\n      if keyValues || filterValues\n        out.ExpressionAttributeValues =\n          merge (keyValues || {}), (filterValues || {})\n      out\n\n    # qv produces query strings with delimited values SunDog can parse.\n    _qv = (o) ->\n      delimit = (s) -> \"#{_delimiter}#{s}#{_delimiter}\"\n      # Determine if this is a DynamoDB value, and whether is anyonymous or named.\n      if o.name == \"anyonymousDynamodbValue\"\n        delimit JSON.stringify o\n      else if o.name == \"namedDynamodbValue\"\n        delimit JSON.stringify first values o\n      else\n        throw new Error \"Unable to create stringified query value for unrecongied object #{JSON.stringify o}\"\n\n    qv = Method.create()\n    Method.define qv, isFunction, (f) -> (x) -> _qv f x\n    Method.define qv, isObject, (o) -> _qv o\n\n    update = (name, key, updateEx, options={}) ->\n      p = {TableName: name, Key: key}\n      {result, values:_values} = _parseConditional updateEx\n      options.UpdateExpression = result if result\n      options.ExpressionAttributeValues = _values if _values\n      await db.updateItem merge p, options\n\n    query = (name, keyEx, filterEx, options={}, current) ->\n      current = _setupCurrent() if !current\n      if !current.options\n        current.options = options = _parseQuery options, name, keyEx, filterEx\n      else\n        {options} = current\n\n      p = {}\n      p.ExclusiveStartKey = current.LastEvaluatedKey if current.LastEvaluatedKey\n      results = await db.query merge p, options\n\n      current = _catCurrent current, results\n      if !results.LastEvaluatedKey || options.Limit\n        current\n      else\n        await query name, keyEx, filterEx, options, current\n\n    scan = (name, filterEx, options={}, current) ->\n      current = _setupCurrent() if !current\n      if !current.options\n        current.options = options = _parseQuery options, name, false, filterEx\n      else\n        {options} = current\n\n      p = {}\n      p.ExclusiveStartKey = current.LastEvaluatedKey if current.LastEvaluatedKey\n      results = await db.scan merge p, options\n\n      current = _catCurrent current, results\n      if !results.LastEvaluatedKey || options.Limit\n        current\n      else\n        await scan name, filterEx, options, current\n\n\n\n    {tableGet, tableCreate, tableUpdate, tableDel, tableWaitForReady, tableWaitForDeleted, tableEmpty, keysFilter, to, parse, merge, get, put, del, qv, update, query, scan}\n\nexport default dynamodbPrimitive\n"],"sourceRoot":""} | ||
//# sourceURL=primitives/dynamodb.coffee |
@@ -6,31 +6,34 @@ "use strict"; | ||
}); | ||
exports.default = void 0; | ||
var _cognito = require("./cognito"); | ||
var _acm = _interopRequireDefault(require("./acm")); | ||
var _cognito2 = _interopRequireDefault(_cognito); | ||
var _cloudformation = _interopRequireDefault(require("./cloudformation")); | ||
var _dynamodb = require("./dynamodb"); | ||
var _cloudfront = _interopRequireDefault(require("./cloudfront")); | ||
var _dynamodb2 = _interopRequireDefault(_dynamodb); | ||
var _cloudwatchlogs = _interopRequireDefault(require("./cloudwatchlogs")); | ||
var _kms = require("./kms"); | ||
var _cognito = _interopRequireDefault(require("./cognito")); | ||
var _kms2 = _interopRequireDefault(_kms); | ||
var _dynamodb = _interopRequireDefault(require("./dynamodb")); | ||
var _s = require("./s3"); | ||
var _ec = _interopRequireDefault(require("./ec2")); | ||
var _s2 = _interopRequireDefault(_s); | ||
var _kms = _interopRequireDefault(require("./kms")); | ||
var _ses = require("./ses"); | ||
var _lambda = _interopRequireDefault(require("./lambda")); | ||
var _ses2 = _interopRequireDefault(_ses); | ||
var _route = _interopRequireDefault(require("./route53")); | ||
var _sns = require("./sns"); | ||
var _s = _interopRequireDefault(require("./s3")); | ||
var _sns2 = _interopRequireDefault(_sns); | ||
var _ses = _interopRequireDefault(require("./ses")); | ||
var _sts = require("./sts"); | ||
var _sns = _interopRequireDefault(require("./sns")); | ||
var _sts2 = _interopRequireDefault(_sts); | ||
var _sts = _interopRequireDefault(require("./sts")); | ||
var _url = _interopRequireDefault(require("./url")); | ||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | ||
@@ -42,6 +45,30 @@ | ||
return Object.defineProperties({}, { | ||
ACM: { | ||
enumerable: true, | ||
get: function () { | ||
return (0, _acm.default)(_AWS.SDK); | ||
} | ||
}, | ||
CloudFormation: { | ||
enumerable: true, | ||
get: function () { | ||
return (0, _cloudformation.default)(_AWS.SDK); | ||
} | ||
}, | ||
CloudFront: { | ||
enumerable: true, | ||
get: function () { | ||
return (0, _cloudfront.default)(_AWS.SDK); | ||
} | ||
}, | ||
CloudWatchLogs: { | ||
enumerable: true, | ||
get: function () { | ||
return (0, _cloudwatchlogs.default)(_AWS.SDK); | ||
} | ||
}, | ||
Cognito: { | ||
enumerable: true, | ||
get: function () { | ||
return (0, _cognito2.default)(_AWS); | ||
return (0, _cognito.default)(_AWS.SDK); | ||
} | ||
@@ -52,15 +79,33 @@ }, | ||
get: function () { | ||
return (0, _dynamodb2.default)(_AWS); | ||
return (0, _dynamodb.default)(_AWS.SDK); | ||
} | ||
}, | ||
EC2: { | ||
enumerable: true, | ||
get: function () { | ||
return (0, _ec.default)(_AWS.SDK); | ||
} | ||
}, | ||
KMS: { | ||
enumerable: true, | ||
get: function () { | ||
return (0, _kms2.default)(_AWS); | ||
return (0, _kms.default)(_AWS.SDK); | ||
} | ||
}, | ||
Lambda: { | ||
enumerable: true, | ||
get: function () { | ||
return (0, _lambda.default)(_AWS.SDK); | ||
} | ||
}, | ||
Route53: { | ||
enumerable: true, | ||
get: function () { | ||
return (0, _route.default)(_AWS.SDK); | ||
} | ||
}, | ||
S3: { | ||
enumerable: true, | ||
get: function () { | ||
return (0, _s2.default)(_AWS); | ||
return (0, _s.default)(_AWS.SDK); | ||
} | ||
@@ -71,3 +116,3 @@ }, | ||
get: function () { | ||
return (0, _ses2.default)(_AWS); | ||
return (0, _ses.default)(_AWS.SDK); | ||
} | ||
@@ -78,3 +123,3 @@ }, | ||
get: function () { | ||
return (0, _sns2.default)(_AWS); | ||
return (0, _sns.default)(_AWS.SDK); | ||
} | ||
@@ -85,4 +130,10 @@ }, | ||
get: function () { | ||
return (0, _sts2.default)(_AWS); | ||
return (0, _sts.default)(_AWS.SDK); | ||
} | ||
}, | ||
URL: { | ||
enumerable: true, | ||
get: function () { | ||
return (0, _url.default)(); | ||
} | ||
} | ||
@@ -92,2 +143,5 @@ }); | ||
exports.default = Primitives; | ||
var _default = Primitives; | ||
exports.default = _default; | ||
//# sourceMappingURL=data:application/json;base64,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QUEsRUFBSyxZQUFBO2VBQUcsa0JBQUksSUFBSSxDQUFSLEdBQUEsQztBQUFIO0FBREwsS0F4Q0Y7QUEwQ0EsSUFBQSxHQUFBLEVBQ0U7QUFBQSxNQUFBLFVBQUEsRUFBQSxJQUFBO0FBQ0EsTUFBQSxHQUFBLEVBQUssWUFBQTtlQUFHLG1CO0FBQUg7QUFETDtBQTNDRixHQURGLEM7QUFEVyxDQUFiOztlQWdEZSxVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGFjbSBmcm9tIFwiLi9hY21cIlxuaW1wb3J0IGNsb3VkZm9ybWF0aW9uIGZyb20gXCIuL2Nsb3VkZm9ybWF0aW9uXCJcbmltcG9ydCBjbG91ZGZyb250IGZyb20gXCIuL2Nsb3VkZnJvbnRcIlxuaW1wb3J0IGNsb3Vkd2F0Y2hsb2dzIGZyb20gXCIuL2Nsb3Vkd2F0Y2hsb2dzXCJcbmltcG9ydCBjb2duaXRvIGZyb20gXCIuL2NvZ25pdG9cIlxuaW1wb3J0IGR5bmFtb2RiIGZyb20gXCIuL2R5bmFtb2RiXCJcbmltcG9ydCBlYzIgZnJvbSBcIi4vZWMyXCJcbmltcG9ydCBrbXMgZnJvbSBcIi4va21zXCJcbmltcG9ydCBsYW1iZGEgZnJvbSBcIi4vbGFtYmRhXCJcbmltcG9ydCByb3V0ZTUzIGZyb20gXCIuL3JvdXRlNTNcIlxuaW1wb3J0IHMzIGZyb20gXCIuL3MzXCJcbmltcG9ydCBzZXMgZnJvbSBcIi4vc2VzXCJcbmltcG9ydCBzbnMgZnJvbSBcIi4vc25zXCJcbmltcG9ydCBzdHMgZnJvbSBcIi4vc3RzXCJcbmltcG9ydCB1cmwgZnJvbSBcIi4vdXJsXCIgICMgVVJMIHBhcnNpbmcgLyBmb3JtYXR0aW5nIGhlbHBlcnNcblxuUHJpbWl0aXZlcyA9IChfQVdTKSAtPlxuICBPYmplY3QuZGVmaW5lUHJvcGVydGllcyB7fSxcbiAgICBBQ006XG4gICAgICBlbnVtZXJhYmxlOiB0cnVlXG4gICAgICBnZXQ6IC0+IGFjbSBfQVdTLlNES1xuICAgIENsb3VkRm9ybWF0aW9uOlxuICAgICAgZW51bWVyYWJsZTogdHJ1ZVxuICAgICAgZ2V0OiAtPiBjbG91ZGZvcm1hdGlvbiBfQVdTLlNES1xuICAgIENsb3VkRnJvbnQ6XG4gICAgICBlbnVtZXJhYmxlOiB0cnVlXG4gICAgICBnZXQ6IC0+IGNsb3VkZnJvbnQgX0FXUy5TREtcbiAgICBDbG91ZFdhdGNoTG9nczpcbiAgICAgIGVudW1lcmFibGU6IHRydWVcbiAgICAgIGdldDogLT4gY2xvdWR3YXRjaGxvZ3MgX0FXUy5TREtcbiAgICBDb2duaXRvOlxuICAgICAgZW51bWVyYWJsZTogdHJ1ZVxuICAgICAgZ2V0OiAtPiBjb2duaXRvIF9BV1MuU0RLXG4gICAgRHluYW1vREI6XG4gICAgICBlbnVtZXJhYmxlOiB0cnVlXG4gICAgICBnZXQ6IC0+IGR5bmFtb2RiIF9BV1MuU0RLXG4gICAgRUMyOlxuICAgICAgZW51bWVyYWJsZTogdHJ1ZVxuICAgICAgZ2V0OiAtPiBlYzIgX0FXUy5TREtcbiAgICBLTVM6XG4gICAgICBlbnVtZXJhYmxlOiB0cnVlXG4gICAgICBnZXQ6IC0+IGttcyBfQVdTLlNES1xuICAgIExhbWJkYTpcbiAgICAgIGVudW1lcmFibGU6IHRydWVcbiAgICAgIGdldDogLT4gbGFtYmRhIF9BV1MuU0RLXG4gICAgUm91dGU1MzpcbiAgICAgIGVudW1lcmFibGU6IHRydWVcbiAgICAgIGdldDogLT4gcm91dGU1MyBfQVdTLlNES1xuICAgIFMzOlxuICAgICAgZW51bWVyYWJsZTogdHJ1ZVxuICAgICAgZ2V0OiAtPiBzMyBfQVdTLlNES1xuICAgIFNFUzpcbiAgICAgIGVudW1lcmFibGU6IHRydWVcbiAgICAgIGdldDogLT4gc2VzIF9BV1MuU0RLXG4gICAgU05TOlxuICAgICAgZW51bWVyYWJsZTogdHJ1ZVxuICAgICAgZ2V0OiAtPiBzbnMgX0FXUy5TREtcbiAgICBTVFM6XG4gICAgICBlbnVtZXJhYmxlOiB0cnVlXG4gICAgICBnZXQ6IC0+IHN0cyBfQVdTLlNES1xuICAgIFVSTDpcbiAgICAgIGVudW1lcmFibGU6IHRydWVcbiAgICAgIGdldDogLT4gdXJsKClcblxuZXhwb3J0IGRlZmF1bHQgUHJpbWl0aXZlc1xuIl0sInNvdXJjZVJvb3QiOiIifQ== | ||
//# sourceURL=primitives/index.coffee |
@@ -6,19 +6,22 @@ "use strict"; | ||
}); | ||
exports.default = void 0; | ||
var _fairmont = require("fairmont"); | ||
var _pandaParchment = require("panda-parchment"); | ||
var _utils = require("./utils"); | ||
function _asyncToGenerator(fn) { return function () { var gen = fn.apply(this, arguments); return new Promise(function (resolve, reject) { function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { return Promise.resolve(value).then(function (value) { step("next", value); }, function (err) { step("throw", err); }); } } return step("next"); }); }; } | ||
var _lift = require("../lift"); | ||
// Primitives for the service KMS. | ||
// NOTE: In KMS methods besides "create" and "delete" and "addAlias": ID can be key ID, key ARN, or key alias name. | ||
var cognitoPrimative; | ||
var cognitoPrimitive; | ||
cognitoPrimative = function (_AWS) { | ||
var addAlias, create, decrypt, encrypt, get, kms, randomKey, reEncrypt, removeAlias, scheduleDelete; | ||
kms = _AWS.KMS; | ||
get = (() => { | ||
var _ref = _asyncToGenerator(function* (id, tokens) { | ||
cognitoPrimitive = function (SDK) { | ||
return function (configuration) { | ||
var addAlias, create, decrypt, encrypt, get, kms, randomKey, reEncrypt, removeAlias, scheduleDelete; | ||
kms = (0, _lift.applyConfiguration)(configuration, SDK.KMS); | ||
get = async function (id, tokens) { | ||
var KeyMetadata, e, params; | ||
try { | ||
@@ -28,6 +31,10 @@ params = { | ||
}; | ||
if (tokens) { | ||
params.GrantTokens = tokens; | ||
} | ||
({ KeyMetadata } = yield kms.describeKey(params)); | ||
({ | ||
KeyMetadata | ||
} = await kms.describeKey(params)); | ||
return KeyMetadata; | ||
@@ -38,21 +45,13 @@ } catch (error) { | ||
} | ||
}); | ||
}; | ||
return function get(_x, _x2) { | ||
return _ref.apply(this, arguments); | ||
}; | ||
})(); | ||
create = (() => { | ||
var _ref2 = _asyncToGenerator(function* (params = {}) { | ||
create = async function (params = {}) { | ||
var KeyMetadata; | ||
({ KeyMetadata } = yield kms.createKey(params)); | ||
({ | ||
KeyMetadata | ||
} = await kms.createKey(params)); | ||
return KeyMetadata; | ||
}); | ||
}; | ||
return function create() { | ||
return _ref2.apply(this, arguments); | ||
}; | ||
})(); | ||
scheduleDelete = (() => { | ||
var _ref3 = _asyncToGenerator(function* (id, delay) { | ||
scheduleDelete = async function (id, delay) { | ||
var params; | ||
@@ -62,39 +61,35 @@ params = { | ||
}; | ||
if (delay) { | ||
params.PendingWindowInDays = delay; | ||
} | ||
return yield kms.deleteKey(params); | ||
}); | ||
return function scheduleDelete(_x3, _x4) { | ||
return _ref3.apply(this, arguments); | ||
return await kms.deleteKey(params); | ||
}; | ||
})(); | ||
addAlias = (() => { | ||
var _ref4 = _asyncToGenerator(function* (TargetKeyId, AliasName) { | ||
return yield kms.createAlias({ TargetKeyId, AliasName }); | ||
}); | ||
return function addAlias(_x5, _x6) { | ||
return _ref4.apply(this, arguments); | ||
addAlias = async function (TargetKeyId, AliasName) { | ||
return await kms.createAlias({ | ||
TargetKeyId, | ||
AliasName | ||
}); | ||
}; | ||
})(); | ||
removeAlias = (() => { | ||
var _ref5 = _asyncToGenerator(function* (AliasName) { | ||
return yield kms.deleteAlias({ AliasName }); | ||
}); | ||
return function removeAlias(_x7) { | ||
return _ref5.apply(this, arguments); | ||
removeAlias = async function (AliasName) { | ||
return await kms.deleteAlias({ | ||
AliasName | ||
}); | ||
}; | ||
})(); | ||
randomKey = (() => { | ||
var _ref6 = _asyncToGenerator(function* (size, encoding = "hex") { | ||
randomKey = async function (size, encoding = "hex") { | ||
var Plaintext; | ||
({ Plaintext } = yield kms.generateRandom({ | ||
({ | ||
Plaintext | ||
} = await kms.generateRandom({ | ||
NumberOfBytes: size | ||
})); | ||
switch (encoding) { | ||
case "buffer": | ||
return Plaintext; | ||
case "ascii": | ||
@@ -109,2 +104,3 @@ case "hex": | ||
return Plaintext.toString(encoding); | ||
case "base64": | ||
@@ -114,4 +110,6 @@ // Omitting padding characters, per: | ||
return Plaintext.toString("base64").replace(/\=+$/, ''); | ||
case "base64padded": | ||
return Plaintext.toString("base64"); | ||
case "base64url": | ||
@@ -121,14 +119,11 @@ // Based on RFC 4648's "base64url" mapping: | ||
return Plaintext.toString("base64").replace(/\+/g, '-').replace(/\//g, '_').replace(/\=+$/, ''); | ||
default: | ||
throw new Error(`Unknown encoding ${encoding}.`); | ||
} | ||
}); | ||
}; | ||
return function randomKey(_x8) { | ||
return _ref6.apply(this, arguments); | ||
}; | ||
})(); | ||
encrypt = (() => { | ||
var _ref7 = _asyncToGenerator(function* (id, plaintext, encoding = "utf8", options = {}) { | ||
encrypt = async function (id, plaintext, encoding = "utf8", options = {}) { | ||
var CiphertextBlob, input, params; | ||
switch (encoding) { | ||
@@ -145,8 +140,11 @@ case "utf8": | ||
break; | ||
case "buffer": | ||
input = plaintext; | ||
break; | ||
default: | ||
throw new Error(`Unknown encoding ${encoding}.`); | ||
} | ||
params = { | ||
@@ -156,13 +154,10 @@ KeyId: id, | ||
}; | ||
params = (0, _fairmont.merge)(params, options); | ||
({ CiphertextBlob } = yield kms.encrypt(params)); | ||
params = (0, _pandaParchment.merge)(params, options); | ||
({ | ||
CiphertextBlob | ||
} = await kms.encrypt(params)); | ||
return CiphertextBlob.toString("base64"); | ||
}); | ||
}; | ||
return function encrypt(_x9, _x10) { | ||
return _ref7.apply(this, arguments); | ||
}; | ||
})(); | ||
decrypt = (() => { | ||
var _ref8 = _asyncToGenerator(function* (blob, encoding = "utf8", options = {}) { | ||
decrypt = async function (blob, encoding = "utf8", options = {}) { | ||
var Plaintext, params; | ||
@@ -172,4 +167,7 @@ params = { | ||
}; | ||
params = (0, _fairmont.merge)(params, options); | ||
({ Plaintext } = yield kms.decrypt(params)); | ||
params = (0, _pandaParchment.merge)(params, options); | ||
({ | ||
Plaintext | ||
} = await kms.decrypt(params)); | ||
switch (encoding) { | ||
@@ -185,15 +183,12 @@ case "utf8": | ||
return Plaintext.toString(encoding); | ||
case "buffer": | ||
return Plaintext; | ||
default: | ||
throw new Error(`Unknown encoding ${encoding}.`); | ||
} | ||
}); | ||
}; | ||
return function decrypt(_x11) { | ||
return _ref8.apply(this, arguments); | ||
}; | ||
})(); | ||
reEncrypt = (() => { | ||
var _ref9 = _asyncToGenerator(function* (id, blob, options = {}) { | ||
reEncrypt = async function (id, blob, options = {}) { | ||
var CiphertextBlob, params; | ||
@@ -204,14 +199,26 @@ params = { | ||
}; | ||
params = (0, _fairmont.merge)(params, options); | ||
({ CiphertextBlob } = yield kms.reEncrypt(params)); | ||
params = (0, _pandaParchment.merge)(params, options); | ||
({ | ||
CiphertextBlob | ||
} = await kms.reEncrypt(params)); | ||
return CiphertextBlob.toString("base64"); | ||
}); | ||
}; | ||
return function reEncrypt(_x12, _x13) { | ||
return _ref9.apply(this, arguments); | ||
return { | ||
get, | ||
create, | ||
scheduleDelete, | ||
addAlias, | ||
removeAlias, | ||
randomKey, | ||
decrypt, | ||
encrypt, | ||
reEncrypt | ||
}; | ||
})(); | ||
return { get, create, scheduleDelete, addAlias, removeAlias, randomKey, decrypt, encrypt, reEncrypt }; | ||
}; | ||
}; | ||
exports.default = cognitoPrimative; | ||
var _default = cognitoPrimitive; | ||
exports.default = _default; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["primitives/kms.coffee"],"names":[],"mappings":"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","sourcesContent":["# Primitives for the service KMS.\n# NOTE: In KMS methods besides \"create\" and \"delete\" and \"addAlias\": ID can be key ID, key ARN, or key alias name.\n\nimport {cat, merge} from \"panda-parchment\"\nimport {notFound} from \"./utils\"\nimport {applyConfiguration} from \"../lift\"\n\ncognitoPrimitive = (SDK) ->\n  (configuration) ->\n    kms = applyConfiguration configuration, SDK.KMS\n\n    get = (id, tokens) ->\n      try\n        params = {KeyId: id}\n        params.GrantTokens = tokens if tokens\n        {KeyMetadata} = await kms.describeKey params\n        KeyMetadata\n      catch e\n        notFound e, 400, \"NotFoundException\"\n\n    create = (params={}) ->\n      {KeyMetadata} = await kms.createKey params\n      KeyMetadata\n\n    scheduleDelete = (id, delay) ->\n      params = KeyId: id\n      params.PendingWindowInDays = delay if delay\n      await kms.deleteKey params\n\n    addAlias = (TargetKeyId, AliasName) ->\n      await kms.createAlias {TargetKeyId, AliasName}\n\n    removeAlias = (AliasName) ->\n      await kms.deleteAlias {AliasName}\n\n    randomKey = (size, encoding=\"hex\") ->\n      {Plaintext} = await kms.generateRandom {NumberOfBytes: size}\n      switch encoding\n        when \"buffer\"\n          Plaintext\n        when \"ascii\", \"hex\", \"utf8\", \"utf16le\", \"ucs2\", \"latin1\", \"binary\", \"hex\"\n          Plaintext.toString encoding\n        when \"base64\"\n          # Omitting padding characters, per:\n          # https://tools.ietf.org/html/rfc4648#section-3.2\n          Plaintext.toString(\"base64\")\n          .replace(/\\=+$/, '')\n        when \"base64padded\"\n          Plaintext.toString(\"base64\")\n        when \"base64url\"\n          # Based on RFC 4648's \"base64url\" mapping:\n          # https://tools.ietf.org/html/rfc4648#section-5\n          Plaintext.toString(\"base64\")\n          .replace(/\\+/g, '-')\n          .replace(/\\//g, '_')\n          .replace(/\\=+$/, '')\n        else\n          throw new Error \"Unknown encoding #{encoding}.\"\n\n    encrypt = (id, plaintext, encoding=\"utf8\", options={}) ->\n      switch encoding\n        when \"utf8\", \"base64\", \"hex\", \"ascii\", \"utf16le\", \"ucs2\", \"latin1\", \"binary\"\n          input = Buffer.from plaintext, encoding\n        when \"buffer\"\n          input = plaintext\n        else\n          throw new Error \"Unknown encoding #{encoding}.\"\n      params =\n        KeyId: id\n        Plaintext: input\n      params = merge params, options\n      {CiphertextBlob} = await kms.encrypt params\n      CiphertextBlob.toString(\"base64\")\n\n    decrypt = (blob, encoding=\"utf8\", options={}) ->\n      params = CiphertextBlob: Buffer.from(blob, \"base64\")\n      params = merge params, options\n      {Plaintext} = await kms.decrypt params\n      switch encoding\n        when \"utf8\", \"base64\", \"hex\", \"ascii\", \"utf16le\", \"ucs2\", \"latin1\", \"binary\"\n          Plaintext.toString encoding\n        when \"buffer\"\n          Plaintext\n        else\n          throw new Error \"Unknown encoding #{encoding}.\"\n\n    reEncrypt = (id, blob, options={}) ->\n      params =\n        DestinationKeyId: id\n        CyphertextBlob: Buffer.from(blob, \"base64\")\n      params = merge params, options\n      {CiphertextBlob} = await kms.reEncrypt params\n      CiphertextBlob.toString(\"base64\")\n\n\n    {get, create, scheduleDelete, addAlias, removeAlias, randomKey, decrypt, encrypt, reEncrypt}\n\n\nexport default cognitoPrimitive\n"],"sourceRoot":""} | ||
//# sourceURL=primitives/kms.coffee |
@@ -6,31 +6,43 @@ "use strict"; | ||
}); | ||
exports.default = void 0; | ||
var _fs = require("fs"); | ||
var _fairmont = require("fairmont"); | ||
var _crypto = _interopRequireDefault(require("crypto")); | ||
var _mime = require("mime"); | ||
var _pandaGarden = require("panda-garden"); | ||
var _mime2 = _interopRequireDefault(_mime); | ||
var _pandaParchment = require("panda-parchment"); | ||
var _pandaQuill = require("panda-quill"); | ||
var _mime = _interopRequireDefault(require("mime")); | ||
var _utils = require("./utils"); | ||
var _lift = require("../lift"); | ||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | ||
function _asyncToGenerator(fn) { return function () { var gen = fn.apply(this, arguments); return new Promise(function (resolve, reject) { function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { return Promise.resolve(value).then(function (value) { step("next", value); }, function (err) { step("throw", err); }); } } return step("next"); }); }; } | ||
// Primitives for the service S3. The main entities are buckets and objects. | ||
// This follows the naming convention that methods that work on buckets will be | ||
// prefixed "bucket*", whereas object methods will have no prefix. | ||
var s3Primative, | ||
var md5, | ||
s3Primitive, | ||
indexOf = [].indexOf; | ||
s3Primative = function (_AWS) { | ||
var bucketDel, bucketEmpty, bucketExists, bucketTouch, del, exists, get, list, put, s3; | ||
s3 = _AWS.S3; | ||
bucketExists = (() => { | ||
var _ref = _asyncToGenerator(function* (name) { | ||
md5 = function (string) { | ||
return _crypto.default.createHash('md5').update(string, 'utf-8').digest("hex"); | ||
}; | ||
s3Primitive = function (SDK) { | ||
return function (configuration) { | ||
var bucketDel, bucketEmpty, bucketExists, bucketPutACL, bucketTouch, del, exists, get, list, multipartAbort, multipartComplete, multipartPut, multipartStart, put, s3, sign, signPost; | ||
s3 = (0, _lift.applyConfiguration)(configuration, SDK.S3); | ||
bucketExists = async function (name) { | ||
var e; | ||
try { | ||
yield s3.headBucket({ | ||
await s3.headBucket({ | ||
Bucket: name | ||
@@ -43,13 +55,9 @@ }); | ||
} | ||
}); | ||
}; | ||
return function bucketExists(_x) { | ||
return _ref.apply(this, arguments); | ||
}; | ||
})(); | ||
exists = (0, _fairmont.curry)((() => { | ||
var _ref2 = _asyncToGenerator(function* (name, key) { | ||
exists = (0, _pandaGarden.curry)(async function (name, key) { | ||
var e; | ||
try { | ||
yield s3.headObject({ | ||
await s3.headObject({ | ||
Bucket: name, | ||
@@ -65,52 +73,41 @@ Key: key | ||
return function (_x2, _x3) { | ||
return _ref2.apply(this, arguments); | ||
}; | ||
})()); | ||
bucketTouch = (() => { | ||
var _ref3 = _asyncToGenerator(function* (name) { | ||
if (yield bucketExists(name)) { | ||
bucketTouch = async function (name) { | ||
if (await bucketExists(name)) { | ||
return true; | ||
} | ||
yield s3.createBucket({ | ||
await s3.createBucket({ | ||
Bucket: name | ||
}); | ||
return yield (0, _fairmont.sleep)(15000); // race condition with S3 API. Wait to be available. | ||
}); | ||
return await (0, _pandaParchment.sleep)(15000); // race condition with S3 API. Wait to be available. | ||
}; | ||
return function bucketTouch(_x4) { | ||
return _ref3.apply(this, arguments); | ||
}; | ||
})(); | ||
put = (0, _fairmont.curry)((() => { | ||
var _ref4 = _asyncToGenerator(function* (name, key, data, filetype) { | ||
var body, content, params; | ||
put = (0, _pandaGarden.curry)(async function (Bucket, Key, data, filetype) { | ||
var body, content; | ||
if (filetype) { | ||
// here, data is stringified data. | ||
content = body = new Buffer(data); | ||
content = body = Buffer.from(data); | ||
} else { | ||
// here, data is a path to file. | ||
filetype = _mime2.default.lookup(data); | ||
filetype = _mime.default.getType(data); | ||
body = (0, _fs.createReadStream)(data); | ||
content = indexOf.call(_mime2.default.lookup(data), "text") >= 0 ? yield (0, _fairmont.read)(data) : yield (0, _fairmont.read)(data, "buffer"); | ||
content = indexOf.call(_mime.default.getType(data), "text") >= 0 ? await (0, _pandaQuill.read)(data) : await (0, _pandaQuill.read)(data, "buffer"); | ||
} | ||
params = { | ||
Bucket: name, | ||
Key: key, | ||
return await s3.putObject({ | ||
Bucket, | ||
Key, | ||
ContentType: filetype, | ||
ContentMD5: new Buffer((0, _fairmont.md5)(content), "hex").toString('base64'), | ||
ContentMD5: Buffer.from(md5(content), "hex").toString('base64'), | ||
Body: body | ||
}; | ||
return yield s3.putObject(params); | ||
}); | ||
}); | ||
get = (0, _pandaGarden.curry)(async function (name, key, encoding = "utf8") { | ||
var Body, e; | ||
return function (_x5, _x6, _x7, _x8) { | ||
return _ref4.apply(this, arguments); | ||
}; | ||
})()); | ||
get = (0, _fairmont.curry)((() => { | ||
var _ref5 = _asyncToGenerator(function* (name, key, encoding = "utf8") { | ||
var Body, e; | ||
try { | ||
({ Body } = yield s3.getObject({ | ||
({ | ||
Body | ||
} = await s3.getObject({ | ||
Bucket: name, | ||
@@ -125,12 +122,7 @@ Key: key | ||
}); | ||
del = (0, _pandaGarden.curry)(async function (name, key) { | ||
var e; | ||
return function (_x9, _x10) { | ||
return _ref5.apply(this, arguments); | ||
}; | ||
})()); | ||
del = (0, _fairmont.curry)((() => { | ||
var _ref6 = _asyncToGenerator(function* (name, key) { | ||
var e; | ||
try { | ||
return yield s3.deleteObject({ | ||
return await s3.deleteObject({ | ||
Bucket: name, | ||
@@ -145,11 +137,7 @@ Key: key | ||
return function (_x11, _x12) { | ||
return _ref6.apply(this, arguments); | ||
}; | ||
})()); | ||
bucketDel = (() => { | ||
var _ref7 = _asyncToGenerator(function* (name) { | ||
bucketDel = async function (name) { | ||
var e; | ||
try { | ||
return yield s3.deleteBucket({ | ||
return await s3.deleteBucket({ | ||
Bucket: name | ||
@@ -161,10 +149,5 @@ }); | ||
} | ||
}); | ||
}; | ||
return function bucketDel(_x13) { | ||
return _ref7.apply(this, arguments); | ||
}; | ||
})(); | ||
list = (0, _fairmont.curry)((() => { | ||
var _ref8 = _asyncToGenerator(function* (name, items = [], marker) { | ||
list = (0, _pandaGarden.curry)(async function (name, items = [], marker) { | ||
var Contents, IsTruncated, NextContinuationToken, p; | ||
@@ -175,40 +158,124 @@ p = { | ||
}; | ||
if (marker) { | ||
p.ContinuationToken = marker; | ||
} | ||
({ IsTruncated, Contents, NextContinuationToken } = yield s3.listObjectsV2(p)); | ||
({ | ||
IsTruncated, | ||
Contents, | ||
NextContinuationToken | ||
} = await s3.listObjectsV2(p)); | ||
if (IsTruncated) { | ||
items = (0, _fairmont.cat)(items, Contents); | ||
return yield list(name, items, NextContinuationToken); | ||
items = (0, _pandaParchment.cat)(items, Contents); | ||
return await list(name, items, NextContinuationToken); | ||
} else { | ||
return (0, _fairmont.cat)(items, Contents); | ||
return (0, _pandaParchment.cat)(items, Contents); | ||
} | ||
}); | ||
}); // TODO: make this more efficient by throttling to X connections at once. AWS | ||
// only supports N requests per second from an account, and I don't want this | ||
// to violate that limit, but we can do better than one at a time. | ||
return function (_x14) { | ||
return _ref8.apply(this, arguments); | ||
}; | ||
})()); | ||
// TODO: make this more efficient by throttling to X connections at once. AWS | ||
// only supports N requests per second from an account, and I don't want this | ||
// to violate that limit, but we can do better than one at a time. | ||
bucketEmpty = (() => { | ||
var _ref9 = _asyncToGenerator(function* (name) { | ||
bucketEmpty = async function (name) { | ||
var i, items, j, len, results; | ||
items = yield list(name); | ||
items = await list(name); | ||
results = []; | ||
for (j = 0, len = items.length; j < len; j++) { | ||
i = items[j]; | ||
results.push((yield del(name, i.Key))); | ||
results.push((await del(name, i.Key))); | ||
} | ||
return results; | ||
}); | ||
}; | ||
return function bucketEmpty(_x15) { | ||
return _ref9.apply(this, arguments); | ||
bucketPutACL = async function (parameters) { | ||
return await s3.putBucketAcl(parameters); | ||
}; //#### | ||
// Multipart upload functions | ||
//#### | ||
multipartStart = async function (Bucket, Key, ContentType, options = {}) { | ||
return await s3.createMultipartUpload((0, _pandaParchment.merge)({ | ||
Bucket, | ||
Key, | ||
ContentType | ||
}, options)); | ||
}; | ||
})(); | ||
return { bucketExists, exists, bucketTouch, put, get, del, bucketDel, list, bucketEmpty }; | ||
multipartAbort = async function (Bucket, Key, UploadId) { | ||
return await s3.abortMultipartUpload({ | ||
Bucket, | ||
Key, | ||
UploadId | ||
}); | ||
}; | ||
multipartComplete = async function (Bucket, Key, UploadId, MultipartUpload) { | ||
return await s3.completeMultipartUpload({ | ||
Bucket, | ||
Key, | ||
UploadId, | ||
MultipartUpload | ||
}); | ||
}; | ||
multipartPut = async function (Bucket, Key, UploadId, PartNumber, part, filetype) { | ||
var body, content; | ||
if (filetype) { | ||
// here, data is stringified data. | ||
content = body = Buffer.from(part); | ||
} else { | ||
// here, data is a path to file. | ||
filetype = _mime.default.getType(part); | ||
body = (0, _fs.createReadStream)(part); | ||
content = indexOf.call(filetype, "text") >= 0 ? await (0, _pandaQuill.read)(part) : await (0, _pandaQuill.read)(part, "buffer"); | ||
} | ||
return await s3.uploadPart({ | ||
Bucket, | ||
Key, | ||
UploadId, | ||
PartNumber, | ||
ContentType: filetype, | ||
ContentMD5: Buffer.from(md5(content), "hex").toString('base64'), | ||
Body: body | ||
}); | ||
}; // Signing a URL grants the bearer the ability to perform the given action against an S3 object, even if they are not you. | ||
sign = async function (action, parameters) { | ||
return await s3.getSignedUrl(action, parameters); | ||
}; | ||
signPost = async function (parameters) { | ||
return await s3.createPresignedPost(parameters); | ||
}; | ||
return { | ||
bucketExists, | ||
exists, | ||
bucketTouch, | ||
put, | ||
get, | ||
del, | ||
bucketDel, | ||
list, | ||
bucketEmpty, | ||
multipartStart, | ||
multipartAbort, | ||
multipartPut, | ||
multipartComplete, | ||
sign, | ||
signPost | ||
}; | ||
}; | ||
}; | ||
exports.default = s3Primative; | ||
var _default = s3Primitive; | ||
exports.default = _default; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["primitives/s3.coffee"],"names":[],"mappings":";;;;;;;AAIA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAEA;;AACA;;;;AAZA;;;AAAA,IAAA,GAAA;AAAA,IAAA,WAAA;AAAA,IAAA,OAAA,GAAA,GAAA,OAAA;;AAcA,GAAA,GAAM,UAAA,MAAA,EAAA;SACJ,gBAAA,UAAA,CAAA,KAAA,EAAA,MAAA,CAAA,MAAA,EAAA,OAAA,EAAA,MAAA,CAAA,KAAA,C;AADI,CAAN;;AAGA,WAAA,GAAc,UAAA,GAAA,EAAA;SACZ,UAAA,aAAA,EAAA;AACE,QAAA,SAAA,EAAA,WAAA,EAAA,YAAA,EAAA,YAAA,EAAA,WAAA,EAAA,GAAA,EAAA,MAAA,EAAA,GAAA,EAAA,IAAA,EAAA,cAAA,EAAA,iBAAA,EAAA,YAAA,EAAA,cAAA,EAAA,GAAA,EAAA,EAAA,EAAA,IAAA,EAAA,QAAA;AAAA,IAAA,EAAA,GAAK,8BAAA,aAAA,EAAkC,GAAG,CAArC,EAAA,CAAL;;AAEA,IAAA,YAAA,GAAe,gBAAA,IAAA,EAAA;AACb,UAAA,CAAA;;AAAA,UAAA;AACE,cAAM,EAAE,CAAF,UAAA,CAAc;AAAA,UAAA,MAAA,EAAQ;AAAR,SAAd,CAAN;eADF,I;AAAA,OAAA,CAAA,OAAA,KAAA,EAAA;AAGM,QAAA,CAAA,GAAA,KAAA;eACJ,qBAJF,CAIE,C;;AALW,KAAf;;AAOA,IAAA,MAAA,GAAS,wBAAM,gBAAA,IAAA,EAAA,GAAA,EAAA;AACb,UAAA,CAAA;;AAAA,UAAA;AACE,cAAM,EAAE,CAAF,UAAA,CAAc;AAAC,UAAA,MAAA,EAAD,IAAA;AAAe,UAAA,GAAA,EAAK;AAApB,SAAd,CAAN;eADF,I;AAAA,OAAA,CAAA,OAAA,KAAA,EAAA;AAGM,QAAA,CAAA,GAAA,KAAA;eACJ,qBAJF,CAIE,C;;AALK,KAAA,CAAT;;AAOA,IAAA,WAAA,GAAc,gBAAA,IAAA,EAAA;AACZ,UAAe,MAAM,YAAA,CAArB,IAAqB,CAArB,EAAA;AAAA,eAAA,IAAA;;;AACA,YAAM,EAAE,CAAF,YAAA,CAAgB;AAAC,QAAA,MAAA,EAAQ;AAAT,OAAhB,CAAN;AACA,aAAA,MAAM,2BAHM,KAGN,CAAN,CAHY,CAAA;AAAA,KAAd;;AAKA,IAAA,GAAA,GAAM,wBAAM,gBAAA,MAAA,EAAA,GAAA,EAAA,IAAA,EAAA,QAAA,EAAA;AACV,UAAA,IAAA,EAAA,OAAA;;AAAA,UAAA,QAAA,EAAA;;AAEE,QAAA,OAAA,GAAU,IAAA,GAAO,MAAM,CAAN,IAAA,CAFnB,IAEmB,CAAjB;AAFF,OAAA,MAAA;;AAKE,QAAA,QAAA,GAAW,cAAA,OAAA,CAAA,IAAA,CAAX;AACA,QAAA,IAAA,GAAO,0BAAA,IAAA,CAAP;AACA,QAAA,OAAA,GACK,OAAA,CAAA,IAAA,CAAU,cAAA,OAAA,CAAV,IAAU,CAAV,EAAA,MAAA,KAAH,CAAG,GACD,MAAM,sBADR,IACQ,CADL,GAGD,MAAM,sBAAA,IAAA,EAXZ,QAWY,CAJV;;;AAMF,aAAA,MAAM,EAAE,CAAF,SAAA,CAAa;AAAA,QAAA,MAAA;AAAA,QAAA,GAAA;AAEjB,QAAA,WAAA,EAFiB,QAAA;AAGjB,QAAA,UAAA,EAAY,MAAM,CAAN,IAAA,CAAY,GAAA,CAAZ,OAAY,CAAZ,EAAA,KAAA,EAAA,QAAA,CAHK,QAGL,CAHK;AAIjB,QAAA,IAAA,EAAM;AAJW,OAAb,CAAN;AAdI,KAAA,CAAN;AAqBA,IAAA,GAAA,GAAM,wBAAM,gBAAA,IAAA,EAAA,GAAA,EAAY,QAAA,GAAZ,MAAA,EAAA;AACV,UAAA,IAAA,EAAA,CAAA;;AAAA,UAAA;AACE,SAAA;AAAA,UAAA;AAAA,YAAS,MAAM,EAAE,CAAF,SAAA,CAAa;AAAC,UAAA,MAAA,EAAD,IAAA;AAAe,UAAA,GAAA,EAAK;AAApB,SAAb,CAAf;eACA,IAAI,CAAJ,QAAA,CAFF,QAEE,C;AAFF,OAAA,CAAA,OAAA,KAAA,EAAA;AAGM,QAAA,CAAA,GAAA,KAAA;eACJ,qBAJF,CAIE,C;;AALE,KAAA,CAAN;AAOA,IAAA,GAAA,GAAM,wBAAM,gBAAA,IAAA,EAAA,GAAA,EAAA;AACV,UAAA,CAAA;;AAAA,UAAA;AACE,eAAA,MAAM,EAAE,CAAF,YAAA,CAAgB;AAAC,UAAA,MAAA,EAAD,IAAA;AAAe,UAAA,GAAA,EAAK;AAApB,SAAhB,CAAN;AADF,OAAA,CAAA,OAAA,KAAA,EAAA;AAEM,QAAA,CAAA,GAAA,KAAA;eACJ,qBAHF,CAGE,C;;AAJE,KAAA,CAAN;;AAMA,IAAA,SAAA,GAAY,gBAAA,IAAA,EAAA;AACV,UAAA,CAAA;;AAAA,UAAA;AACE,eAAA,MAAM,EAAE,CAAF,YAAA,CAAgB;AAAA,UAAA,MAAA,EAAQ;AAAR,SAAhB,CAAN;AADF,OAAA,CAAA,OAAA,KAAA,EAAA;AAEM,QAAA,CAAA,GAAA,KAAA;eACJ,qBAHF,CAGE,C;;AAJQ,KAAZ;;AAMA,IAAA,IAAA,GAAO,wBAAM,gBAAA,IAAA,EAAO,KAAA,GAAP,EAAA,EAAA,MAAA,EAAA;AACX,UAAA,QAAA,EAAA,WAAA,EAAA,qBAAA,EAAA,CAAA;AAAA,MAAA,CAAA,GAAI;AAAC,QAAA,MAAA,EAAD,IAAA;AAAe,QAAA,OAAA,EAAS;AAAxB,OAAJ;;AACA,UAAA,MAAA,EAAA;AAAA,QAAA,CAAC,CAAD,iBAAA,GAAA,MAAA;;;AAEA,OAAA;AAAA,QAAA,WAAA;AAAA,QAAA,QAAA;AAAA,QAAA;AAAA,UAAiD,MAAM,EAAE,CAAF,aAAA,CAAvD,CAAuD,CAAvD;;AACA,UAAA,WAAA,EAAA;AACE,QAAA,KAAA,GAAQ,yBAAA,KAAA,EAAA,QAAA,CAAR;AACA,eAAA,MAAM,IAAA,CAAA,IAAA,EAAA,KAAA,EAFR,qBAEQ,CAAN;AAFF,OAAA,MAAA;eAIE,yBAAA,KAAA,EAJF,QAIE,C;;AAtEJ,KA6DO,CAAP,CA9DF,C;;;;AA4EE,IAAA,WAAA,GAAc,gBAAA,IAAA,EAAA;AACZ,UAAA,CAAA,EAAA,KAAA,EAAA,CAAA,EAAA,GAAA,EAAA,OAAA;AAAA,MAAA,KAAA,GAAQ,MAAM,IAAA,CAAN,IAAM,CAAd;AACsB,MAAA,OAAA,GAAA,EAAA;;AAAA,WAAA,CAAA,GAAA,CAAA,EAAA,GAAA,GAAA,KAAA,CAAA,MAAA,EAAA,CAAA,GAAA,GAAA,EAAA,CAAA,EAAA,EAAA;;gBAAtB,I,EAAA,MAAM,GAAA,CAAA,IAAA,EAAU,CAAC,CAAjB,GAAM,C;AAAgB;;;AAFV,KAAd;;AAIA,IAAA,YAAA,GAAe,gBAAA,UAAA,EAAA;AACb,aAAA,MAAM,EAAE,CAAF,YAAA,CAAN,UAAM,CAAN;AAhFF,KA+EA,CAhFF,C;;;;;AAsFE,IAAA,cAAA,GAAiB,gBAAA,MAAA,EAAA,GAAA,EAAA,WAAA,EAA2B,OAAA,GAA3B,EAAA,EAAA;AACf,aAAA,MAAM,EAAE,CAAF,qBAAA,CAAyB,2BAAM;AAAA,QAAA,MAAA;AAAA,QAAA,GAAA;AAAN,QAAA;AAAM,OAAN,EAA/B,OAA+B,CAAzB,CAAN;AADe,KAAjB;;AAGA,IAAA,cAAA,GAAiB,gBAAA,MAAA,EAAA,GAAA,EAAA,QAAA,EAAA;AACf,aAAA,MAAM,EAAE,CAAF,oBAAA,CAAwB;AAAA,QAAA,MAAA;AAAA,QAAA,GAAA;AAA9B,QAAA;AAA8B,OAAxB,CAAN;AADe,KAAjB;;AAGA,IAAA,iBAAA,GAAoB,gBAAA,MAAA,EAAA,GAAA,EAAA,QAAA,EAAA,eAAA,EAAA;AAClB,aAAA,MAAM,EAAE,CAAF,uBAAA,CAA2B;AAAA,QAAA,MAAA;AAAA,QAAA,GAAA;AAAA,QAAA,QAAA;AAAjC,QAAA;AAAiC,OAA3B,CAAN;AADkB,KAApB;;AAGA,IAAA,YAAA,GAAe,gBAAA,MAAA,EAAA,GAAA,EAAA,QAAA,EAAA,UAAA,EAAA,IAAA,EAAA,QAAA,EAAA;AACb,UAAA,IAAA,EAAA,OAAA;;AAAA,UAAA,QAAA,EAAA;;AAEE,QAAA,OAAA,GAAU,IAAA,GAAO,MAAM,CAAN,IAAA,CAFnB,IAEmB,CAAjB;AAFF,OAAA,MAAA;;AAKE,QAAA,QAAA,GAAW,cAAA,OAAA,CAAA,IAAA,CAAX;AACA,QAAA,IAAA,GAAO,0BAAA,IAAA,CAAP;AACA,QAAA,OAAA,GACK,OAAA,CAAA,IAAA,CAAA,QAAA,EAAA,MAAA,KAAH,CAAG,GACD,MAAM,sBADR,IACQ,CADL,GAGD,MAAM,sBAAA,IAAA,EAXZ,QAWY,CAJV;;;AAMF,aAAA,MAAM,EAAE,CAAF,UAAA,CAAc;AAAA,QAAA,MAAA;AAAA,QAAA,GAAA;AAAA,QAAA,QAAA;AAAA,QAAA,UAAA;AAElB,QAAA,WAAA,EAFkB,QAAA;AAGlB,QAAA,UAAA,EAAY,MAAM,CAAN,IAAA,CAAY,GAAA,CAAZ,OAAY,CAAZ,EAAA,KAAA,EAAA,QAAA,CAHM,QAGN,CAHM;AAIlB,QAAA,IAAA,EAAM;AAJY,OAAd,CAAN;AA5GF,KA8FA,CA/FF,C;;;AAsHE,IAAA,IAAA,GAAO,gBAAA,MAAA,EAAA,UAAA,EAAA;AACL,aAAA,MAAM,EAAE,CAAF,YAAA,CAAA,MAAA,EAAN,UAAM,CAAN;AADK,KAAP;;AAGA,IAAA,QAAA,GAAW,gBAAA,UAAA,EAAA;AACT,aAAA,MAAM,EAAE,CAAF,mBAAA,CAAN,UAAM,CAAN;AADS,KAAX;;WAIA;AAAA,MAAA,YAAA;AAAA,MAAA,MAAA;AAAA,MAAA,WAAA;AAAA,MAAA,GAAA;AAAA,MAAA,GAAA;AAAA,MAAA,GAAA;AAAA,MAAA,SAAA;AAAA,MAAA,IAAA;AAAA,MAAA,WAAA;AAAA,MAAA,cAAA;AAAA,MAAA,cAAA;AAAA,MAAA,YAAA;AAAA,MAAA,iBAAA;AAAA,MAAA,IAAA;AAAA,MAAA;AAAA,K;AA7HF,G;AADY,CAAd;;eAiIe,W","sourcesContent":["# Primitives for the service S3.  The main entities are buckets and objects.\n# This follows the naming convention that methods that work on buckets will be\n# prefixed \"bucket*\", whereas object methods will have no prefix.\n\nimport {createReadStream} from \"fs\"\nimport Crypto from \"crypto\"\nimport {curry} from \"panda-garden\"\nimport {sleep, cat, merge} from \"panda-parchment\"\nimport {read} from \"panda-quill\"\nimport mime from \"mime\"\n\nimport {notFound} from \"./utils\"\nimport {applyConfiguration} from \"../lift\"\n\nmd5 = (string) ->\n  Crypto.createHash('md5').update(string, 'utf-8').digest(\"hex\")\n\ns3Primitive = (SDK) ->\n  (configuration) ->\n    s3 = applyConfiguration configuration, SDK.S3\n\n    bucketExists = (name) ->\n      try\n        await s3.headBucket Bucket: name\n        true\n      catch e\n        notFound e\n\n    exists = curry (name, key) ->\n      try\n        await s3.headObject {Bucket: name, Key: key}\n        true\n      catch e\n        notFound e\n\n    bucketTouch = (name) ->\n      return true if await bucketExists name\n      await s3.createBucket {Bucket: name}\n      await sleep 15000 # race condition with S3 API.  Wait to be available.\n\n    put = curry (Bucket, Key, data, filetype) ->\n      if filetype\n        # here, data is stringified data.\n        content = body = Buffer.from data\n      else\n        # here, data is a path to file.\n        filetype = mime.getType data\n        body = createReadStream data\n        content =\n          if \"text\" in mime.getType(data)\n            await read data\n          else\n            await read data, \"buffer\"\n\n      await s3.putObject {\n        Bucket, Key,\n        ContentType: filetype\n        ContentMD5: Buffer.from(md5(content), \"hex\").toString('base64')\n        Body: body\n      }\n\n    get = curry (name, key, encoding=\"utf8\") ->\n      try\n        {Body} = await s3.getObject {Bucket: name, Key: key}\n        Body.toString encoding\n      catch e\n        notFound e\n\n    del = curry (name, key) ->\n      try\n        await s3.deleteObject {Bucket: name, Key: key}\n      catch e\n        notFound e\n\n    bucketDel = (name) ->\n      try\n        await s3.deleteBucket Bucket: name\n      catch e\n        notFound e\n\n    list = curry (name, items=[], marker) ->\n      p = {Bucket: name, MaxKeys: 1000}\n      p.ContinuationToken = marker if marker\n\n      {IsTruncated, Contents, NextContinuationToken} = await s3.listObjectsV2 p\n      if IsTruncated\n        items = cat items, Contents\n        await list name, items, NextContinuationToken\n      else\n        cat items, Contents\n\n    # TODO: make this more efficient by throttling to X connections at once. AWS\n    # only supports N requests per second from an account, and I don't want this\n    # to violate that limit, but we can do better than one at a time.\n    bucketEmpty = (name) ->\n      items = await list name\n      await del name, i.Key for i in items\n\n    bucketPutACL = (parameters) ->\n      await s3.putBucketAcl parameters\n\n    #####\n    # Multipart upload functions\n    #####\n    multipartStart = (Bucket, Key, ContentType, options={}) ->\n      await s3.createMultipartUpload merge {Bucket, Key, ContentType}, options\n\n    multipartAbort = (Bucket, Key, UploadId) ->\n      await s3.abortMultipartUpload {Bucket, Key, UploadId}\n\n    multipartComplete = (Bucket, Key, UploadId, MultipartUpload) ->\n      await s3.completeMultipartUpload {Bucket, Key, UploadId, MultipartUpload}\n\n    multipartPut = (Bucket, Key, UploadId, PartNumber, part, filetype) ->\n      if filetype\n        # here, data is stringified data.\n        content = body = Buffer.from part\n      else\n        # here, data is a path to file.\n        filetype = mime.getType part\n        body = createReadStream part\n        content =\n          if \"text\" in filetype\n            await read part\n          else\n            await read part, \"buffer\"\n\n      await s3.uploadPart {\n        Bucket, Key, UploadId, PartNumber,\n        ContentType: filetype\n        ContentMD5: Buffer.from(md5(content), \"hex\").toString('base64')\n        Body: body\n      }\n\n\n    # Signing a URL grants the bearer the ability to perform the given action against an S3 object, even if they are not you.\n    sign = (action, parameters) ->\n      await s3.getSignedUrl action, parameters\n\n    signPost = (parameters) ->\n      await s3.createPresignedPost parameters\n\n\n    {bucketExists, exists, bucketTouch, put, get, del, bucketDel, list, bucketEmpty, multipartStart, multipartAbort, multipartPut, multipartComplete, sign, signPost}\n\n\nexport default s3Primitive\n"],"sourceRoot":""} | ||
//# sourceURL=primitives/s3.coffee |
@@ -6,22 +6,25 @@ "use strict"; | ||
}); | ||
exports.default = void 0; | ||
var _fairmont = require("fairmont"); | ||
var _pandaParchment = require("panda-parchment"); | ||
function _asyncToGenerator(fn) { return function () { var gen = fn.apply(this, arguments); return new Promise(function (resolve, reject) { function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { return Promise.resolve(value).then(function (value) { step("next", value); }, function (err) { step("throw", err); }); } } return step("next"); }); }; } | ||
var _lift = require("../lift"); | ||
// Primitives for the service SES (simple email service). | ||
var sesPrimative; | ||
var sesPrimitive; | ||
sesPrimative = function (_AWS) { | ||
var sendEmail, ses; | ||
ses = _AWS.SES; | ||
sendEmail = (() => { | ||
var _ref = _asyncToGenerator(function* (src, dest, subject, body, format = "text", opts = {}) { | ||
sesPrimitive = function (SDK) { | ||
return function (configuration) { | ||
var sendEmail, ses; | ||
ses = (0, _lift.applyConfiguration)(configuration, SDK.SES); | ||
sendEmail = async function (src, dest, subject, body, format = "text", opts = {}) { | ||
var Body, Destination, Source, Subject, params; | ||
Source = src; | ||
if ((0, _fairmont.isArray)(dest)) { | ||
if ((0, _pandaParchment.isArray)(dest)) { | ||
Destination = { | ||
ToAddresses: dest | ||
}; | ||
} else if ((0, _fairmont.isObject)(dest)) { | ||
} else if ((0, _pandaParchment.isObject)(dest)) { | ||
Destination = dest; | ||
@@ -33,5 +36,7 @@ } else { | ||
} | ||
Subject = { | ||
Data: subject | ||
}; | ||
if (format === "text") { | ||
@@ -52,18 +57,24 @@ Body = { | ||
} | ||
params = { | ||
Source, | ||
Destination, | ||
Message: { Subject, Body } | ||
Message: { | ||
Subject, | ||
Body | ||
} | ||
}; | ||
params = (0, _fairmont.merge)(params, opts); | ||
return yield ses.sendEmail(params); | ||
}); | ||
params = (0, _pandaParchment.merge)(params, opts); | ||
return await ses.sendEmail(params); | ||
}; | ||
return function sendEmail(_x, _x2, _x3, _x4) { | ||
return _ref.apply(this, arguments); | ||
return { | ||
sendEmail | ||
}; | ||
})(); | ||
return { sendEmail }; | ||
}; | ||
}; | ||
exports.default = sesPrimative; | ||
var _default = sesPrimitive; | ||
exports.default = _default; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInByaW1pdGl2ZXMvc2VzLmNvZmZlZSJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQ0E7O0FBQ0E7O0FBRkE7QUFBQSxJQUFBLFlBQUE7O0FBSUEsWUFBQSxHQUFlLFVBQUEsR0FBQSxFQUFBO1NBQ2IsVUFBQSxhQUFBLEVBQUE7QUFDRSxRQUFBLFNBQUEsRUFBQSxHQUFBO0FBQUEsSUFBQSxHQUFBLEdBQU0sOEJBQUEsYUFBQSxFQUFrQyxHQUFHLENBQXJDLEdBQUEsQ0FBTjs7QUFFQSxJQUFBLFNBQUEsR0FBWSxnQkFBQSxHQUFBLEVBQUEsSUFBQSxFQUFBLE9BQUEsRUFBQSxJQUFBLEVBQTJCLE1BQUEsR0FBM0IsTUFBQSxFQUEwQyxJQUFBLEdBQTFDLEVBQUEsRUFBQTtBQUNWLFVBQUEsSUFBQSxFQUFBLFdBQUEsRUFBQSxNQUFBLEVBQUEsT0FBQSxFQUFBLE1BQUE7QUFBQSxNQUFBLE1BQUEsR0FBUyxHQUFUOztBQUNBLFVBQUcsNkJBQUgsSUFBRyxDQUFILEVBQUE7QUFDRSxRQUFBLFdBQUEsR0FBYztBQUFBLFVBQUEsV0FBQSxFQUFhO0FBQWIsU0FBZDtBQURGLE9BQUEsTUFFSyxJQUFHLDhCQUFILElBQUcsQ0FBSCxFQUFBO0FBQ0gsUUFBQSxXQUFBLEdBREcsSUFDSDtBQURHLE9BQUEsTUFBQTtBQUdILFFBQUEsV0FBQSxHQUFjO0FBQUEsVUFBQSxXQUFBLEVBQWEsQ0FBQSxJQUFBO0FBQWIsU0FBZDs7O0FBRUYsTUFBQSxPQUFBLEdBQVU7QUFBQSxRQUFBLElBQUEsRUFBTTtBQUFOLE9BQVY7O0FBQ0EsVUFBRyxNQUFBLEtBQUgsTUFBQSxFQUFBO0FBQ0UsUUFBQSxJQUFBLEdBQU87QUFBQSxVQUFBLElBQUEsRUFBTTtBQUFBLFlBQUEsSUFBQSxFQUFNO0FBQU47QUFBTixTQUFQO0FBREYsT0FBQSxNQUVLLElBQUcsTUFBQSxLQUFILE1BQUEsRUFBQTtBQUNILFFBQUEsSUFBQSxHQUFPO0FBQUEsVUFBQSxJQUFBLEVBQU07QUFBQSxZQUFBLElBQUEsRUFBTTtBQUFOO0FBQU4sU0FBUDtBQURHLE9BQUEsTUFBQTtBQUdILGNBQU0sSUFBQSxLQUFBLENBSEgscUJBR0csQ0FBTjs7O0FBRUYsTUFBQSxNQUFBLEdBQVM7QUFBQSxRQUFBLE1BQUE7QUFBQSxRQUFBLFdBQUE7QUFHUCxRQUFBLE9BQUEsRUFBUztBQUFBLFVBQUEsT0FBQTtBQUFBLFVBQUE7QUFBQTtBQUhGLE9BQVQ7QUFNQSxNQUFBLE1BQUEsR0FBUywyQkFBQSxNQUFBLEVBQUEsSUFBQSxDQUFUO0FBQ0EsYUFBQSxNQUFNLEdBQUcsQ0FBSCxTQUFBLENBQU4sTUFBTSxDQUFOO0FBeEJVLEtBQVo7O1dBMEJBO0FBQUEsTUFBQTtBQUFBLEs7QUE3QkYsRztBQURhLENBQWY7O2VBaUNlLFkiLCJzb3VyY2VzQ29udGVudCI6WyIjIFByaW1pdGl2ZXMgZm9yIHRoZSBzZXJ2aWNlIFNFUyAoc2ltcGxlIGVtYWlsIHNlcnZpY2UpLlxuaW1wb3J0IHtpc09iamVjdCwgaXNBcnJheSwgbWVyZ2V9IGZyb20gXCJwYW5kYS1wYXJjaG1lbnRcIlxuaW1wb3J0IHthcHBseUNvbmZpZ3VyYXRpb259IGZyb20gXCIuLi9saWZ0XCJcblxuc2VzUHJpbWl0aXZlID0gKFNESykgLT5cbiAgKGNvbmZpZ3VyYXRpb24pIC0+XG4gICAgc2VzID0gYXBwbHlDb25maWd1cmF0aW9uIGNvbmZpZ3VyYXRpb24sIFNESy5TRVNcblxuICAgIHNlbmRFbWFpbCA9IChzcmMsIGRlc3QsIHN1YmplY3QsIGJvZHksIGZvcm1hdD1cInRleHRcIiwgb3B0cz17fSkgLT5cbiAgICAgIFNvdXJjZSA9IHNyY1xuICAgICAgaWYgaXNBcnJheSBkZXN0XG4gICAgICAgIERlc3RpbmF0aW9uID0gVG9BZGRyZXNzZXM6IGRlc3RcbiAgICAgIGVsc2UgaWYgaXNPYmplY3QgZGVzdFxuICAgICAgICBEZXN0aW5hdGlvbiA9IGRlc3RcbiAgICAgIGVsc2VcbiAgICAgICAgRGVzdGluYXRpb24gPSBUb0FkZHJlc3NlczogW2Rlc3RdXG5cbiAgICAgIFN1YmplY3QgPSBEYXRhOiBzdWJqZWN0XG4gICAgICBpZiBmb3JtYXQgPT0gXCJ0ZXh0XCJcbiAgICAgICAgQm9keSA9IFRleHQ6IERhdGE6IGJvZHlcbiAgICAgIGVsc2UgaWYgZm9ybWF0ID09IFwiaHRtbFwiXG4gICAgICAgIEJvZHkgPSBIdG1sOiBEYXRhOiBib2R5XG4gICAgICBlbHNlXG4gICAgICAgIHRocm93IG5ldyBFcnJvciBcIlVua25vd24gYm9keSBmb3JtYXRcIlxuXG4gICAgICBwYXJhbXMgPSB7XG4gICAgICAgIFNvdXJjZVxuICAgICAgICBEZXN0aW5hdGlvblxuICAgICAgICBNZXNzYWdlOiB7U3ViamVjdCwgQm9keX1cbiAgICAgIH1cblxuICAgICAgcGFyYW1zID0gbWVyZ2UgcGFyYW1zLCBvcHRzXG4gICAgICBhd2FpdCBzZXMuc2VuZEVtYWlsIHBhcmFtc1xuXG4gICAge3NlbmRFbWFpbH1cblxuXG5leHBvcnQgZGVmYXVsdCBzZXNQcmltaXRpdmVcbiJdLCJzb3VyY2VSb290IjoiIn0= | ||
//# sourceURL=primitives/ses.coffee |
@@ -6,23 +6,30 @@ "use strict"; | ||
}); | ||
exports.default = void 0; | ||
function _asyncToGenerator(fn) { return function () { var gen = fn.apply(this, arguments); return new Promise(function (resolve, reject) { function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { return Promise.resolve(value).then(function (value) { step("next", value); }, function (err) { step("throw", err); }); } } return step("next"); }); }; } | ||
var _lift = require("../lift"); | ||
// Primitives for the service SNS (simple notificaiton service). | ||
var snsPrimative; | ||
var snsPrimitive; | ||
snsPrimative = function (_AWS) { | ||
var sendSMS, sns; | ||
sns = _AWS.SNS; | ||
sendSMS = (() => { | ||
var _ref = _asyncToGenerator(function* (PhoneNumber, Message) { | ||
return yield sns.publish({ PhoneNumber, Message }); | ||
}); | ||
snsPrimitive = function (SDK) { | ||
return function (configuration) { | ||
var sendSMS, sns; | ||
sns = (0, _lift.applyConfiguration)(configuration, SDK.SNS); | ||
return function sendSMS(_x, _x2) { | ||
return _ref.apply(this, arguments); | ||
sendSMS = async function (PhoneNumber, Message) { | ||
return await sns.publish({ | ||
PhoneNumber, | ||
Message | ||
}); | ||
}; | ||
})(); | ||
return { sendSMS }; | ||
return { | ||
sendSMS | ||
}; | ||
}; | ||
}; | ||
exports.default = snsPrimative; | ||
var _default = snsPrimitive; | ||
exports.default = _default; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInByaW1pdGl2ZXMvc25zLmNvZmZlZSJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQ0E7O0FBREE7QUFBQSxJQUFBLFlBQUE7O0FBR0EsWUFBQSxHQUFlLFVBQUEsR0FBQSxFQUFBO1NBQ2IsVUFBQSxhQUFBLEVBQUE7QUFDRSxRQUFBLE9BQUEsRUFBQSxHQUFBO0FBQUEsSUFBQSxHQUFBLEdBQU0sOEJBQUEsYUFBQSxFQUFrQyxHQUFHLENBQXJDLEdBQUEsQ0FBTjs7QUFFQSxJQUFBLE9BQUEsR0FBVSxnQkFBQSxXQUFBLEVBQUEsT0FBQSxFQUFBO0FBQ1IsYUFBQSxNQUFNLEdBQUcsQ0FBSCxPQUFBLENBQVk7QUFBQSxRQUFBLFdBQUE7QUFBbEIsUUFBQTtBQUFrQixPQUFaLENBQU47QUFEUSxLQUFWOztXQUdBO0FBQUEsTUFBQTtBQUFBLEs7QUFORixHO0FBRGEsQ0FBZjs7ZUFTZSxZIiwic291cmNlc0NvbnRlbnQiOlsiIyBQcmltaXRpdmVzIGZvciB0aGUgc2VydmljZSBTTlMgKHNpbXBsZSBub3RpZmljYWl0b24gc2VydmljZSkuXG5pbXBvcnQge2FwcGx5Q29uZmlndXJhdGlvbn0gZnJvbSBcIi4uL2xpZnRcIlxuXG5zbnNQcmltaXRpdmUgPSAoU0RLKSAtPlxuICAoY29uZmlndXJhdGlvbikgLT5cbiAgICBzbnMgPSBhcHBseUNvbmZpZ3VyYXRpb24gY29uZmlndXJhdGlvbiwgU0RLLlNOU1xuXG4gICAgc2VuZFNNUyA9IChQaG9uZU51bWJlciwgTWVzc2FnZSkgLT5cbiAgICAgIGF3YWl0IHNucy5wdWJsaXNoIHtQaG9uZU51bWJlciwgTWVzc2FnZX1cblxuICAgIHtzZW5kU01TfVxuXG5leHBvcnQgZGVmYXVsdCBzbnNQcmltaXRpdmVcbiJdLCJzb3VyY2VSb290IjoiIn0= | ||
//# sourceURL=primitives/sns.coffee |
@@ -6,23 +6,27 @@ "use strict"; | ||
}); | ||
exports.default = void 0; | ||
function _asyncToGenerator(fn) { return function () { var gen = fn.apply(this, arguments); return new Promise(function (resolve, reject) { function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { return Promise.resolve(value).then(function (value) { step("next", value); }, function (err) { step("throw", err); }); } } return step("next"); }); }; } | ||
var _lift = require("../lift"); | ||
// Primitives for the service Cognito. The base entity is the "user". Methods that act on other entities, like pools or clients are prefixed as such. | ||
var stsPrimative; | ||
var stsPrimitive; | ||
stsPrimative = function (_AWS) { | ||
var sts, whoAmI; | ||
sts = _AWS.STS; | ||
whoAmI = (() => { | ||
var _ref = _asyncToGenerator(function* () { | ||
return yield sts.getCallerIdentity(); | ||
}); | ||
stsPrimitive = function (SDK) { | ||
return function (configuration) { | ||
var sts, whoAmI; | ||
sts = (0, _lift.applyConfiguration)(configuration, SDK.STS); | ||
return function whoAmI() { | ||
return _ref.apply(this, arguments); | ||
whoAmI = async function () { | ||
return await sts.getCallerIdentity(); | ||
}; | ||
})(); | ||
return { whoAmI }; | ||
return { | ||
whoAmI | ||
}; | ||
}; | ||
}; | ||
exports.default = stsPrimative; | ||
var _default = stsPrimitive; | ||
exports.default = _default; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInByaW1pdGl2ZXMvc3RzLmNvZmZlZSJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQ0E7O0FBREE7QUFBQSxJQUFBLFlBQUE7O0FBR0EsWUFBQSxHQUFlLFVBQUEsR0FBQSxFQUFBO1NBQ2IsVUFBQSxhQUFBLEVBQUE7QUFDRSxRQUFBLEdBQUEsRUFBQSxNQUFBO0FBQUEsSUFBQSxHQUFBLEdBQU0sOEJBQUEsYUFBQSxFQUFrQyxHQUFHLENBQXJDLEdBQUEsQ0FBTjs7QUFFQSxJQUFBLE1BQUEsR0FBUyxrQkFBQTtBQUFHLGFBQUEsTUFBTSxHQUFHLENBQVQsaUJBQU0sRUFBTjtBQUFILEtBQVQ7O1dBRUE7QUFBQSxNQUFBO0FBQUEsSztBQUxGLEc7QUFEYSxDQUFmOztlQVFlLFkiLCJzb3VyY2VzQ29udGVudCI6WyIjIFByaW1pdGl2ZXMgZm9yIHRoZSBzZXJ2aWNlIENvZ25pdG8uICBUaGUgYmFzZSBlbnRpdHkgaXMgdGhlIFwidXNlclwiLiAgTWV0aG9kcyB0aGF0IGFjdCBvbiBvdGhlciBlbnRpdGllcywgbGlrZSBwb29scyBvciBjbGllbnRzIGFyZSBwcmVmaXhlZCBhcyBzdWNoLlxuaW1wb3J0IHthcHBseUNvbmZpZ3VyYXRpb259IGZyb20gXCIuLi9saWZ0XCJcblxuc3RzUHJpbWl0aXZlID0gKFNESykgLT5cbiAgKGNvbmZpZ3VyYXRpb24pIC0+XG4gICAgc3RzID0gYXBwbHlDb25maWd1cmF0aW9uIGNvbmZpZ3VyYXRpb24sIFNESy5TVFNcblxuICAgIHdob0FtSSA9IC0+IGF3YWl0IHN0cy5nZXRDYWxsZXJJZGVudGl0eSgpXG5cbiAgICB7d2hvQW1JfVxuXG5leHBvcnQgZGVmYXVsdCBzdHNQcmltaXRpdmVcbiJdLCJzb3VyY2VSb290IjoiIn0= | ||
//# sourceURL=primitives/sts.coffee |
@@ -6,6 +6,16 @@ "use strict"; | ||
}); | ||
exports.where = exports.notFound = void 0; | ||
var _pandaGarden = require("panda-garden"); | ||
var _pandaParchment = require("panda-parchment"); | ||
var _pandaRiver = require("panda-river"); | ||
var notFound, where; | ||
exports.where = where; | ||
exports.notFound = notFound; | ||
// Some SunDog methods return false when a resource cannot be found instead | ||
// of throwing the raw AWS error. In custom cases, that's not always 404. | ||
var notFound; | ||
exports.notFound = notFound = function (e, status = 404, code) { | ||
@@ -16,2 +26,3 @@ if ((e != null ? e.statusCode : void 0) === status) { | ||
} | ||
return false; | ||
@@ -23,2 +34,6 @@ } else { | ||
exports.notFound = notFound; | ||
exports.where = where = (0, _pandaGarden.curry)(function (example, i) { | ||
return (0, _pandaRiver.select)((0, _pandaParchment.query)(example), i); | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInByaW1pdGl2ZXMvdXRpbHMuY29mZmVlIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFDQTs7QUFGQSxJQUFBLFFBQUEsRUFBQSxLQUFBOzs7Ozs7QUFPQSxtQkFBQSxRQUFBLEdBQVcsVUFBQSxDQUFBLEVBQUksTUFBQSxHQUFKLEdBQUEsRUFBQSxJQUFBLEVBQUE7QUFDVCxNQUFBLENBQUEsQ0FBQSxJQUFBLElBQUEsR0FBRyxDQUFDLENBQUUsVUFBTixHQUFNLEtBQUgsQ0FBSCxNQUFBLE1BQUEsRUFBQTtBQUNFLFFBQVcsSUFBQSxJQUFRLENBQUMsQ0FBRCxJQUFBLEtBQW5CLElBQUEsRUFBQTtBQUFBLFlBQUEsQ0FBQTs7O1dBREYsSztBQUFBLEdBQUEsTUFBQTtBQUlFLFVBSkYsQ0FJRTs7QUFMTyxDQUFYOztBQU9BLGdCQUFBLEtBQUEsR0FBUSx3QkFBTSxVQUFBLE9BQUEsRUFBQSxDQUFBLEVBQUE7U0FBZ0Isd0JBQVEsMkJBQVIsT0FBUSxDQUFSLEVBQUEsQ0FBQSxDO0FBQXRCLENBQUEsQ0FBUiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Y3Vycnl9IGZyb20gXCJwYW5kYS1nYXJkZW5cIlxuaW1wb3J0IHtxdWVyeX0gZnJvbSBcInBhbmRhLXBhcmNobWVudFwiXG5pbXBvcnQge3NlbGVjdH0gZnJvbSBcInBhbmRhLXJpdmVyXCJcblxuXG4jIFNvbWUgU3VuRG9nIG1ldGhvZHMgcmV0dXJuIGZhbHNlIHdoZW4gYSByZXNvdXJjZSBjYW5ub3QgYmUgZm91bmQgaW5zdGVhZFxuIyBvZiB0aHJvd2luZyB0aGUgcmF3IEFXUyBlcnJvci4gIEluIGN1c3RvbSBjYXNlcywgdGhhdCdzIG5vdCBhbHdheXMgNDA0Llxubm90Rm91bmQgPSAoZSwgc3RhdHVzPTQwNCwgY29kZSkgLT5cbiAgaWYgZT8uc3RhdHVzQ29kZSA9PSBzdGF0dXNcbiAgICB0aHJvdyBlIGlmIGNvZGUgJiYgZS5jb2RlICE9IGNvZGVcbiAgICBmYWxzZVxuICBlbHNlXG4gICAgdGhyb3cgZVxuXG53aGVyZSA9IGN1cnJ5IChleGFtcGxlLCBpKSAtPiBzZWxlY3QgKHF1ZXJ5IGV4YW1wbGUpLCBpXG5cbmV4cG9ydCB7bm90Rm91bmQsIHdoZXJlfVxuIl0sInNvdXJjZVJvb3QiOiIifQ== | ||
//# sourceURL=primitives/utils.coffee |
{ | ||
"name": "sundog", | ||
"version": "0.0.9", | ||
"version": "1.0.0", | ||
"description": "Wrapper for the JavaScript AWS SDK, powered by Fairmont to give it a functional boost", | ||
@@ -10,3 +10,5 @@ "main": "build/npm/src/index.js", | ||
], | ||
"scripts": {}, | ||
"scripts": { | ||
"test": "gulp npm:test" | ||
}, | ||
"repository": { | ||
@@ -38,11 +40,18 @@ "type": "git", | ||
"dependencies": { | ||
"fairmont": "2.0.1", | ||
"mime": "^2.0.3" | ||
"mime": "^2.0.3", | ||
"panda-garden": "^3.0.4", | ||
"panda-generics": "^4.0.2", | ||
"panda-parchment": "^4.0.4", | ||
"panda-quill": "^3.1.1", | ||
"panda-river": "^4.3.0" | ||
}, | ||
"devDependencies": { | ||
"coffeescript": "2.1.0", | ||
"gulp": "github:gulpjs/gulp#4.0", | ||
"panda-builder": "1.1.1", | ||
"@babel/core": "^7.1.2", | ||
"@babel/preset-env": "^7.1.0", | ||
"amen": "^2.1.0", | ||
"coffeescript": "^2.3.2", | ||
"gulp": "github:gulpjs/gulp#v4.0.0", | ||
"panda-builder": "^2.4.1", | ||
"source-map-support": "^0.5.0" | ||
} | ||
} |
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
Network access
Supply chain riskThis module accesses the network.
Found 1 instance in 1 package
No v1
QualityPackage is not semver >=1. This means it is not stable and does not support ^ ranges.
Found 1 instance in 1 package
187937
25
2646
0
6
7
2
+ Addedpanda-garden@^3.0.4
+ Addedpanda-generics@^4.0.2
+ Addedpanda-parchment@^4.0.4
+ Addedpanda-quill@^3.1.1
+ Addedpanda-river@^4.3.0
+ Addedminimatch@3.1.2(transitive)
+ Addedpanda-garden@1.0.03.5.0(transitive)
+ Addedpanda-generics@4.3.0(transitive)
+ Addedpanda-parchment@4.2.1(transitive)
+ Addedpanda-quill@3.4.5(transitive)
+ Addedpanda-river@4.4.2(transitive)
- Removedfairmont@2.0.1
- Removedbase64-words@0.2.0(transitive)
- Removedfairmont@2.0.1(transitive)
- Removedfairmont-core@1.0.1(transitive)
- Removedfairmont-filesystem@2.0.0(transitive)
- Removedfairmont-helpers@2.0.1(transitive)
- Removedfairmont-multimethods@1.0.1(transitive)
- Removedfairmont-process@2.0.0(transitive)
- Removedfairmont-reactive@2.0.0(transitive)
- Removedminimatch@2.0.10(transitive)