New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

sundog

Package Overview
Dependencies
Maintainers
1
Versions
65
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

sundog - npm Package Compare versions

Comparing version 0.0.9 to 1.0.0

build/npm/src/lift-all.js

6

build/npm/src/helpers/index.js

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

32

build/npm/src/index.js

@@ -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":"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","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"
}
}
SocketSocket SOC 2 Logo

Product

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

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc