diff --git a/CHANGELOG.md b/CHANGELOG.md index f1b712b..280af12 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,4 +1,4 @@ -## [0.1.1](https://github.com/DiaKEM/dexcom-api-client/compare/0.1.0...0.1.1) (2022-03-22)* chore: ts fixed (75fcb83) +## [0.1.2](https://github.com/DiaKEM/dexcom-api-client/compare/0.1.1...0.1.2) (2022-03-22)## [0.1.1](https://github.com/DiaKEM/dexcom-api-client/compare/0.1.0...0.1.1) (2022-03-22)* chore: ts fixed (75fcb83) * feat: observer feature implemented (930f1d1)## [0.0.6](https://github.com/DiaKEM/dexcom-api-client/compare/0.0.5...0.0.6) (2022-03-21)## [0.0.5](https://github.com/DiaKEM/dexcom-api-client/compare/0.0.4...0.0.5) (2022-03-21)## 0.0.4 (2022-03-21) \ No newline at end of file diff --git a/lib/client.d.ts b/lib/client.d.ts index 6173915..2ace47a 100644 --- a/lib/client.d.ts +++ b/lib/client.d.ts @@ -2,28 +2,19 @@ import { AxiosRequestConfig } from 'axios'; import schedule from 'node-schedule'; import { CGMDataType } from './utils'; declare type DexcomApiClientType = { - username: string; - password: string; - server: 'US' | 'EU'; - clientOpts?: AxiosRequestConfig; + username: string; + password: string; + server: 'US' | 'EU'; + clientOpts?: AxiosRequestConfig; }; -export declare const DexcomApiClient: ({ - username, - password, - server, - clientOpts, -}: DexcomApiClientType) => { - login: () => Promise; - read: (minutesAgo?: number, count?: number) => Promise; - readLast: () => Promise; - observe: ({ - maxAttempts, - delay, - listener, - }: { - maxAttempts?: number | undefined; - delay?: number | undefined; - listener: (data: CGMDataType) => void; - }) => Promise; +export declare const DexcomApiClient: ({ username, password, server, clientOpts, }: DexcomApiClientType) => { + login: () => Promise; + read: (minutesAgo?: number, count?: number) => Promise; + readLast: () => Promise; + observe: ({ maxAttempts, delay, listener, }: { + maxAttempts?: number | undefined; + delay?: number | undefined; + listener: (data: CGMDataType) => void; + }) => Promise; }; export {}; diff --git a/lib/client.js b/lib/client.js index 7964dce..74d6df2 100644 --- a/lib/client.js +++ b/lib/client.js @@ -1,457 +1,310 @@ -'use strict'; +"use strict"; -var _interopRequireDefault = require('@babel/runtime/helpers/interopRequireDefault'); +var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); -Object.defineProperty(exports, '__esModule', { - value: true, +Object.defineProperty(exports, "__esModule", { + value: true }); exports.DexcomApiClient = void 0; -var _regenerator = _interopRequireDefault( - require('@babel/runtime/regenerator') -); - -var _toConsumableArray2 = _interopRequireDefault( - require('@babel/runtime/helpers/toConsumableArray') -); - -var _slicedToArray2 = _interopRequireDefault( - require('@babel/runtime/helpers/slicedToArray') -); - -var _asyncToGenerator2 = _interopRequireDefault( - require('@babel/runtime/helpers/asyncToGenerator') -); - -var _defineProperty2 = _interopRequireDefault( - require('@babel/runtime/helpers/defineProperty') -); - -var _axios = _interopRequireDefault(require('axios')); - -var _nodeSchedule = _interopRequireDefault(require('node-schedule')); - -var _utils = require('./utils'); - -function ownKeys(object, enumerableOnly) { - var keys = Object.keys(object); - if (Object.getOwnPropertySymbols) { - var symbols = Object.getOwnPropertySymbols(object); - enumerableOnly && - (symbols = symbols.filter(function (sym) { - return Object.getOwnPropertyDescriptor(object, sym).enumerable; - })), - keys.push.apply(keys, symbols); - } - return keys; -} - -function _objectSpread(target) { - for (var i = 1; i < arguments.length; i++) { - var source = null != arguments[i] ? arguments[i] : {}; - i % 2 - ? ownKeys(Object(source), !0).forEach(function (key) { - (0, _defineProperty2['default'])(target, key, source[key]); - }) - : Object.getOwnPropertyDescriptors - ? Object.defineProperties( - target, - Object.getOwnPropertyDescriptors(source) - ) - : ownKeys(Object(source)).forEach(function (key) { - Object.defineProperty( - target, - key, - Object.getOwnPropertyDescriptor(source, key) - ); - }); - } - return target; -} +var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator")); + +var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray")); + +var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray")); + +var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator")); + +var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); + +var _axios = _interopRequireDefault(require("axios")); + +var _nodeSchedule = _interopRequireDefault(require("node-schedule")); + +var _utils = require("./utils"); + +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } + +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } var APPLICATION_ID = 'd89443d2-327c-4a6f-89e5-496bbb0317db'; var DexcomApiClient = function DexcomApiClient(_ref) { var username = _ref.username, - password = _ref.password, - server = _ref.server, - clientOpts = _ref.clientOpts; - var targetServer = - server === 'EU' ? 'shareous1.dexcom.com' : 'share2.dexcom.com'; + password = _ref.password, + server = _ref.server, + clientOpts = _ref.clientOpts; + var targetServer = server === 'EU' ? 'shareous1.dexcom.com' : 'share2.dexcom.com'; var sessionId = null; - var client = _axios['default'].create( - _objectSpread( - { - baseURL: 'https://'.concat(targetServer, '/ShareWebServices/Services'), - headers: { - 'Content-Type': 'application/json', - Accept: 'application/json', - }, - }, - clientOpts - ) - ); - - var login = /*#__PURE__*/ (function () { - var _ref2 = (0, _asyncToGenerator2['default'])( - /*#__PURE__*/ _regenerator['default'].mark(function _callee() { - var payload, responses; - return _regenerator['default'].wrap( - function _callee$(_context) { - while (1) { - switch ((_context.prev = _context.next)) { - case 0: - payload = { - accountName: username, - password: password, - applicationId: APPLICATION_ID, - }; - _context.prev = 1; - _context.next = 4; - return Promise.all([ - client.post( - '/General/AuthenticatePublisherAccount', - payload - ), - client.post( - '/General/LoginPublisherAccountByName', - payload - ), - ]); - - case 4: - responses = _context.sent; - - if ( - !responses.some(function (e) { - return !(0, _utils.validate)(e); - }) - ) { - _context.next = 7; - break; - } + var client = _axios["default"].create(_objectSpread({ + baseURL: "https://".concat(targetServer, "/ShareWebServices/Services"), + headers: { + 'Content-Type': 'application/json', + Accept: 'application/json' + } + }, clientOpts)); + + var login = /*#__PURE__*/function () { + var _ref2 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() { + var payload, responses; + return _regenerator["default"].wrap(function _callee$(_context) { + while (1) { + switch (_context.prev = _context.next) { + case 0: + payload = { + accountName: username, + password: password, + applicationId: APPLICATION_ID + }; + _context.prev = 1; + _context.next = 4; + return Promise.all([client.post('/General/AuthenticatePublisherAccount', payload), client.post('/General/LoginPublisherAccountByName', payload)]); + + case 4: + responses = _context.sent; + + if (!responses.some(function (e) { + return !(0, _utils.validate)(e); + })) { + _context.next = 7; + break; + } - throw new Error('Login failed.'); + throw new Error('Login failed.'); - case 7: - sessionId = responses[1].data; - console.log('Logged in successfully', sessionId); - _context.next = 14; - break; + case 7: + sessionId = responses[1].data; + console.log('Logged in successfully', sessionId); + _context.next = 14; + break; - case 11: - _context.prev = 11; - _context.t0 = _context['catch'](1); - throw new Error('Unable to login in'); + case 11: + _context.prev = 11; + _context.t0 = _context["catch"](1); + throw new Error('Unable to login in'); - case 14: - case 'end': - return _context.stop(); - } - } - }, - _callee, - null, - [[1, 11]] - ); - }) - ); + case 14: + case "end": + return _context.stop(); + } + } + }, _callee, null, [[1, 11]]); + })); return function login() { return _ref2.apply(this, arguments); }; - })(); - - var loginAndTry = /*#__PURE__*/ (function () { - var _ref3 = (0, _asyncToGenerator2['default'])( - /*#__PURE__*/ _regenerator['default'].mark(function _callee2(func) { - var response; - return _regenerator['default'].wrap( - function _callee2$(_context2) { - while (1) { - switch ((_context2.prev = _context2.next)) { - case 0: - response = null; - - if (sessionId) { - _context2.next = 4; - break; - } + }(); + + var loginAndTry = /*#__PURE__*/function () { + var _ref3 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2(func) { + var response; + return _regenerator["default"].wrap(function _callee2$(_context2) { + while (1) { + switch (_context2.prev = _context2.next) { + case 0: + response = null; + + if (sessionId) { + _context2.next = 4; + break; + } - _context2.next = 4; - return login(); + _context2.next = 4; + return login(); - case 4: - _context2.prev = 4; - _context2.next = 7; - return func.apply(null); + case 4: + _context2.prev = 4; + _context2.next = 7; + return func.apply(null); - case 7: - response = _context2.sent; - _context2.next = 17; - break; + case 7: + response = _context2.sent; + _context2.next = 17; + break; - case 10: - _context2.prev = 10; - _context2.t0 = _context2['catch'](4); - _context2.next = 14; - return login(); + case 10: + _context2.prev = 10; + _context2.t0 = _context2["catch"](4); + _context2.next = 14; + return login(); - case 14: - _context2.next = 16; - return func.apply(null); + case 14: + _context2.next = 16; + return func.apply(null); - case 16: - response = _context2.sent; + case 16: + response = _context2.sent; - case 17: - return _context2.abrupt('return', response); + case 17: + return _context2.abrupt("return", response); - case 18: - case 'end': - return _context2.stop(); - } - } - }, - _callee2, - null, - [[4, 10]] - ); - }) - ); + case 18: + case "end": + return _context2.stop(); + } + } + }, _callee2, null, [[4, 10]]); + })); return function loginAndTry(_x) { return _ref3.apply(this, arguments); }; - })(); + }(); - var read = /*#__PURE__*/ (function () { - var _ref4 = (0, _asyncToGenerator2['default'])( - /*#__PURE__*/ _regenerator['default'].mark(function _callee4() { - var minutesAgo, + var read = /*#__PURE__*/function () { + var _ref4 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee4() { + var minutesAgo, count, _args4 = arguments; - return _regenerator['default'].wrap(function _callee4$(_context4) { - while (1) { - switch ((_context4.prev = _context4.next)) { - case 0: - minutesAgo = - _args4.length > 0 && _args4[0] !== undefined - ? _args4[0] - : 1440; - count = - _args4.length > 1 && _args4[1] !== undefined - ? _args4[1] - : 288; - return _context4.abrupt( - 'return', - loginAndTry( - /*#__PURE__*/ (0, _asyncToGenerator2['default'])( - /*#__PURE__*/ _regenerator['default'].mark( - function _callee3() { - var params, response; - return _regenerator['default'].wrap( - function _callee3$(_context3) { - while (1) { - switch ((_context3.prev = _context3.next)) { - case 0: - params = { - sessionId: sessionId, - minutes: minutesAgo, - maxCount: count, - }; - _context3.next = 3; - return client.post( - '/Publisher/ReadPublisherLatestGlucoseValues', - null, - { - params: params, - } - ); - - case 3: - response = _context3.sent; - return _context3.abrupt( - 'return', - response.data.map(_utils.transform) - ); - - case 5: - case 'end': - return _context3.stop(); - } - } - }, - _callee3 - ); - } - ) - ) - ) - ); - - case 3: - case 'end': - return _context4.stop(); - } + return _regenerator["default"].wrap(function _callee4$(_context4) { + while (1) { + switch (_context4.prev = _context4.next) { + case 0: + minutesAgo = _args4.length > 0 && _args4[0] !== undefined ? _args4[0] : 1440; + count = _args4.length > 1 && _args4[1] !== undefined ? _args4[1] : 288; + return _context4.abrupt("return", loginAndTry( /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3() { + var params, response; + return _regenerator["default"].wrap(function _callee3$(_context3) { + while (1) { + switch (_context3.prev = _context3.next) { + case 0: + params = { + sessionId: sessionId, + minutes: minutesAgo, + maxCount: count + }; + _context3.next = 3; + return client.post('/Publisher/ReadPublisherLatestGlucoseValues', null, { + params: params + }); + + case 3: + response = _context3.sent; + return _context3.abrupt("return", response.data.map(_utils.transform)); + + case 5: + case "end": + return _context3.stop(); + } + } + }, _callee3); + })))); + + case 3: + case "end": + return _context4.stop(); } - }, _callee4); - }) - ); + } + }, _callee4); + })); return function read() { return _ref4.apply(this, arguments); }; - })(); - - var readLast = /*#__PURE__*/ (function () { - var _ref6 = (0, _asyncToGenerator2['default'])( - /*#__PURE__*/ _regenerator['default'].mark(function _callee5() { - return _regenerator['default'].wrap(function _callee5$(_context5) { - while (1) { - switch ((_context5.prev = _context5.next)) { - case 0: - return _context5.abrupt('return', read(9999, 1)); - - case 1: - case 'end': - return _context5.stop(); - } + }(); + + var readLast = /*#__PURE__*/function () { + var _ref6 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee5() { + return _regenerator["default"].wrap(function _callee5$(_context5) { + while (1) { + switch (_context5.prev = _context5.next) { + case 0: + return _context5.abrupt("return", read(9999, 1)); + + case 1: + case "end": + return _context5.stop(); } - }, _callee5); - }) - ); + } + }, _callee5); + })); return function readLast() { return _ref6.apply(this, arguments); }; - })(); - - var observe = /*#__PURE__*/ (function () { - var _ref8 = (0, _asyncToGenerator2['default'])( - /*#__PURE__*/ _regenerator['default'].mark(function _callee7(_ref7) { - var _ref7$maxAttempts, - maxAttempts, - _ref7$delay, - delay, - listener, - _yield$readLast, - _yield$readLast2, - data, - rawMinutes, - a, - b, - runPoints, - proc; - - return _regenerator['default'].wrap(function _callee7$(_context7) { - while (1) { - switch ((_context7.prev = _context7.next)) { - case 0: - (_ref7$maxAttempts = _ref7.maxAttempts), - (maxAttempts = - _ref7$maxAttempts === void 0 ? 50 : _ref7$maxAttempts), - (_ref7$delay = _ref7.delay), - (delay = _ref7$delay === void 0 ? 1000 : _ref7$delay), - (listener = _ref7.listener); - _context7.next = 3; - return readLast(); - - case 3: - _yield$readLast = _context7.sent; - _yield$readLast2 = (0, _slicedToArray2['default'])( - _yield$readLast, - 1 - ); - data = _yield$readLast2[0]; - rawMinutes = data.date.getMinutes(); - a = String(rawMinutes).padStart(2, '0')[1]; - b = String(rawMinutes + 5).padStart(2, '0')[1]; - runPoints = ['0', '1', '2', '3', '4', '5'].reduce(function ( - acc, - e - ) { - return [].concat((0, _toConsumableArray2['default'])(acc), [ - e + a, - e + b, - ]); - }, - []); - - proc = function proc() { - var attempt = 0; - var interval = setInterval( - /*#__PURE__*/ (0, _asyncToGenerator2['default'])( - /*#__PURE__*/ _regenerator['default'].mark( - function _callee6() { - var lastCgmData; - return _regenerator['default'].wrap( - function _callee6$(_context6) { - while (1) { - switch ((_context6.prev = _context6.next)) { - case 0: - if (attempt >= maxAttempts) { - clearInterval(interval); - } - - _context6.next = 3; - return read(1, 1); - - case 3: - lastCgmData = _context6.sent; - - if (lastCgmData.length) { - listener.apply(null, [lastCgmData[0]]); - clearInterval(interval); - } - - attempt += 1; - - case 6: - case 'end': - return _context6.stop(); - } - } - }, - _callee6 - ); - } - ) - ), - delay - ); - }; - - return _context7.abrupt( - 'return', - _nodeSchedule['default'].scheduleJob( - ''.concat(runPoints.join(','), ' * * * *'), - proc - ) - ); - - case 12: - case 'end': - return _context7.stop(); - } + }(); + + var observe = /*#__PURE__*/function () { + var _ref8 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee7(_ref7) { + var _ref7$maxAttempts, maxAttempts, _ref7$delay, delay, listener, _yield$readLast, _yield$readLast2, data, rawMinutes, a, b, runPoints, proc; + + return _regenerator["default"].wrap(function _callee7$(_context7) { + while (1) { + switch (_context7.prev = _context7.next) { + case 0: + _ref7$maxAttempts = _ref7.maxAttempts, maxAttempts = _ref7$maxAttempts === void 0 ? 50 : _ref7$maxAttempts, _ref7$delay = _ref7.delay, delay = _ref7$delay === void 0 ? 1000 : _ref7$delay, listener = _ref7.listener; + _context7.next = 3; + return readLast(); + + case 3: + _yield$readLast = _context7.sent; + _yield$readLast2 = (0, _slicedToArray2["default"])(_yield$readLast, 1); + data = _yield$readLast2[0]; + rawMinutes = data.date.getMinutes(); + a = String(rawMinutes).padStart(2, '0')[1]; + b = String(rawMinutes + 5).padStart(2, '0')[1]; + runPoints = ['0', '1', '2', '3', '4', '5'].reduce(function (acc, e) { + return [].concat((0, _toConsumableArray2["default"])(acc), [e + a, e + b]); + }, []); + + proc = function proc() { + var attempt = 0; + var interval = setInterval( /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee6() { + var lastCgmData; + return _regenerator["default"].wrap(function _callee6$(_context6) { + while (1) { + switch (_context6.prev = _context6.next) { + case 0: + if (attempt >= maxAttempts) { + clearInterval(interval); + } + + _context6.next = 3; + return read(1, 1); + + case 3: + lastCgmData = _context6.sent; + + if (lastCgmData.length) { + listener.apply(null, [lastCgmData[0]]); + clearInterval(interval); + } + + attempt += 1; + + case 6: + case "end": + return _context6.stop(); + } + } + }, _callee6); + })), delay); + }; + + return _context7.abrupt("return", _nodeSchedule["default"].scheduleJob("".concat(runPoints.join(','), " * * * *"), proc)); + + case 12: + case "end": + return _context7.stop(); } - }, _callee7); - }) - ); + } + }, _callee7); + })); return function observe(_x2) { return _ref8.apply(this, arguments); }; - })(); + }(); return { login: login, read: read, readLast: readLast, - observe: observe, + observe: observe }; }; exports.DexcomApiClient = DexcomApiClient; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/client.ts"],"names":["APPLICATION_ID","DexcomApiClient","username","password","server","clientOpts","targetServer","sessionId","client","axios","create","baseURL","headers","Accept","login","payload","accountName","applicationId","Promise","all","post","responses","some","e","Error","data","console","log","loginAndTry","func","response","apply","read","minutesAgo","count","params","minutes","maxCount","map","transform","readLast","observe","maxAttempts","delay","listener","rawMinutes","date","getMinutes","a","String","padStart","b","runPoints","reduce","acc","proc","attempt","interval","setInterval","clearInterval","lastCgmData","length","schedule","scheduleJob","join"],"mappings":"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","sourcesContent":["import axios, { AxiosRequestConfig } from 'axios';\nimport schedule from 'node-schedule';\nimport { CGMDataType, transform, validate } from './utils';\n\nconst APPLICATION_ID = 'd89443d2-327c-4a6f-89e5-496bbb0317db';\n\ntype DexcomApiClientType = {\n  username: string;\n  password: string;\n  server: 'US' | 'EU';\n  clientOpts?: AxiosRequestConfig;\n};\n\nexport const DexcomApiClient = ({\n  username,\n  password,\n  server,\n  clientOpts,\n}: DexcomApiClientType) => {\n  const targetServer =\n    server === 'EU' ? 'shareous1.dexcom.com' : 'share2.dexcom.com';\n  let sessionId: string | null = null;\n\n  const client = axios.create({\n    baseURL: `https://${targetServer}/ShareWebServices/Services`,\n    headers: {\n      'Content-Type': 'application/json',\n      Accept: 'application/json',\n    },\n    ...clientOpts,\n  });\n\n  const login = async () => {\n    const payload = {\n      accountName: username,\n      password,\n      applicationId: APPLICATION_ID,\n    };\n\n    try {\n      const responses = await Promise.all([\n        client.post('/General/AuthenticatePublisherAccount', payload),\n        client.post('/General/LoginPublisherAccountByName', payload),\n      ]);\n\n      if (responses.some(e => !validate(e))) {\n        throw new Error('Login failed.');\n      }\n\n      sessionId = responses[1].data;\n\n      console.log('Logged in successfully', sessionId);\n    } catch (e) {\n      throw new Error('Unable to login in');\n    }\n  };\n\n  const loginAndTry = async <T>(func: () => Promise<T> | T) => {\n    let response = null;\n\n    if (!sessionId) await login();\n\n    try {\n      response = await func.apply(null);\n    } catch (e) {\n      await login();\n\n      response = await func.apply(null);\n    }\n\n    return response;\n  };\n\n  const read = async (minutesAgo = 1440, count = 288): Promise<CGMDataType[]> =>\n    loginAndTry<CGMDataType[]>(async () => {\n      const params = {\n        sessionId,\n        minutes: minutesAgo,\n        maxCount: count,\n      };\n\n      const response = await client.post(\n        '/Publisher/ReadPublisherLatestGlucoseValues',\n        null,\n        { params }\n      );\n\n      return response.data.map(transform);\n    });\n\n  const readLast = async () => read(9999, 1);\n\n  type ObserverInputType = {\n    maxAttempts?: number;\n    delay?: number;\n    listener: (data: CGMDataType) => void;\n  };\n  const observe = async ({\n    maxAttempts = 50,\n    delay = 1000,\n    listener,\n  }: ObserverInputType) => {\n    const [data] = await readLast();\n    const rawMinutes = data.date.getMinutes();\n    const a = String(rawMinutes).padStart(2, '0')[1];\n    const b = String(rawMinutes + 5).padStart(2, '0')[1];\n    const runPoints = ['0', '1', '2', '3', '4', '5'].reduce<string[]>(\n      (acc, e) => [...acc, e + a, e + b],\n      []\n    );\n    const proc = () => {\n      let attempt = 0;\n      const interval = setInterval(async () => {\n        if (attempt >= maxAttempts) {\n          clearInterval(interval);\n        }\n\n        const lastCgmData = await read(1, 1);\n\n        if (lastCgmData.length) {\n          listener.apply(null, [lastCgmData[0]]);\n          clearInterval(interval);\n        }\n        attempt += 1;\n      }, delay);\n    };\n\n    return schedule.scheduleJob(`${runPoints.join(',')} * * * *`, proc);\n  };\n  return {\n    login,\n    read,\n    readLast,\n    observe,\n  };\n};\n"]} +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/client.ts"],"names":["APPLICATION_ID","DexcomApiClient","username","password","server","clientOpts","targetServer","sessionId","client","axios","create","baseURL","headers","Accept","login","payload","accountName","applicationId","Promise","all","post","responses","some","e","Error","data","console","log","loginAndTry","func","response","apply","read","minutesAgo","count","params","minutes","maxCount","map","transform","readLast","observe","maxAttempts","delay","listener","rawMinutes","date","getMinutes","a","String","padStart","b","runPoints","reduce","acc","proc","attempt","interval","setInterval","clearInterval","lastCgmData","length","schedule","scheduleJob","join"],"mappings":"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","sourcesContent":["import axios, { AxiosRequestConfig } from 'axios';\nimport schedule from 'node-schedule';\nimport { CGMDataType, transform, validate } from './utils';\n\nconst APPLICATION_ID = 'd89443d2-327c-4a6f-89e5-496bbb0317db';\n\ntype DexcomApiClientType = {\n  username: string;\n  password: string;\n  server: 'US' | 'EU';\n  clientOpts?: AxiosRequestConfig;\n};\n\nexport const DexcomApiClient = ({\n  username,\n  password,\n  server,\n  clientOpts,\n}: DexcomApiClientType) => {\n  const targetServer =\n    server === 'EU' ? 'shareous1.dexcom.com' : 'share2.dexcom.com';\n  let sessionId: string | null = null;\n\n  const client = axios.create({\n    baseURL: `https://${targetServer}/ShareWebServices/Services`,\n    headers: {\n      'Content-Type': 'application/json',\n      Accept: 'application/json',\n    },\n    ...clientOpts,\n  });\n\n  const login = async () => {\n    const payload = {\n      accountName: username,\n      password,\n      applicationId: APPLICATION_ID,\n    };\n\n    try {\n      const responses = await Promise.all([\n        client.post('/General/AuthenticatePublisherAccount', payload),\n        client.post('/General/LoginPublisherAccountByName', payload),\n      ]);\n\n      if (responses.some(e => !validate(e))) {\n        throw new Error('Login failed.');\n      }\n\n      sessionId = responses[1].data;\n\n      console.log('Logged in successfully', sessionId);\n    } catch (e) {\n      throw new Error('Unable to login in');\n    }\n  };\n\n  const loginAndTry = async <T>(func: () => Promise<T> | T) => {\n    let response = null;\n\n    if (!sessionId) await login();\n\n    try {\n      response = await func.apply(null);\n    } catch (e) {\n      await login();\n\n      response = await func.apply(null);\n    }\n\n    return response;\n  };\n\n  const read = async (minutesAgo = 1440, count = 288): Promise<CGMDataType[]> =>\n    loginAndTry<CGMDataType[]>(async () => {\n      const params = {\n        sessionId,\n        minutes: minutesAgo,\n        maxCount: count,\n      };\n\n      const response = await client.post(\n        '/Publisher/ReadPublisherLatestGlucoseValues',\n        null,\n        { params }\n      );\n\n      return response.data.map(transform);\n    });\n\n  const readLast = async () => read(9999, 1);\n\n  type ObserverInputType = {\n    maxAttempts?: number;\n    delay?: number;\n    listener: (data: CGMDataType) => void;\n  };\n  const observe = async ({\n    maxAttempts = 50,\n    delay = 1000,\n    listener,\n  }: ObserverInputType) => {\n    const [data] = await readLast();\n    const rawMinutes = data.date.getMinutes();\n    const a = String(rawMinutes).padStart(2, '0')[1];\n    const b = String(rawMinutes + 5).padStart(2, '0')[1];\n    const runPoints = ['0', '1', '2', '3', '4', '5'].reduce<string[]>(\n      (acc, e) => [...acc, e + a, e + b],\n      []\n    );\n    const proc = () => {\n      let attempt = 0;\n      const interval = setInterval(async () => {\n        if (attempt >= maxAttempts) {\n          clearInterval(interval);\n        }\n\n        const lastCgmData = await read(1, 1);\n\n        if (lastCgmData.length) {\n          listener.apply(null, [lastCgmData[0]]);\n          clearInterval(interval);\n        }\n        attempt += 1;\n      }, delay);\n    };\n\n    return schedule.scheduleJob(`${runPoints.join(',')} * * * *`, proc);\n  };\n  return {\n    login,\n    read,\n    readLast,\n    observe,\n  };\n};\n"]} \ No newline at end of file diff --git a/lib/index.js b/lib/index.js index 810ce1a..759bb49 100644 --- a/lib/index.js +++ b/lib/index.js @@ -1,19 +1,19 @@ -'use strict'; +"use strict"; -Object.defineProperty(exports, '__esModule', { - value: true, +Object.defineProperty(exports, "__esModule", { + value: true }); -var _client = require('./client'); +var _client = require("./client"); Object.keys(_client).forEach(function (key) { - if (key === 'default' || key === '__esModule') return; + if (key === "default" || key === "__esModule") return; if (key in exports && exports[key] === _client[key]) return; Object.defineProperty(exports, key, { enumerable: true, get: function get() { return _client[key]; - }, + } }); }); -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY2xpZW50JztcbiJdfQ== +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY2xpZW50JztcbiJdfQ== \ No newline at end of file diff --git a/lib/utils.d.ts b/lib/utils.d.ts index d162440..5c67dbb 100644 --- a/lib/utils.d.ts +++ b/lib/utils.d.ts @@ -1,23 +1,16 @@ import { AxiosResponse } from 'axios'; -declare type DexcomTrendType = - | 'DoubleDown' - | 'SingleDown' - | 'FortyFiveDown' - | 'Flat' - | 'FortyFiveUp' - | 'SingleUp' - | 'DoubleUp'; +declare type DexcomTrendType = 'DoubleDown' | 'SingleDown' | 'FortyFiveDown' | 'Flat' | 'FortyFiveUp' | 'SingleUp' | 'DoubleUp'; declare type DexcomDataType = { - WT: string; - ST: string; - DT: string; - Value: number; - Trend: DexcomTrendType; + WT: string; + ST: string; + DT: string; + Value: number; + Trend: DexcomTrendType; }; export declare type CGMDataType = { - date: Date; - value: number; - trend: DexcomTrendType; + date: Date; + value: number; + trend: DexcomTrendType; }; export declare const transform: (input: DexcomDataType) => CGMDataType; export declare const validate: (payload: AxiosResponse) => boolean; diff --git a/lib/utils.js b/lib/utils.js index 463dee6..132581c 100644 --- a/lib/utils.js +++ b/lib/utils.js @@ -1,7 +1,7 @@ -'use strict'; +"use strict"; -Object.defineProperty(exports, '__esModule', { - value: true, +Object.defineProperty(exports, "__esModule", { + value: true }); exports.validate = exports.transform = void 0; @@ -15,7 +15,7 @@ var transform = function transform(input) { return { date: new Date(parseInt(parsedDate[1], 10)), value: input.Value, - trend: input.Trend, + trend: input.Trend }; }; @@ -26,4 +26,4 @@ var validate = function validate(payload) { }; exports.validate = validate; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy91dGlscy50cyJdLCJuYW1lcyI6WyJ0cmFuc2Zvcm0iLCJpbnB1dCIsInBhcnNlZERhdGUiLCJXVCIsIm1hdGNoIiwiQXJyYXkiLCJpc0FycmF5IiwiRXJyb3IiLCJkYXRlIiwiRGF0ZSIsInBhcnNlSW50IiwidmFsdWUiLCJWYWx1ZSIsInRyZW5kIiwiVHJlbmQiLCJ2YWxpZGF0ZSIsInBheWxvYWQiLCJkYXRhIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBdUJPLElBQU1BLFNBQVMsR0FBRyxTQUFaQSxTQUFZLENBQUNDLEtBQUQsRUFBd0M7QUFDL0QsTUFBTUMsVUFBVSxHQUFHRCxLQUFLLENBQUNFLEVBQU4sQ0FBU0MsS0FBVCxDQUFlLGtCQUFmLENBQW5COztBQUVBLE1BQUksQ0FBQ0YsVUFBRCxJQUFlLENBQUNHLEtBQUssQ0FBQ0MsT0FBTixDQUFjSixVQUFkLENBQWhCLElBQTZDLENBQUNBLFVBQVUsQ0FBQyxDQUFELENBQTVELEVBQWlFO0FBQy9ELFVBQU0sSUFBSUssS0FBSixDQUFVLCtCQUFWLENBQU47QUFDRDs7QUFFRCxTQUFPO0FBQ0xDLElBQUFBLElBQUksRUFBRSxJQUFJQyxJQUFKLENBQVNDLFFBQVEsQ0FBQ1IsVUFBVSxDQUFDLENBQUQsQ0FBWCxFQUFnQixFQUFoQixDQUFqQixDQUREO0FBRUxTLElBQUFBLEtBQUssRUFBRVYsS0FBSyxDQUFDVyxLQUZSO0FBR0xDLElBQUFBLEtBQUssRUFBRVosS0FBSyxDQUFDYTtBQUhSLEdBQVA7QUFLRCxDQVpNOzs7O0FBY0EsSUFBTUMsUUFBUSxHQUFHLFNBQVhBLFFBQVcsQ0FBQ0MsT0FBRDtBQUFBLFNBQ3RCQSxPQUFPLENBQUNDLElBQVIsS0FBaUIsc0NBREs7QUFBQSxDQUFqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEF4aW9zUmVzcG9uc2UgfSBmcm9tICdheGlvcyc7XG5cbnR5cGUgRGV4Y29tVHJlbmRUeXBlID1cbiAgfCAnRG91YmxlRG93bidcbiAgfCAnU2luZ2xlRG93bidcbiAgfCAnRm9ydHlGaXZlRG93bidcbiAgfCAnRmxhdCdcbiAgfCAnRm9ydHlGaXZlVXAnXG4gIHwgJ1NpbmdsZVVwJ1xuICB8ICdEb3VibGVVcCc7XG50eXBlIERleGNvbURhdGFUeXBlID0ge1xuICBXVDogc3RyaW5nO1xuICBTVDogc3RyaW5nO1xuICBEVDogc3RyaW5nO1xuICBWYWx1ZTogbnVtYmVyO1xuICBUcmVuZDogRGV4Y29tVHJlbmRUeXBlO1xufTtcblxuZXhwb3J0IHR5cGUgQ0dNRGF0YVR5cGUgPSB7XG4gIGRhdGU6IERhdGU7XG4gIHZhbHVlOiBudW1iZXI7XG4gIHRyZW5kOiBEZXhjb21UcmVuZFR5cGU7XG59O1xuZXhwb3J0IGNvbnN0IHRyYW5zZm9ybSA9IChpbnB1dDogRGV4Y29tRGF0YVR5cGUpOiBDR01EYXRhVHlwZSA9PiB7XG4gIGNvbnN0IHBhcnNlZERhdGUgPSBpbnB1dC5XVC5tYXRjaCgvRGF0ZVxcKChbMC05XSopXFwpLyk7XG5cbiAgaWYgKCFwYXJzZWREYXRlIHx8ICFBcnJheS5pc0FycmF5KHBhcnNlZERhdGUpIHx8ICFwYXJzZWREYXRlWzFdKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdVbmFibGUgdG8gcGFyc2UgZGV4Y29tIG9iamVjdCcpO1xuICB9XG5cbiAgcmV0dXJuIHtcbiAgICBkYXRlOiBuZXcgRGF0ZShwYXJzZUludChwYXJzZWREYXRlWzFdLCAxMCkpLFxuICAgIHZhbHVlOiBpbnB1dC5WYWx1ZSxcbiAgICB0cmVuZDogaW5wdXQuVHJlbmQsXG4gIH07XG59O1xuXG5leHBvcnQgY29uc3QgdmFsaWRhdGUgPSAocGF5bG9hZDogQXhpb3NSZXNwb25zZSkgPT5cbiAgcGF5bG9hZC5kYXRhICE9PSAnMDAwMDAwMDAtMDAwMC0wMDAwLTAwMDAtMDAwMDAwMDAwMDAwJztcbiJdfQ== +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy91dGlscy50cyJdLCJuYW1lcyI6WyJ0cmFuc2Zvcm0iLCJpbnB1dCIsInBhcnNlZERhdGUiLCJXVCIsIm1hdGNoIiwiQXJyYXkiLCJpc0FycmF5IiwiRXJyb3IiLCJkYXRlIiwiRGF0ZSIsInBhcnNlSW50IiwidmFsdWUiLCJWYWx1ZSIsInRyZW5kIiwiVHJlbmQiLCJ2YWxpZGF0ZSIsInBheWxvYWQiLCJkYXRhIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBdUJPLElBQU1BLFNBQVMsR0FBRyxTQUFaQSxTQUFZLENBQUNDLEtBQUQsRUFBd0M7QUFDL0QsTUFBTUMsVUFBVSxHQUFHRCxLQUFLLENBQUNFLEVBQU4sQ0FBU0MsS0FBVCxDQUFlLGtCQUFmLENBQW5COztBQUVBLE1BQUksQ0FBQ0YsVUFBRCxJQUFlLENBQUNHLEtBQUssQ0FBQ0MsT0FBTixDQUFjSixVQUFkLENBQWhCLElBQTZDLENBQUNBLFVBQVUsQ0FBQyxDQUFELENBQTVELEVBQWlFO0FBQy9ELFVBQU0sSUFBSUssS0FBSixDQUFVLCtCQUFWLENBQU47QUFDRDs7QUFFRCxTQUFPO0FBQ0xDLElBQUFBLElBQUksRUFBRSxJQUFJQyxJQUFKLENBQVNDLFFBQVEsQ0FBQ1IsVUFBVSxDQUFDLENBQUQsQ0FBWCxFQUFnQixFQUFoQixDQUFqQixDQUREO0FBRUxTLElBQUFBLEtBQUssRUFBRVYsS0FBSyxDQUFDVyxLQUZSO0FBR0xDLElBQUFBLEtBQUssRUFBRVosS0FBSyxDQUFDYTtBQUhSLEdBQVA7QUFLRCxDQVpNOzs7O0FBY0EsSUFBTUMsUUFBUSxHQUFHLFNBQVhBLFFBQVcsQ0FBQ0MsT0FBRDtBQUFBLFNBQ3RCQSxPQUFPLENBQUNDLElBQVIsS0FBaUIsc0NBREs7QUFBQSxDQUFqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEF4aW9zUmVzcG9uc2UgfSBmcm9tICdheGlvcyc7XG5cbnR5cGUgRGV4Y29tVHJlbmRUeXBlID1cbiAgfCAnRG91YmxlRG93bidcbiAgfCAnU2luZ2xlRG93bidcbiAgfCAnRm9ydHlGaXZlRG93bidcbiAgfCAnRmxhdCdcbiAgfCAnRm9ydHlGaXZlVXAnXG4gIHwgJ1NpbmdsZVVwJ1xuICB8ICdEb3VibGVVcCc7XG50eXBlIERleGNvbURhdGFUeXBlID0ge1xuICBXVDogc3RyaW5nO1xuICBTVDogc3RyaW5nO1xuICBEVDogc3RyaW5nO1xuICBWYWx1ZTogbnVtYmVyO1xuICBUcmVuZDogRGV4Y29tVHJlbmRUeXBlO1xufTtcblxuZXhwb3J0IHR5cGUgQ0dNRGF0YVR5cGUgPSB7XG4gIGRhdGU6IERhdGU7XG4gIHZhbHVlOiBudW1iZXI7XG4gIHRyZW5kOiBEZXhjb21UcmVuZFR5cGU7XG59O1xuZXhwb3J0IGNvbnN0IHRyYW5zZm9ybSA9IChpbnB1dDogRGV4Y29tRGF0YVR5cGUpOiBDR01EYXRhVHlwZSA9PiB7XG4gIGNvbnN0IHBhcnNlZERhdGUgPSBpbnB1dC5XVC5tYXRjaCgvRGF0ZVxcKChbMC05XSopXFwpLyk7XG5cbiAgaWYgKCFwYXJzZWREYXRlIHx8ICFBcnJheS5pc0FycmF5KHBhcnNlZERhdGUpIHx8ICFwYXJzZWREYXRlWzFdKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdVbmFibGUgdG8gcGFyc2UgZGV4Y29tIG9iamVjdCcpO1xuICB9XG5cbiAgcmV0dXJuIHtcbiAgICBkYXRlOiBuZXcgRGF0ZShwYXJzZUludChwYXJzZWREYXRlWzFdLCAxMCkpLFxuICAgIHZhbHVlOiBpbnB1dC5WYWx1ZSxcbiAgICB0cmVuZDogaW5wdXQuVHJlbmQsXG4gIH07XG59O1xuXG5leHBvcnQgY29uc3QgdmFsaWRhdGUgPSAocGF5bG9hZDogQXhpb3NSZXNwb25zZSkgPT5cbiAgcGF5bG9hZC5kYXRhICE9PSAnMDAwMDAwMDAtMDAwMC0wMDAwLTAwMDAtMDAwMDAwMDAwMDAwJztcbiJdfQ== \ No newline at end of file diff --git a/package-lock.json b/package-lock.json index eeb2215..0d2cd0a 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,12 +1,12 @@ { "name": "@diakem/dexcom-api-client", - "version": "0.1.1", + "version": "0.1.2", "lockfileVersion": 2, "requires": true, "packages": { "": { "name": "@diakem/dexcom-api-client", - "version": "0.1.1", + "version": "0.1.2", "license": "MIT", "dependencies": { "axios": "^0.26.1", diff --git a/package.json b/package.json index b59cf24..47338e5 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@diakem/dexcom-api-client", - "version": "0.1.1", + "version": "0.1.2", "description": "Dexcom API client to communicate and retrieve data from the sharing service.", "main": "lib/index.js", "types": "./lib/index.d.ts",