keez-invoicing 1.1.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (111) hide show
  1. package/LICENSE +28 -0
  2. package/README.md +366 -0
  3. package/dist/coverage/lcov-report/block-navigation.js +71 -0
  4. package/dist/coverage/lcov-report/prettify.js +478 -0
  5. package/dist/coverage/lcov-report/sorter.js +177 -0
  6. package/dist/eslint.config.js +56 -0
  7. package/dist/jest.config.cjs +13 -0
  8. package/dist/jest.config.js +13 -0
  9. package/dist/src/api/__tests__/index.test.js +52 -0
  10. package/dist/src/api/authorise.js +48 -0
  11. package/dist/src/api/invoices/cancel.js +33 -0
  12. package/dist/src/api/invoices/create.js +97 -0
  13. package/dist/src/api/invoices/delete.js +33 -0
  14. package/dist/src/api/invoices/downloadPdf.js +31 -0
  15. package/dist/src/api/invoices/getAll.js +84 -0
  16. package/dist/src/api/invoices/sendMail.js +59 -0
  17. package/dist/src/api/invoices/submitEfactura.js +34 -0
  18. package/dist/src/api/invoices/update.js +61 -0
  19. package/dist/src/api/invoices/validate.js +39 -0
  20. package/dist/src/api/invoices/view.js +93 -0
  21. package/dist/src/api/items/create.js +42 -0
  22. package/dist/src/api/items/getAll.js +74 -0
  23. package/dist/src/api/items/getById.js +46 -0
  24. package/dist/src/api/items/index.js +14 -0
  25. package/dist/src/api/items/patch.js +49 -0
  26. package/dist/src/api/items/update.js +41 -0
  27. package/dist/src/config/constants.js +23 -0
  28. package/dist/src/config/constructorParam.js +3 -0
  29. package/dist/src/config/measureUnit.js +22 -0
  30. package/dist/src/config/paymentType.js +17 -0
  31. package/dist/src/config/paymentType.js.js +16 -0
  32. package/dist/src/dto/allInvoicesResponse.js +3 -0
  33. package/dist/src/dto/authResponse.js +3 -0
  34. package/dist/src/dto/common/index.js +3 -0
  35. package/dist/src/dto/common/paginationParams.js +3 -0
  36. package/dist/src/dto/createInvoiceRequest.js +3 -0
  37. package/dist/src/dto/invoiceResponse.js +3 -0
  38. package/dist/src/dto/invoices/index.js +3 -0
  39. package/dist/src/dto/invoices/invoiceFilterParams.js +3 -0
  40. package/dist/src/dto/invoices/invoiceRequestV2.js +3 -0
  41. package/dist/src/dto/invoices/sendInvoiceParams.js +3 -0
  42. package/dist/src/dto/items/allItemsResponse.js +3 -0
  43. package/dist/src/dto/items/index.js +3 -0
  44. package/dist/src/dto/items/itemRequest.js +3 -0
  45. package/dist/src/dto/items/itemResponse.js +3 -0
  46. package/dist/src/errors/KeezError.js +27 -0
  47. package/dist/src/helpers/logger.js +15 -0
  48. package/dist/src/index.js +15 -0
  49. package/dist/src/keezApi.js +283 -0
  50. package/dist/tests/additional-coverage.test.js +351 -0
  51. package/dist/tests/edge-cases.test.js +353 -0
  52. package/dist/tests/error-handling.test.js +224 -0
  53. package/dist/tests/filter-params.test.js +267 -0
  54. package/dist/tests/index.test.js +493 -0
  55. package/dist/tests/invoices-extended.test.js +168 -0
  56. package/dist/tests/items.test.js +142 -0
  57. package/dist/types/coverage/lcov-report/block-navigation.d.ts +1 -0
  58. package/dist/types/coverage/lcov-report/prettify.d.ts +0 -0
  59. package/dist/types/coverage/lcov-report/sorter.d.ts +1 -0
  60. package/dist/types/eslint.config.d.ts +2 -0
  61. package/dist/types/jest.config.d.cts +9 -0
  62. package/dist/types/jest.config.d.ts +9 -0
  63. package/dist/types/src/api/__tests__/index.test.d.ts +1 -0
  64. package/dist/types/src/api/authorise.d.ts +18 -0
  65. package/dist/types/src/api/invoices/cancel.d.ts +9 -0
  66. package/dist/types/src/api/invoices/create.d.ts +22 -0
  67. package/dist/types/src/api/invoices/delete.d.ts +9 -0
  68. package/dist/types/src/api/invoices/downloadPdf.d.ts +8 -0
  69. package/dist/types/src/api/invoices/getAll.d.ts +22 -0
  70. package/dist/types/src/api/invoices/sendMail.d.ts +24 -0
  71. package/dist/types/src/api/invoices/submitEfactura.d.ts +9 -0
  72. package/dist/types/src/api/invoices/update.d.ts +11 -0
  73. package/dist/types/src/api/invoices/validate.d.ts +21 -0
  74. package/dist/types/src/api/invoices/view.d.ts +22 -0
  75. package/dist/types/src/api/items/create.d.ts +10 -0
  76. package/dist/types/src/api/items/getAll.d.ts +10 -0
  77. package/dist/types/src/api/items/getById.d.ts +10 -0
  78. package/dist/types/src/api/items/index.d.ts +5 -0
  79. package/dist/types/src/api/items/patch.d.ts +11 -0
  80. package/dist/types/src/api/items/update.d.ts +11 -0
  81. package/dist/types/src/config/constants.d.ts +13 -0
  82. package/dist/types/src/config/constructorParam.d.ts +6 -0
  83. package/dist/types/src/config/measureUnit.d.ts +17 -0
  84. package/dist/types/src/config/paymentType.d.ts +12 -0
  85. package/dist/types/src/config/paymentType.js.d.ts +11 -0
  86. package/dist/types/src/dto/allInvoicesResponse.d.ts +21 -0
  87. package/dist/types/src/dto/authResponse.d.ts +7 -0
  88. package/dist/types/src/dto/common/index.d.ts +1 -0
  89. package/dist/types/src/dto/common/paginationParams.d.ts +4 -0
  90. package/dist/types/src/dto/createInvoiceRequest.d.ts +34 -0
  91. package/dist/types/src/dto/invoiceResponse.d.ts +48 -0
  92. package/dist/types/src/dto/invoices/index.d.ts +3 -0
  93. package/dist/types/src/dto/invoices/invoiceFilterParams.d.ts +8 -0
  94. package/dist/types/src/dto/invoices/invoiceRequestV2.d.ts +23 -0
  95. package/dist/types/src/dto/invoices/sendInvoiceParams.d.ts +5 -0
  96. package/dist/types/src/dto/items/allItemsResponse.d.ts +13 -0
  97. package/dist/types/src/dto/items/index.d.ts +3 -0
  98. package/dist/types/src/dto/items/itemRequest.d.ts +34 -0
  99. package/dist/types/src/dto/items/itemResponse.d.ts +15 -0
  100. package/dist/types/src/errors/KeezError.d.ts +11 -0
  101. package/dist/types/src/helpers/logger.d.ts +2 -0
  102. package/dist/types/src/index.d.ts +11 -0
  103. package/dist/types/src/keezApi.d.ts +114 -0
  104. package/dist/types/tests/additional-coverage.test.d.ts +1 -0
  105. package/dist/types/tests/edge-cases.test.d.ts +1 -0
  106. package/dist/types/tests/error-handling.test.d.ts +1 -0
  107. package/dist/types/tests/filter-params.test.d.ts +1 -0
  108. package/dist/types/tests/index.test.d.ts +1 -0
  109. package/dist/types/tests/invoices-extended.test.d.ts +1 -0
  110. package/dist/types/tests/items.test.d.ts +1 -0
  111. package/package.json +66 -0
@@ -0,0 +1,177 @@
1
+ "use strict";
2
+ /* eslint-disable */
3
+ var addSorting = (function () {
4
+ 'use strict';
5
+ var cols, currentSort = {
6
+ index: 0,
7
+ desc: false
8
+ };
9
+ // returns the summary table element
10
+ function getTable() {
11
+ return document.querySelector('.coverage-summary');
12
+ }
13
+ // returns the thead element of the summary table
14
+ function getTableHeader() {
15
+ return getTable().querySelector('thead tr');
16
+ }
17
+ // returns the tbody element of the summary table
18
+ function getTableBody() {
19
+ return getTable().querySelector('tbody');
20
+ }
21
+ // returns the th element for nth column
22
+ function getNthColumn(n) {
23
+ return getTableHeader().querySelectorAll('th')[n];
24
+ }
25
+ function onFilterInput() {
26
+ const searchValue = document.getElementById('fileSearch').value;
27
+ const rows = document.getElementsByTagName('tbody')[0].children;
28
+ // Try to create a RegExp from the searchValue. If it fails (invalid regex),
29
+ // it will be treated as a plain text search
30
+ let searchRegex;
31
+ try {
32
+ searchRegex = new RegExp(searchValue, 'i'); // 'i' for case-insensitive
33
+ }
34
+ catch (error) {
35
+ searchRegex = null;
36
+ }
37
+ for (let i = 0; i < rows.length; i++) {
38
+ const row = rows[i];
39
+ let isMatch = false;
40
+ if (searchRegex) {
41
+ // If a valid regex was created, use it for matching
42
+ isMatch = searchRegex.test(row.textContent);
43
+ }
44
+ else {
45
+ // Otherwise, fall back to the original plain text search
46
+ isMatch = row.textContent
47
+ .toLowerCase()
48
+ .includes(searchValue.toLowerCase());
49
+ }
50
+ row.style.display = isMatch ? '' : 'none';
51
+ }
52
+ }
53
+ // loads the search box
54
+ function addSearchBox() {
55
+ var template = document.getElementById('filterTemplate');
56
+ var templateClone = template.content.cloneNode(true);
57
+ templateClone.getElementById('fileSearch').oninput = onFilterInput;
58
+ template.parentElement.appendChild(templateClone);
59
+ }
60
+ // loads all columns
61
+ function loadColumns() {
62
+ var colNodes = getTableHeader().querySelectorAll('th'), colNode, cols = [], col, i;
63
+ for (i = 0; i < colNodes.length; i += 1) {
64
+ colNode = colNodes[i];
65
+ col = {
66
+ key: colNode.getAttribute('data-col'),
67
+ sortable: !colNode.getAttribute('data-nosort'),
68
+ type: colNode.getAttribute('data-type') || 'string'
69
+ };
70
+ cols.push(col);
71
+ if (col.sortable) {
72
+ col.defaultDescSort = col.type === 'number';
73
+ colNode.innerHTML =
74
+ colNode.innerHTML + '<span class="sorter"></span>';
75
+ }
76
+ }
77
+ return cols;
78
+ }
79
+ // attaches a data attribute to every tr element with an object
80
+ // of data values keyed by column name
81
+ function loadRowData(tableRow) {
82
+ var tableCols = tableRow.querySelectorAll('td'), colNode, col, data = {}, i, val;
83
+ for (i = 0; i < tableCols.length; i += 1) {
84
+ colNode = tableCols[i];
85
+ col = cols[i];
86
+ val = colNode.getAttribute('data-value');
87
+ if (col.type === 'number') {
88
+ val = Number(val);
89
+ }
90
+ data[col.key] = val;
91
+ }
92
+ return data;
93
+ }
94
+ // loads all row data
95
+ function loadData() {
96
+ var rows = getTableBody().querySelectorAll('tr'), i;
97
+ for (i = 0; i < rows.length; i += 1) {
98
+ rows[i].data = loadRowData(rows[i]);
99
+ }
100
+ }
101
+ // sorts the table using the data for the ith column
102
+ function sortByIndex(index, desc) {
103
+ var key = cols[index].key, sorter = function (a, b) {
104
+ a = a.data[key];
105
+ b = b.data[key];
106
+ return a < b ? -1 : a > b ? 1 : 0;
107
+ }, finalSorter = sorter, tableBody = document.querySelector('.coverage-summary tbody'), rowNodes = tableBody.querySelectorAll('tr'), rows = [], i;
108
+ if (desc) {
109
+ finalSorter = function (a, b) {
110
+ return -1 * sorter(a, b);
111
+ };
112
+ }
113
+ for (i = 0; i < rowNodes.length; i += 1) {
114
+ rows.push(rowNodes[i]);
115
+ tableBody.removeChild(rowNodes[i]);
116
+ }
117
+ rows.sort(finalSorter);
118
+ for (i = 0; i < rows.length; i += 1) {
119
+ tableBody.appendChild(rows[i]);
120
+ }
121
+ }
122
+ // removes sort indicators for current column being sorted
123
+ function removeSortIndicators() {
124
+ var col = getNthColumn(currentSort.index), cls = col.className;
125
+ cls = cls.replace(/ sorted$/, '').replace(/ sorted-desc$/, '');
126
+ col.className = cls;
127
+ }
128
+ // adds sort indicators for current column being sorted
129
+ function addSortIndicators() {
130
+ getNthColumn(currentSort.index).className += currentSort.desc
131
+ ? ' sorted-desc'
132
+ : ' sorted';
133
+ }
134
+ // adds event listeners for all sorter widgets
135
+ function enableUI() {
136
+ var i, el, ithSorter = function ithSorter(i) {
137
+ var col = cols[i];
138
+ return function () {
139
+ var desc = col.defaultDescSort;
140
+ if (currentSort.index === i) {
141
+ desc = !currentSort.desc;
142
+ }
143
+ sortByIndex(i, desc);
144
+ removeSortIndicators();
145
+ currentSort.index = i;
146
+ currentSort.desc = desc;
147
+ addSortIndicators();
148
+ };
149
+ };
150
+ for (i = 0; i < cols.length; i += 1) {
151
+ if (cols[i].sortable) {
152
+ // add the click event handler on the th so users
153
+ // dont have to click on those tiny arrows
154
+ el = getNthColumn(i).querySelector('.sorter').parentElement;
155
+ if (el.addEventListener) {
156
+ el.addEventListener('click', ithSorter(i));
157
+ }
158
+ else {
159
+ el.attachEvent('onclick', ithSorter(i));
160
+ }
161
+ }
162
+ }
163
+ }
164
+ // adds sorting functionality to the UI
165
+ return function () {
166
+ if (!getTable()) {
167
+ return;
168
+ }
169
+ cols = loadColumns();
170
+ loadData();
171
+ addSearchBox();
172
+ addSortIndicators();
173
+ enableUI();
174
+ };
175
+ })();
176
+ window.addEventListener('load', addSorting);
177
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sorter.js","sourceRoot":"","sources":["../../../coverage/lcov-report/sorter.js"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable */\nvar addSorting = (function() {\n    'use strict';\n    var cols,\n        currentSort = {\n            index: 0,\n            desc: false\n        };\n\n    // returns the summary table element\n    function getTable() {\n        return document.querySelector('.coverage-summary');\n    }\n    // returns the thead element of the summary table\n    function getTableHeader() {\n        return getTable().querySelector('thead tr');\n    }\n    // returns the tbody element of the summary table\n    function getTableBody() {\n        return getTable().querySelector('tbody');\n    }\n    // returns the th element for nth column\n    function getNthColumn(n) {\n        return getTableHeader().querySelectorAll('th')[n];\n    }\n\n    function onFilterInput() {\n        const searchValue = document.getElementById('fileSearch').value;\n        const rows = document.getElementsByTagName('tbody')[0].children;\n\n        // Try to create a RegExp from the searchValue. If it fails (invalid regex),\n        // it will be treated as a plain text search\n        let searchRegex;\n        try {\n            searchRegex = new RegExp(searchValue, 'i'); // 'i' for case-insensitive\n        } catch (error) {\n            searchRegex = null;\n        }\n\n        for (let i = 0; i < rows.length; i++) {\n            const row = rows[i];\n            let isMatch = false;\n\n            if (searchRegex) {\n                // If a valid regex was created, use it for matching\n                isMatch = searchRegex.test(row.textContent);\n            } else {\n                // Otherwise, fall back to the original plain text search\n                isMatch = row.textContent\n                    .toLowerCase()\n                    .includes(searchValue.toLowerCase());\n            }\n\n            row.style.display = isMatch ? '' : 'none';\n        }\n    }\n\n    // loads the search box\n    function addSearchBox() {\n        var template = document.getElementById('filterTemplate');\n        var templateClone = template.content.cloneNode(true);\n        templateClone.getElementById('fileSearch').oninput = onFilterInput;\n        template.parentElement.appendChild(templateClone);\n    }\n\n    // loads all columns\n    function loadColumns() {\n        var colNodes = getTableHeader().querySelectorAll('th'),\n            colNode,\n            cols = [],\n            col,\n            i;\n\n        for (i = 0; i < colNodes.length; i += 1) {\n            colNode = colNodes[i];\n            col = {\n                key: colNode.getAttribute('data-col'),\n                sortable: !colNode.getAttribute('data-nosort'),\n                type: colNode.getAttribute('data-type') || 'string'\n            };\n            cols.push(col);\n            if (col.sortable) {\n                col.defaultDescSort = col.type === 'number';\n                colNode.innerHTML =\n                    colNode.innerHTML + '<span class=\"sorter\"></span>';\n            }\n        }\n        return cols;\n    }\n    // attaches a data attribute to every tr element with an object\n    // of data values keyed by column name\n    function loadRowData(tableRow) {\n        var tableCols = tableRow.querySelectorAll('td'),\n            colNode,\n            col,\n            data = {},\n            i,\n            val;\n        for (i = 0; i < tableCols.length; i += 1) {\n            colNode = tableCols[i];\n            col = cols[i];\n            val = colNode.getAttribute('data-value');\n            if (col.type === 'number') {\n                val = Number(val);\n            }\n            data[col.key] = val;\n        }\n        return data;\n    }\n    // loads all row data\n    function loadData() {\n        var rows = getTableBody().querySelectorAll('tr'),\n            i;\n\n        for (i = 0; i < rows.length; i += 1) {\n            rows[i].data = loadRowData(rows[i]);\n        }\n    }\n    // sorts the table using the data for the ith column\n    function sortByIndex(index, desc) {\n        var key = cols[index].key,\n            sorter = function(a, b) {\n                a = a.data[key];\n                b = b.data[key];\n                return a < b ? -1 : a > b ? 1 : 0;\n            },\n            finalSorter = sorter,\n            tableBody = document.querySelector('.coverage-summary tbody'),\n            rowNodes = tableBody.querySelectorAll('tr'),\n            rows = [],\n            i;\n\n        if (desc) {\n            finalSorter = function(a, b) {\n                return -1 * sorter(a, b);\n            };\n        }\n\n        for (i = 0; i < rowNodes.length; i += 1) {\n            rows.push(rowNodes[i]);\n            tableBody.removeChild(rowNodes[i]);\n        }\n\n        rows.sort(finalSorter);\n\n        for (i = 0; i < rows.length; i += 1) {\n            tableBody.appendChild(rows[i]);\n        }\n    }\n    // removes sort indicators for current column being sorted\n    function removeSortIndicators() {\n        var col = getNthColumn(currentSort.index),\n            cls = col.className;\n\n        cls = cls.replace(/ sorted$/, '').replace(/ sorted-desc$/, '');\n        col.className = cls;\n    }\n    // adds sort indicators for current column being sorted\n    function addSortIndicators() {\n        getNthColumn(currentSort.index).className += currentSort.desc\n            ? ' sorted-desc'\n            : ' sorted';\n    }\n    // adds event listeners for all sorter widgets\n    function enableUI() {\n        var i,\n            el,\n            ithSorter = function ithSorter(i) {\n                var col = cols[i];\n\n                return function() {\n                    var desc = col.defaultDescSort;\n\n                    if (currentSort.index === i) {\n                        desc = !currentSort.desc;\n                    }\n                    sortByIndex(i, desc);\n                    removeSortIndicators();\n                    currentSort.index = i;\n                    currentSort.desc = desc;\n                    addSortIndicators();\n                };\n            };\n        for (i = 0; i < cols.length; i += 1) {\n            if (cols[i].sortable) {\n                // add the click event handler on the th so users\n                // dont have to click on those tiny arrows\n                el = getNthColumn(i).querySelector('.sorter').parentElement;\n                if (el.addEventListener) {\n                    el.addEventListener('click', ithSorter(i));\n                } else {\n                    el.attachEvent('onclick', ithSorter(i));\n                }\n            }\n        }\n    }\n    // adds sorting functionality to the UI\n    return function() {\n        if (!getTable()) {\n            return;\n        }\n        cols = loadColumns();\n        loadData();\n        addSearchBox();\n        addSortIndicators();\n        enableUI();\n    };\n})();\n\nwindow.addEventListener('load', addSorting);\n"]}
@@ -0,0 +1,56 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const js_1 = __importDefault(require("@eslint/js"));
7
+ const typescript_eslint_1 = __importDefault(require("typescript-eslint"));
8
+ const globals_1 = __importDefault(require("globals"));
9
+ exports.default = typescript_eslint_1.default.config(
10
+ // Global ignores (replaces .eslintignore)
11
+ {
12
+ ignores: ['node_modules/**', 'lib/**', 'coverage/**', 'dist/**'],
13
+ },
14
+ // Base ESLint recommended rules
15
+ js_1.default.configs.recommended,
16
+ // TypeScript recommended rules
17
+ ...typescript_eslint_1.default.configs.recommended,
18
+ // Project-specific configuration
19
+ {
20
+ files: ['src/**/*.ts'],
21
+ languageOptions: {
22
+ ecmaVersion: 'latest',
23
+ sourceType: 'module',
24
+ globals: {
25
+ ...globals_1.default.node,
26
+ ...globals_1.default.es2021,
27
+ },
28
+ parserOptions: {
29
+ project: true,
30
+ },
31
+ },
32
+ rules: {
33
+ // Spacing and formatting
34
+ 'indent': 'off',
35
+ '@typescript-eslint/indent': 'off', // Disabled - using Prettier/WebStorm for formatting
36
+ 'object-curly-spacing': ['error', 'always'],
37
+ 'object-curly-newline': 'off',
38
+ 'padded-blocks': 'off',
39
+ // TypeScript specific
40
+ 'no-shadow': 'off',
41
+ '@typescript-eslint/no-shadow': ['error'],
42
+ '@typescript-eslint/no-unused-vars': ['error', { argsIgnorePattern: '^_', caughtErrorsIgnorePattern: '^_' }],
43
+ '@typescript-eslint/no-explicit-any': 'warn',
44
+ // Best practices
45
+ 'max-len': ['error', { code: 144, ignoreUrls: true }],
46
+ 'no-plusplus': ['error', { allowForLoopAfterthoughts: true }],
47
+ 'class-methods-use-this': 'off',
48
+ 'no-underscore-dangle': ['error', { allowAfterThis: true }],
49
+ // Allow certain patterns
50
+ 'no-restricted-syntax': 'off',
51
+ 'arrow-parens': ['error', 'as-needed'],
52
+ 'implicit-arrow-linebreak': 'off',
53
+ 'operator-linebreak': 'off',
54
+ },
55
+ });
56
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXNsaW50LmNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL2VzbGludC5jb25maWcuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxvREFBZ0M7QUFDaEMsMEVBQXlDO0FBQ3pDLHNEQUE4QjtBQUU5QixrQkFBZSwyQkFBUSxDQUFDLE1BQU07QUFDMUIsMENBQTBDO0FBQzFDO0lBQ0ksT0FBTyxFQUFFLENBQUMsaUJBQWlCLEVBQUUsUUFBUSxFQUFFLGFBQWEsRUFBRSxTQUFTLENBQUM7Q0FDbkU7QUFFRCxnQ0FBZ0M7QUFDaEMsWUFBTSxDQUFDLE9BQU8sQ0FBQyxXQUFXO0FBRTFCLCtCQUErQjtBQUMvQixHQUFHLDJCQUFRLENBQUMsT0FBTyxDQUFDLFdBQVc7QUFFL0IsaUNBQWlDO0FBQ2pDO0lBQ0ksS0FBSyxFQUFFLENBQUMsYUFBYSxDQUFDO0lBQ3RCLGVBQWUsRUFBRTtRQUNiLFdBQVcsRUFBRSxRQUFRO1FBQ3JCLFVBQVUsRUFBRSxRQUFRO1FBQ3BCLE9BQU8sRUFBRTtZQUNMLEdBQUcsaUJBQU8sQ0FBQyxJQUFJO1lBQ2YsR0FBRyxpQkFBTyxDQUFDLE1BQU07U0FDcEI7UUFDRCxhQUFhLEVBQUU7WUFDWCxPQUFPLEVBQUUsSUFBSTtTQUNoQjtLQUNKO0lBQ0QsS0FBSyxFQUFFO1FBQ0gseUJBQXlCO1FBQ3pCLFFBQVEsRUFBRSxLQUFLO1FBQ2YsMkJBQTJCLEVBQUUsS0FBSyxFQUFFLG9EQUFvRDtRQUN4RixzQkFBc0IsRUFBRSxDQUFDLE9BQU8sRUFBRSxRQUFRLENBQUM7UUFDM0Msc0JBQXNCLEVBQUUsS0FBSztRQUM3QixlQUFlLEVBQUUsS0FBSztRQUV0QixzQkFBc0I7UUFDdEIsV0FBVyxFQUFFLEtBQUs7UUFDbEIsOEJBQThCLEVBQUUsQ0FBQyxPQUFPLENBQUM7UUFDekMsbUNBQW1DLEVBQUUsQ0FBQyxPQUFPLEVBQUUsRUFBRSxpQkFBaUIsRUFBRSxJQUFJLEVBQUUseUJBQXlCLEVBQUUsSUFBSSxFQUFFLENBQUM7UUFDNUcsb0NBQW9DLEVBQUUsTUFBTTtRQUU1QyxpQkFBaUI7UUFDakIsU0FBUyxFQUFFLENBQUMsT0FBTyxFQUFFLEVBQUUsSUFBSSxFQUFFLEdBQUcsRUFBRSxVQUFVLEVBQUUsSUFBSSxFQUFFLENBQUM7UUFDckQsYUFBYSxFQUFFLENBQUMsT0FBTyxFQUFFLEVBQUUseUJBQXlCLEVBQUUsSUFBSSxFQUFFLENBQUM7UUFDN0Qsd0JBQXdCLEVBQUUsS0FBSztRQUMvQixzQkFBc0IsRUFBRSxDQUFDLE9BQU8sRUFBRSxFQUFFLGNBQWMsRUFBRSxJQUFJLEVBQUUsQ0FBQztRQUUzRCx5QkFBeUI7UUFDekIsc0JBQXNCLEVBQUUsS0FBSztRQUM3QixjQUFjLEVBQUUsQ0FBQyxPQUFPLEVBQUUsV0FBVyxDQUFDO1FBQ3RDLDBCQUEwQixFQUFFLEtBQUs7UUFDakMsb0JBQW9CLEVBQUUsS0FBSztLQUM5QjtDQUNKLENBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBlc2xpbnQgZnJvbSAnQGVzbGludC9qcyc7XG5pbXBvcnQgdHNlc2xpbnQgZnJvbSAndHlwZXNjcmlwdC1lc2xpbnQnO1xuaW1wb3J0IGdsb2JhbHMgZnJvbSAnZ2xvYmFscyc7XG5cbmV4cG9ydCBkZWZhdWx0IHRzZXNsaW50LmNvbmZpZyhcbiAgICAvLyBHbG9iYWwgaWdub3JlcyAocmVwbGFjZXMgLmVzbGludGlnbm9yZSlcbiAgICB7XG4gICAgICAgIGlnbm9yZXM6IFsnbm9kZV9tb2R1bGVzLyoqJywgJ2xpYi8qKicsICdjb3ZlcmFnZS8qKicsICdkaXN0LyoqJ10sXG4gICAgfSxcblxuICAgIC8vIEJhc2UgRVNMaW50IHJlY29tbWVuZGVkIHJ1bGVzXG4gICAgZXNsaW50LmNvbmZpZ3MucmVjb21tZW5kZWQsXG5cbiAgICAvLyBUeXBlU2NyaXB0IHJlY29tbWVuZGVkIHJ1bGVzXG4gICAgLi4udHNlc2xpbnQuY29uZmlncy5yZWNvbW1lbmRlZCxcblxuICAgIC8vIFByb2plY3Qtc3BlY2lmaWMgY29uZmlndXJhdGlvblxuICAgIHtcbiAgICAgICAgZmlsZXM6IFsnc3JjLyoqLyoudHMnXSxcbiAgICAgICAgbGFuZ3VhZ2VPcHRpb25zOiB7XG4gICAgICAgICAgICBlY21hVmVyc2lvbjogJ2xhdGVzdCcsXG4gICAgICAgICAgICBzb3VyY2VUeXBlOiAnbW9kdWxlJyxcbiAgICAgICAgICAgIGdsb2JhbHM6IHtcbiAgICAgICAgICAgICAgICAuLi5nbG9iYWxzLm5vZGUsXG4gICAgICAgICAgICAgICAgLi4uZ2xvYmFscy5lczIwMjEsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgcGFyc2VyT3B0aW9uczoge1xuICAgICAgICAgICAgICAgIHByb2plY3Q6IHRydWUsXG4gICAgICAgICAgICB9LFxuICAgICAgICB9LFxuICAgICAgICBydWxlczoge1xuICAgICAgICAgICAgLy8gU3BhY2luZyBhbmQgZm9ybWF0dGluZ1xuICAgICAgICAgICAgJ2luZGVudCc6ICdvZmYnLFxuICAgICAgICAgICAgJ0B0eXBlc2NyaXB0LWVzbGludC9pbmRlbnQnOiAnb2ZmJywgLy8gRGlzYWJsZWQgLSB1c2luZyBQcmV0dGllci9XZWJTdG9ybSBmb3IgZm9ybWF0dGluZ1xuICAgICAgICAgICAgJ29iamVjdC1jdXJseS1zcGFjaW5nJzogWydlcnJvcicsICdhbHdheXMnXSxcbiAgICAgICAgICAgICdvYmplY3QtY3VybHktbmV3bGluZSc6ICdvZmYnLFxuICAgICAgICAgICAgJ3BhZGRlZC1ibG9ja3MnOiAnb2ZmJyxcblxuICAgICAgICAgICAgLy8gVHlwZVNjcmlwdCBzcGVjaWZpY1xuICAgICAgICAgICAgJ25vLXNoYWRvdyc6ICdvZmYnLFxuICAgICAgICAgICAgJ0B0eXBlc2NyaXB0LWVzbGludC9uby1zaGFkb3cnOiBbJ2Vycm9yJ10sXG4gICAgICAgICAgICAnQHR5cGVzY3JpcHQtZXNsaW50L25vLXVudXNlZC12YXJzJzogWydlcnJvcicsIHsgYXJnc0lnbm9yZVBhdHRlcm46ICdeXycsIGNhdWdodEVycm9yc0lnbm9yZVBhdHRlcm46ICdeXycgfV0sXG4gICAgICAgICAgICAnQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueSc6ICd3YXJuJyxcblxuICAgICAgICAgICAgLy8gQmVzdCBwcmFjdGljZXNcbiAgICAgICAgICAgICdtYXgtbGVuJzogWydlcnJvcicsIHsgY29kZTogMTQ0LCBpZ25vcmVVcmxzOiB0cnVlIH1dLFxuICAgICAgICAgICAgJ25vLXBsdXNwbHVzJzogWydlcnJvcicsIHsgYWxsb3dGb3JMb29wQWZ0ZXJ0aG91Z2h0czogdHJ1ZSB9XSxcbiAgICAgICAgICAgICdjbGFzcy1tZXRob2RzLXVzZS10aGlzJzogJ29mZicsXG4gICAgICAgICAgICAnbm8tdW5kZXJzY29yZS1kYW5nbGUnOiBbJ2Vycm9yJywgeyBhbGxvd0FmdGVyVGhpczogdHJ1ZSB9XSxcblxuICAgICAgICAgICAgLy8gQWxsb3cgY2VydGFpbiBwYXR0ZXJuc1xuICAgICAgICAgICAgJ25vLXJlc3RyaWN0ZWQtc3ludGF4JzogJ29mZicsXG4gICAgICAgICAgICAnYXJyb3ctcGFyZW5zJzogWydlcnJvcicsICdhcy1uZWVkZWQnXSxcbiAgICAgICAgICAgICdpbXBsaWNpdC1hcnJvdy1saW5lYnJlYWsnOiAnb2ZmJyxcbiAgICAgICAgICAgICdvcGVyYXRvci1saW5lYnJlYWsnOiAnb2ZmJyxcbiAgICAgICAgfSxcbiAgICB9LFxuKTtcbiJdfQ==
@@ -0,0 +1,13 @@
1
+ "use strict";
2
+ module.exports = {
3
+ transform: {
4
+ '^.+\\.(t|j)s$': 'ts-jest',
5
+ },
6
+ testRegex: '(/tests/.*|(\\.|/)(test|spec))\\.(t|j)s$',
7
+ modulePathIgnorePatterns: ['<rootDir>/dist/'],
8
+ moduleFileExtensions: ['ts', 'js', 'json', 'node'],
9
+ moduleNameMapper: {
10
+ '^@/(.*)$': '<rootDir>/src/$1',
11
+ },
12
+ };
13
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiamVzdC5jb25maWcuY2pzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vamVzdC5jb25maWcuY2pzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxNQUFNLENBQUMsT0FBTyxHQUFHO0lBQ2IsU0FBUyxFQUFFO1FBQ1AsZUFBZSxFQUFFLFNBQVM7S0FDN0I7SUFDRCxTQUFTLEVBQUUsMENBQTBDO0lBQ3JELHdCQUF3QixFQUFFLENBQUMsaUJBQWlCLENBQUM7SUFDN0Msb0JBQW9CLEVBQUUsQ0FBQyxJQUFJLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxNQUFNLENBQUM7SUFDbEQsZ0JBQWdCLEVBQUU7UUFDZCxVQUFVLEVBQUUsa0JBQWtCO0tBQ2pDO0NBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIm1vZHVsZS5leHBvcnRzID0ge1xuICAgIHRyYW5zZm9ybToge1xuICAgICAgICAnXi4rXFxcXC4odHxqKXMkJzogJ3RzLWplc3QnLFxuICAgIH0sXG4gICAgdGVzdFJlZ2V4OiAnKC90ZXN0cy8uKnwoXFxcXC58LykodGVzdHxzcGVjKSlcXFxcLih0fGopcyQnLFxuICAgIG1vZHVsZVBhdGhJZ25vcmVQYXR0ZXJuczogWyc8cm9vdERpcj4vZGlzdC8nXSxcbiAgICBtb2R1bGVGaWxlRXh0ZW5zaW9uczogWyd0cycsICdqcycsICdqc29uJywgJ25vZGUnXSxcbiAgICBtb2R1bGVOYW1lTWFwcGVyOiB7XG4gICAgICAgICdeQC8oLiopJCc6ICc8cm9vdERpcj4vc3JjLyQxJyxcbiAgICB9LFxufTtcbiJdfQ==
@@ -0,0 +1,13 @@
1
+ "use strict";
2
+ module.exports = {
3
+ transform: {
4
+ '^.+\\.(t|j)s$': 'ts-jest',
5
+ },
6
+ testRegex: '(/tests/.*|(\\.|/)(test|spec))\\.(t|j)s$',
7
+ modulePathIgnorePatterns: ['<rootDir>/dist/'],
8
+ moduleFileExtensions: ['ts', 'js', 'json', 'node'],
9
+ moduleNameMapper: {
10
+ '^@/(.*)$': '<rootDir>/src/$1',
11
+ },
12
+ };
13
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiamVzdC5jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9qZXN0LmNvbmZpZy5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsTUFBTSxDQUFDLE9BQU8sR0FBRztJQUNiLFNBQVMsRUFBRTtRQUNQLGVBQWUsRUFBRSxTQUFTO0tBQzdCO0lBQ0QsU0FBUyxFQUFFLDBDQUEwQztJQUNyRCx3QkFBd0IsRUFBRSxDQUFDLGlCQUFpQixDQUFDO0lBQzdDLG9CQUFvQixFQUFFLENBQUMsSUFBSSxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUUsTUFBTSxDQUFDO0lBQ2xELGdCQUFnQixFQUFFO1FBQ2QsVUFBVSxFQUFFLGtCQUFrQjtLQUNqQztDQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJtb2R1bGUuZXhwb3J0cyA9IHtcbiAgICB0cmFuc2Zvcm06IHtcbiAgICAgICAgJ14uK1xcXFwuKHR8ailzJCc6ICd0cy1qZXN0JyxcbiAgICB9LFxuICAgIHRlc3RSZWdleDogJygvdGVzdHMvLip8KFxcXFwufC8pKHRlc3R8c3BlYykpXFxcXC4odHxqKXMkJyxcbiAgICBtb2R1bGVQYXRoSWdub3JlUGF0dGVybnM6IFsnPHJvb3REaXI+L2Rpc3QvJ10sXG4gICAgbW9kdWxlRmlsZUV4dGVuc2lvbnM6IFsndHMnLCAnanMnLCAnanNvbicsICdub2RlJ10sXG4gICAgbW9kdWxlTmFtZU1hcHBlcjoge1xuICAgICAgICAnXkAvKC4qKSQnOiAnPHJvb3REaXI+L3NyYy8kMScsXG4gICAgfSxcbn07XG4iXX0=
@@ -0,0 +1,52 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ // import nock = require('nock');
4
+ const keezApi_1 = require("../../keezApi");
5
+ describe('Keez API authorisation', () => {
6
+ let keezApi;
7
+ beforeAll(() => {
8
+ keezApi = new keezApi_1.KeezApi({
9
+ application_id: '123',
10
+ client_eid: '123',
11
+ secret: '123',
12
+ user: '123',
13
+ live: true,
14
+ });
15
+ });
16
+ /* test('should generate a new token', async () => {
17
+ const result = await keezApi.createInvoice({
18
+ amount: 400,
19
+ currencyCode: 'RON',
20
+ itemId: '123',
21
+ partner: {
22
+ isLegalPerson: false,
23
+ partnerName: 'Marian Ion',
24
+ countryName: 'Romania',
25
+ countryCode: 'RO',
26
+ countyCode: 'RO.B',
27
+ countyName: 'Bucuresti',
28
+ addressDetails: 'Strada Testez nr. 4',
29
+ cityName: 'Timisoara',
30
+ identificationNumber: '1234',
31
+ },
32
+ paymentType: 10,
33
+ series: 'PDI',
34
+ });
35
+ console.log('result is');
36
+ console.log(result);
37
+ expect(result).toBeTruthy();
38
+ });
39
+
40
+ test('should generate a new token', async () => {
41
+ const result = await keezApi.validateInvoice('f28730f84ed04613a36583e8c2a755c3');
42
+ console.log('result is');
43
+ console.log(result);
44
+ expect(result).toBeTruthy();
45
+ }); */
46
+ test('should change the live mode', () => {
47
+ keezApi.setLive(false);
48
+ expect(keezApi.getBaseDomain())
49
+ .toBe('https://staging.keez.ro');
50
+ });
51
+ });
52
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXgudGVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9hcGkvX190ZXN0c19fL2luZGV4LnRlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxpQ0FBaUM7QUFDakMsMkNBQXdDO0FBRXhDLFFBQVEsQ0FBQyx3QkFBd0IsRUFBRSxHQUFHLEVBQUU7SUFDcEMsSUFBSSxPQUFnQixDQUFDO0lBRXJCLFNBQVMsQ0FBQyxHQUFHLEVBQUU7UUFDWCxPQUFPLEdBQUcsSUFBSSxpQkFBTyxDQUFDO1lBQ2xCLGNBQWMsRUFBRSxLQUFLO1lBQ3JCLFVBQVUsRUFBRSxLQUFLO1lBQ2pCLE1BQU0sRUFBRSxLQUFLO1lBQ2IsSUFBSSxFQUFFLEtBQUs7WUFDWCxJQUFJLEVBQUUsSUFBSTtTQUNiLENBQUMsQ0FBQztJQUNQLENBQUMsQ0FBQyxDQUFDO0lBRUg7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O1dBNkJPO0lBRVAsSUFBSSxDQUFDLDZCQUE2QixFQUFFLEdBQUcsRUFBRTtRQUNyQyxPQUFPLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3ZCLE1BQU0sQ0FBQyxPQUFPLENBQUMsYUFBYSxFQUFFLENBQUM7YUFDMUIsSUFBSSxDQUFDLHlCQUF5QixDQUFDLENBQUM7SUFDekMsQ0FBQyxDQUFDLENBQUM7QUFDUCxDQUFDLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIGltcG9ydCBub2NrID0gcmVxdWlyZSgnbm9jaycpO1xuaW1wb3J0IHsgS2VlekFwaSB9IGZyb20gJy4uLy4uL2tlZXpBcGknO1xuXG5kZXNjcmliZSgnS2VleiBBUEkgYXV0aG9yaXNhdGlvbicsICgpID0+IHtcbiAgICBsZXQga2VlekFwaTogS2VlekFwaTtcblxuICAgIGJlZm9yZUFsbCgoKSA9PiB7XG4gICAgICAgIGtlZXpBcGkgPSBuZXcgS2VlekFwaSh7XG4gICAgICAgICAgICBhcHBsaWNhdGlvbl9pZDogJzEyMycsXG4gICAgICAgICAgICBjbGllbnRfZWlkOiAnMTIzJyxcbiAgICAgICAgICAgIHNlY3JldDogJzEyMycsXG4gICAgICAgICAgICB1c2VyOiAnMTIzJyxcbiAgICAgICAgICAgIGxpdmU6IHRydWUsXG4gICAgICAgIH0pO1xuICAgIH0pO1xuXG4gICAgLyogdGVzdCgnc2hvdWxkIGdlbmVyYXRlIGEgbmV3IHRva2VuJywgYXN5bmMgKCkgPT4ge1xuICAgICAgICBjb25zdCByZXN1bHQgPSBhd2FpdCBrZWV6QXBpLmNyZWF0ZUludm9pY2Uoe1xuICAgICAgICAgICAgYW1vdW50OiA0MDAsXG4gICAgICAgICAgICBjdXJyZW5jeUNvZGU6ICdST04nLFxuICAgICAgICAgICAgaXRlbUlkOiAnMTIzJyxcbiAgICAgICAgICAgIHBhcnRuZXI6IHtcbiAgICAgICAgICAgICAgICBpc0xlZ2FsUGVyc29uOiBmYWxzZSxcbiAgICAgICAgICAgICAgICBwYXJ0bmVyTmFtZTogJ01hcmlhbiBJb24nLFxuICAgICAgICAgICAgICAgIGNvdW50cnlOYW1lOiAnUm9tYW5pYScsXG4gICAgICAgICAgICAgICAgY291bnRyeUNvZGU6ICdSTycsXG4gICAgICAgICAgICAgICAgY291bnR5Q29kZTogJ1JPLkInLFxuICAgICAgICAgICAgICAgIGNvdW50eU5hbWU6ICdCdWN1cmVzdGknLFxuICAgICAgICAgICAgICAgIGFkZHJlc3NEZXRhaWxzOiAnU3RyYWRhIFRlc3RleiBuci4gNCcsXG4gICAgICAgICAgICAgICAgY2l0eU5hbWU6ICdUaW1pc29hcmEnLFxuICAgICAgICAgICAgICAgIGlkZW50aWZpY2F0aW9uTnVtYmVyOiAnMTIzNCcsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgcGF5bWVudFR5cGU6IDEwLFxuICAgICAgICAgICAgc2VyaWVzOiAnUERJJyxcbiAgICAgICAgfSk7XG4gICAgICAgIGNvbnNvbGUubG9nKCdyZXN1bHQgaXMnKTtcbiAgICAgICAgY29uc29sZS5sb2cocmVzdWx0KTtcbiAgICAgICAgZXhwZWN0KHJlc3VsdCkudG9CZVRydXRoeSgpO1xuICAgIH0pO1xuXG4gICAgdGVzdCgnc2hvdWxkIGdlbmVyYXRlIGEgbmV3IHRva2VuJywgYXN5bmMgKCkgPT4ge1xuICAgICAgICBjb25zdCByZXN1bHQgPSBhd2FpdCBrZWV6QXBpLnZhbGlkYXRlSW52b2ljZSgnZjI4NzMwZjg0ZWQwNDYxM2EzNjU4M2U4YzJhNzU1YzMnKTtcbiAgICAgICAgY29uc29sZS5sb2coJ3Jlc3VsdCBpcycpO1xuICAgICAgICBjb25zb2xlLmxvZyhyZXN1bHQpO1xuICAgICAgICBleHBlY3QocmVzdWx0KS50b0JlVHJ1dGh5KCk7XG4gICAgfSk7ICAqL1xuXG4gICAgdGVzdCgnc2hvdWxkIGNoYW5nZSB0aGUgbGl2ZSBtb2RlJywgKCkgPT4ge1xuICAgICAgICBrZWV6QXBpLnNldExpdmUoZmFsc2UpO1xuICAgICAgICBleHBlY3Qoa2VlekFwaS5nZXRCYXNlRG9tYWluKCkpXG4gICAgICAgICAgICAudG9CZSgnaHR0cHM6Ly9zdGFnaW5nLmtlZXoucm8nKTtcbiAgICB9KTtcbn0pO1xuIl19
@@ -0,0 +1,48 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.apiGenerateToken = apiGenerateToken;
7
+ const axios_1 = __importDefault(require("axios"));
8
+ const logger_1 = require("../helpers/logger");
9
+ const KeezError_1 = require("../errors/KeezError");
10
+ const constants_1 = require("../config/constants");
11
+ const keezLogger = logger_1.logger.child({ _library: 'KeezWrapper', _method: 'GenerateToken' });
12
+ /**
13
+ * Generate a token for the Keez API
14
+ * @returns {AuthResponse} - The token response containing the access token and the expiry time
15
+ * @param params - As defined in the interface
16
+ */
17
+ async function apiGenerateToken(params) {
18
+ const url = `${params.baseDomain}/idp/connect/token`;
19
+ const formData = new URLSearchParams({
20
+ client_id: `app${params.appId}`,
21
+ client_secret: params.apiSecret,
22
+ grant_type: 'client_credentials',
23
+ scope: 'public-api',
24
+ });
25
+ try {
26
+ const response = await axios_1.default.post(url, formData.toString(), {
27
+ headers: {
28
+ 'Content-Type': 'application/x-www-form-urlencoded',
29
+ },
30
+ timeout: constants_1.HTTP_REQUEST_TIMEOUT_MS,
31
+ });
32
+ const responseObject = response.data;
33
+ return {
34
+ access_token: responseObject.access_token,
35
+ expires_in: responseObject.expires_in,
36
+ expires_at: new Date(Date.now() + constants_1.TOKEN_EXPIRY_BUFFER_MS).getTime(),
37
+ token_type: responseObject.token_type,
38
+ scope: responseObject.scope,
39
+ };
40
+ }
41
+ catch (error) {
42
+ const axiosError = error;
43
+ const errorMessage = axiosError.response?.data || axiosError.message;
44
+ keezLogger.error(`Error encountered while authenticating: ${JSON.stringify(errorMessage)}`);
45
+ throw new KeezError_1.KeezAuthError(`Authentication failed: ${JSON.stringify(errorMessage)}`, axiosError.response?.status, error);
46
+ }
47
+ }
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aG9yaXNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2FwaS9hdXRob3Jpc2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUF3QkEsNENBbUNDO0FBM0RELGtEQUEwQztBQUMxQyw2Q0FBMEM7QUFFMUMsa0RBQW1EO0FBQ25ELGtEQUFxRjtBQUVyRixNQUFNLFVBQVUsR0FBRyxlQUFNLENBQUMsS0FBSyxDQUFDLEVBQUUsUUFBUSxFQUFFLGFBQWEsRUFBRSxPQUFPLEVBQUUsZUFBZSxFQUFFLENBQUMsQ0FBQztBQWF2Rjs7OztHQUlHO0FBQ0ksS0FBSyxVQUFVLGdCQUFnQixDQUFDLE1BQTJCO0lBQzlELE1BQU0sR0FBRyxHQUFHLEdBQUcsTUFBTSxDQUFDLFVBQVUsb0JBQW9CLENBQUM7SUFDckQsTUFBTSxRQUFRLEdBQUcsSUFBSSxlQUFlLENBQUM7UUFDakMsU0FBUyxFQUFFLE1BQU0sTUFBTSxDQUFDLEtBQUssRUFBRTtRQUMvQixhQUFhLEVBQUUsTUFBTSxDQUFDLFNBQVM7UUFDL0IsVUFBVSxFQUFFLG9CQUFvQjtRQUNoQyxLQUFLLEVBQUUsWUFBWTtLQUN0QixDQUFDLENBQUM7SUFFSCxJQUFJLENBQUM7UUFDRCxNQUFNLFFBQVEsR0FBRyxNQUFNLGVBQUssQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFLFFBQVEsQ0FBQyxRQUFRLEVBQUUsRUFBRTtZQUN4RCxPQUFPLEVBQUU7Z0JBQ0wsY0FBYyxFQUFFLG1DQUFtQzthQUN0RDtZQUNELE9BQU8sRUFBRSxtQ0FBdUI7U0FDbkMsQ0FBQyxDQUFDO1FBRUgsTUFBTSxjQUFjLEdBQUcsUUFBUSxDQUFDLElBQUksQ0FBQztRQUNyQyxPQUFPO1lBQ0gsWUFBWSxFQUFFLGNBQWMsQ0FBQyxZQUFZO1lBQ3pDLFVBQVUsRUFBRSxjQUFjLENBQUMsVUFBVTtZQUNyQyxVQUFVLEVBQUUsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxHQUFHLGtDQUFzQixDQUFDLENBQUMsT0FBTyxFQUFFO1lBQ25FLFVBQVUsRUFBRSxjQUFjLENBQUMsVUFBVTtZQUNyQyxLQUFLLEVBQUUsY0FBYyxDQUFDLEtBQUs7U0FDOUIsQ0FBQztJQUNOLENBQUM7SUFBQyxPQUFPLEtBQUssRUFBRSxDQUFDO1FBQ2IsTUFBTSxVQUFVLEdBQUcsS0FBbUIsQ0FBQztRQUN2QyxNQUFNLFlBQVksR0FBRyxVQUFVLENBQUMsUUFBUSxFQUFFLElBQUksSUFBSSxVQUFVLENBQUMsT0FBTyxDQUFDO1FBQ3JFLFVBQVUsQ0FBQyxLQUFLLENBQUMsMkNBQTJDLElBQUksQ0FBQyxTQUFTLENBQUMsWUFBWSxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBQzVGLE1BQU0sSUFBSSx5QkFBYSxDQUNuQiwwQkFBMEIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxZQUFZLENBQUMsRUFBRSxFQUN4RCxVQUFVLENBQUMsUUFBUSxFQUFFLE1BQU0sRUFDM0IsS0FBSyxDQUNSLENBQUM7SUFDTixDQUFDO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBheGlvcywgeyBBeGlvc0Vycm9yIH0gZnJvbSAnYXhpb3MnO1xuaW1wb3J0IHsgbG9nZ2VyIH0gZnJvbSAnQC9oZWxwZXJzL2xvZ2dlcic7XG5pbXBvcnQgeyBBdXRoUmVzcG9uc2UgfSBmcm9tICdAL2R0by9hdXRoUmVzcG9uc2UnO1xuaW1wb3J0IHsgS2VlekF1dGhFcnJvciB9IGZyb20gJ0AvZXJyb3JzL0tlZXpFcnJvcic7XG5pbXBvcnQgeyBIVFRQX1JFUVVFU1RfVElNRU9VVF9NUywgVE9LRU5fRVhQSVJZX0JVRkZFUl9NUyB9IGZyb20gJ0AvY29uZmlnL2NvbnN0YW50cyc7XG5cbmNvbnN0IGtlZXpMb2dnZXIgPSBsb2dnZXIuY2hpbGQoeyBfbGlicmFyeTogJ0tlZXpXcmFwcGVyJywgX21ldGhvZDogJ0dlbmVyYXRlVG9rZW4nIH0pO1xuXG4vKipcbiAqIGJhc2VEb21haW4gLSBUaGUgYmFzZSBkb21haW4gZm9yIHRoZSBBUElcbiAqIGFwcElkIC0gVGhlIGFwcGxpY2F0aW9uIElEXG4gKiBhcGlTZWNyZXQgLSBUaGUgQVBJIHNlY3JldFxuICovXG5pbnRlcmZhY2UgR2VuZXJhdGVUb2tlblBhcmFtcyB7XG4gICAgcmVhZG9ubHkgYmFzZURvbWFpbjogc3RyaW5nO1xuICAgIHJlYWRvbmx5IGFwcElkOiBzdHJpbmc7XG4gICAgcmVhZG9ubHkgYXBpU2VjcmV0OiBzdHJpbmc7XG59XG5cbi8qKlxuICogR2VuZXJhdGUgYSB0b2tlbiBmb3IgdGhlIEtlZXogQVBJXG4gKiBAcmV0dXJucyB7QXV0aFJlc3BvbnNlfSAtIFRoZSB0b2tlbiByZXNwb25zZSBjb250YWluaW5nIHRoZSBhY2Nlc3MgdG9rZW4gYW5kIHRoZSBleHBpcnkgdGltZVxuICogQHBhcmFtIHBhcmFtcyAtIEFzIGRlZmluZWQgaW4gdGhlIGludGVyZmFjZVxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gYXBpR2VuZXJhdGVUb2tlbihwYXJhbXM6IEdlbmVyYXRlVG9rZW5QYXJhbXMpOiBQcm9taXNlPEF1dGhSZXNwb25zZT4ge1xuICAgIGNvbnN0IHVybCA9IGAke3BhcmFtcy5iYXNlRG9tYWlufS9pZHAvY29ubmVjdC90b2tlbmA7XG4gICAgY29uc3QgZm9ybURhdGEgPSBuZXcgVVJMU2VhcmNoUGFyYW1zKHtcbiAgICAgICAgY2xpZW50X2lkOiBgYXBwJHtwYXJhbXMuYXBwSWR9YCxcbiAgICAgICAgY2xpZW50X3NlY3JldDogcGFyYW1zLmFwaVNlY3JldCxcbiAgICAgICAgZ3JhbnRfdHlwZTogJ2NsaWVudF9jcmVkZW50aWFscycsXG4gICAgICAgIHNjb3BlOiAncHVibGljLWFwaScsXG4gICAgfSk7XG5cbiAgICB0cnkge1xuICAgICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IGF4aW9zLnBvc3QodXJsLCBmb3JtRGF0YS50b1N0cmluZygpLCB7XG4gICAgICAgICAgICBoZWFkZXJzOiB7XG4gICAgICAgICAgICAgICAgJ0NvbnRlbnQtVHlwZSc6ICdhcHBsaWNhdGlvbi94LXd3dy1mb3JtLXVybGVuY29kZWQnLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIHRpbWVvdXQ6IEhUVFBfUkVRVUVTVF9USU1FT1VUX01TLFxuICAgICAgICB9KTtcblxuICAgICAgICBjb25zdCByZXNwb25zZU9iamVjdCA9IHJlc3BvbnNlLmRhdGE7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICBhY2Nlc3NfdG9rZW46IHJlc3BvbnNlT2JqZWN0LmFjY2Vzc190b2tlbixcbiAgICAgICAgICAgIGV4cGlyZXNfaW46IHJlc3BvbnNlT2JqZWN0LmV4cGlyZXNfaW4sXG4gICAgICAgICAgICBleHBpcmVzX2F0OiBuZXcgRGF0ZShEYXRlLm5vdygpICsgVE9LRU5fRVhQSVJZX0JVRkZFUl9NUykuZ2V0VGltZSgpLFxuICAgICAgICAgICAgdG9rZW5fdHlwZTogcmVzcG9uc2VPYmplY3QudG9rZW5fdHlwZSxcbiAgICAgICAgICAgIHNjb3BlOiByZXNwb25zZU9iamVjdC5zY29wZSxcbiAgICAgICAgfTtcbiAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgICBjb25zdCBheGlvc0Vycm9yID0gZXJyb3IgYXMgQXhpb3NFcnJvcjtcbiAgICAgICAgY29uc3QgZXJyb3JNZXNzYWdlID0gYXhpb3NFcnJvci5yZXNwb25zZT8uZGF0YSB8fCBheGlvc0Vycm9yLm1lc3NhZ2U7XG4gICAgICAgIGtlZXpMb2dnZXIuZXJyb3IoYEVycm9yIGVuY291bnRlcmVkIHdoaWxlIGF1dGhlbnRpY2F0aW5nOiAke0pTT04uc3RyaW5naWZ5KGVycm9yTWVzc2FnZSl9YCk7XG4gICAgICAgIHRocm93IG5ldyBLZWV6QXV0aEVycm9yKFxuICAgICAgICAgICAgYEF1dGhlbnRpY2F0aW9uIGZhaWxlZDogJHtKU09OLnN0cmluZ2lmeShlcnJvck1lc3NhZ2UpfWAsXG4gICAgICAgICAgICBheGlvc0Vycm9yLnJlc3BvbnNlPy5zdGF0dXMsXG4gICAgICAgICAgICBlcnJvclxuICAgICAgICApO1xuICAgIH1cbn1cbiJdfQ==
@@ -0,0 +1,33 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.apiCancelInvoice = apiCancelInvoice;
7
+ const axios_1 = __importDefault(require("axios"));
8
+ const logger_1 = require("../../helpers/logger");
9
+ const KeezError_1 = require("../../errors/KeezError");
10
+ const constants_1 = require("../../config/constants");
11
+ const keezLogger = logger_1.logger.child({ _library: 'KeezWrapper', _method: 'Invoices' });
12
+ async function apiCancelInvoice(params) {
13
+ const url = `${params.baseDomain}/api/v1.0/public-api/${params.appClientId}/invoices/canceled`;
14
+ const body = {
15
+ externalId: params.invoiceId,
16
+ };
17
+ try {
18
+ await axios_1.default.post(url, body, {
19
+ headers: {
20
+ Authorization: `Bearer ${params.bearerToken}`,
21
+ 'Content-Type': 'application/json',
22
+ },
23
+ timeout: constants_1.HTTP_REQUEST_TIMEOUT_MS,
24
+ });
25
+ }
26
+ catch (error) {
27
+ const axiosError = error;
28
+ const errorMessage = axiosError.response?.data || axiosError.message;
29
+ keezLogger.error(`Error encountered while canceling invoice (${params.invoiceId}): ${JSON.stringify(errorMessage)}`);
30
+ throw new KeezError_1.KeezApiError(`Failed to cancel invoice: ${JSON.stringify(errorMessage)}`, axiosError.response?.status, error);
31
+ }
32
+ }
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FuY2VsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2FwaS9pbnZvaWNlcy9jYW5jZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFlQSw0Q0EyQkM7QUExQ0Qsa0RBQTBDO0FBQzFDLDZDQUEwQztBQUMxQyxrREFBa0Q7QUFDbEQsa0RBQTZEO0FBRTdELE1BQU0sVUFBVSxHQUFHLGVBQU0sQ0FBQyxLQUFLLENBQUMsRUFBRSxRQUFRLEVBQUUsYUFBYSxFQUFFLE9BQU8sRUFBRSxVQUFVLEVBQUUsQ0FBQyxDQUFDO0FBVTNFLEtBQUssVUFBVSxnQkFBZ0IsQ0FBQyxNQUEyQjtJQUM5RCxNQUFNLEdBQUcsR0FBRyxHQUFHLE1BQU0sQ0FBQyxVQUFVLHdCQUF3QixNQUFNLENBQUMsV0FBVyxvQkFBb0IsQ0FBQztJQUUvRixNQUFNLElBQUksR0FBRztRQUNULFVBQVUsRUFBRSxNQUFNLENBQUMsU0FBUztLQUMvQixDQUFDO0lBRUYsSUFBSSxDQUFDO1FBQ0QsTUFBTSxlQUFLLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxJQUFJLEVBQUU7WUFDeEIsT0FBTyxFQUFFO2dCQUNMLGFBQWEsRUFBRSxVQUFVLE1BQU0sQ0FBQyxXQUFXLEVBQUU7Z0JBQzdDLGNBQWMsRUFBRSxrQkFBa0I7YUFDckM7WUFDRCxPQUFPLEVBQUUsbUNBQXVCO1NBQ25DLENBQUMsQ0FBQztJQUNQLENBQUM7SUFBQyxPQUFPLEtBQUssRUFBRSxDQUFDO1FBQ2IsTUFBTSxVQUFVLEdBQUcsS0FBbUIsQ0FBQztRQUN2QyxNQUFNLFlBQVksR0FBRyxVQUFVLENBQUMsUUFBUSxFQUFFLElBQUksSUFBSSxVQUFVLENBQUMsT0FBTyxDQUFDO1FBQ3JFLFVBQVUsQ0FBQyxLQUFLLENBQ1osOENBQThDLE1BQU0sQ0FBQyxTQUFTLE1BQU0sSUFBSSxDQUFDLFNBQVMsQ0FBQyxZQUFZLENBQUMsRUFBRSxDQUNyRyxDQUFDO1FBQ0YsTUFBTSxJQUFJLHdCQUFZLENBQ2xCLDZCQUE2QixJQUFJLENBQUMsU0FBUyxDQUFDLFlBQVksQ0FBQyxFQUFFLEVBQzNELFVBQVUsQ0FBQyxRQUFRLEVBQUUsTUFBTSxFQUMzQixLQUFLLENBQ1IsQ0FBQztJQUNOLENBQUM7QUFDTCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGF4aW9zLCB7IEF4aW9zRXJyb3IgfSBmcm9tICdheGlvcyc7XG5pbXBvcnQgeyBsb2dnZXIgfSBmcm9tICdAL2hlbHBlcnMvbG9nZ2VyJztcbmltcG9ydCB7IEtlZXpBcGlFcnJvciB9IGZyb20gJ0AvZXJyb3JzL0tlZXpFcnJvcic7XG5pbXBvcnQgeyBIVFRQX1JFUVVFU1RfVElNRU9VVF9NUyB9IGZyb20gJ0AvY29uZmlnL2NvbnN0YW50cyc7XG5cbmNvbnN0IGtlZXpMb2dnZXIgPSBsb2dnZXIuY2hpbGQoeyBfbGlicmFyeTogJ0tlZXpXcmFwcGVyJywgX21ldGhvZDogJ0ludm9pY2VzJyB9KTtcblxuaW50ZXJmYWNlIENhbmNlbEludm9pY2VQYXJhbXMge1xuICAgIHJlYWRvbmx5IGJhc2VEb21haW46IHN0cmluZztcbiAgICByZWFkb25seSBhcHBJZDogc3RyaW5nO1xuICAgIHJlYWRvbmx5IGFwcENsaWVudElkOiBzdHJpbmc7XG4gICAgcmVhZG9ubHkgYmVhcmVyVG9rZW46IHN0cmluZztcbiAgICByZWFkb25seSBpbnZvaWNlSWQ6IHN0cmluZztcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGFwaUNhbmNlbEludm9pY2UocGFyYW1zOiBDYW5jZWxJbnZvaWNlUGFyYW1zKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgY29uc3QgdXJsID0gYCR7cGFyYW1zLmJhc2VEb21haW59L2FwaS92MS4wL3B1YmxpYy1hcGkvJHtwYXJhbXMuYXBwQ2xpZW50SWR9L2ludm9pY2VzL2NhbmNlbGVkYDtcblxuICAgIGNvbnN0IGJvZHkgPSB7XG4gICAgICAgIGV4dGVybmFsSWQ6IHBhcmFtcy5pbnZvaWNlSWQsXG4gICAgfTtcblxuICAgIHRyeSB7XG4gICAgICAgIGF3YWl0IGF4aW9zLnBvc3QodXJsLCBib2R5LCB7XG4gICAgICAgICAgICBoZWFkZXJzOiB7XG4gICAgICAgICAgICAgICAgQXV0aG9yaXphdGlvbjogYEJlYXJlciAke3BhcmFtcy5iZWFyZXJUb2tlbn1gLFxuICAgICAgICAgICAgICAgICdDb250ZW50LVR5cGUnOiAnYXBwbGljYXRpb24vanNvbicsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgdGltZW91dDogSFRUUF9SRVFVRVNUX1RJTUVPVVRfTVMsXG4gICAgICAgIH0pO1xuICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICAgIGNvbnN0IGF4aW9zRXJyb3IgPSBlcnJvciBhcyBBeGlvc0Vycm9yO1xuICAgICAgICBjb25zdCBlcnJvck1lc3NhZ2UgPSBheGlvc0Vycm9yLnJlc3BvbnNlPy5kYXRhIHx8IGF4aW9zRXJyb3IubWVzc2FnZTtcbiAgICAgICAga2VlekxvZ2dlci5lcnJvcihcbiAgICAgICAgICAgIGBFcnJvciBlbmNvdW50ZXJlZCB3aGlsZSBjYW5jZWxpbmcgaW52b2ljZSAoJHtwYXJhbXMuaW52b2ljZUlkfSk6ICR7SlNPTi5zdHJpbmdpZnkoZXJyb3JNZXNzYWdlKX1gXG4gICAgICAgICk7XG4gICAgICAgIHRocm93IG5ldyBLZWV6QXBpRXJyb3IoXG4gICAgICAgICAgICBgRmFpbGVkIHRvIGNhbmNlbCBpbnZvaWNlOiAke0pTT04uc3RyaW5naWZ5KGVycm9yTWVzc2FnZSl9YCxcbiAgICAgICAgICAgIGF4aW9zRXJyb3IucmVzcG9uc2U/LnN0YXR1cyxcbiAgICAgICAgICAgIGVycm9yXG4gICAgICAgICk7XG4gICAgfVxufVxuIl19
@@ -0,0 +1,97 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.apiCreateInvoice = apiCreateInvoice;
7
+ const axios_1 = __importDefault(require("axios"));
8
+ const logger_1 = require("../../helpers/logger");
9
+ const KeezError_1 = require("../../errors/KeezError");
10
+ const constants_1 = require("../../config/constants");
11
+ const measureUnit_1 = require("../../config/measureUnit");
12
+ const keezLogger = logger_1.logger.child({
13
+ _library: 'KeezWrapper',
14
+ _method: 'Invoices',
15
+ });
16
+ /**
17
+ * Helper to get current date in YYYYMMDD format
18
+ */
19
+ function getCurrentDateNumber() {
20
+ const now = new Date();
21
+ const year = now.getFullYear();
22
+ const month = String(now.getMonth() + constants_1.MONTH_INDEX_OFFSET).padStart(constants_1.DATE_PAD_LENGTH, '0');
23
+ const day = String(now.getDate()).padStart(constants_1.DATE_PAD_LENGTH, '0');
24
+ return parseInt(`${year}${month}${day}`, constants_1.DECIMAL_RADIX);
25
+ }
26
+ /**
27
+ * Create an invoice
28
+ * @param params as defined in the interface
29
+ * @returns {Promise<string>} - The external ID of the created invoice
30
+ */
31
+ async function apiCreateInvoice(params) {
32
+ const url = `${params.baseDomain}/api/v1.0/public-api/${params.appClientId}/invoices`;
33
+ const currentDate = getCurrentDateNumber();
34
+ const body = {
35
+ series: params.invoice.series,
36
+ documentDate: params.invoice.documentDate ?? currentDate,
37
+ dueDate: params.invoice.dueDate ?? currentDate,
38
+ vatOnCollection: params.invoice.vatOnCollection ?? false,
39
+ currencyCode: params.invoice.currencyCode,
40
+ originalNetAmount: params.invoice.amount,
41
+ originalNetAmountCurrency: params.invoice.amount,
42
+ originalVatAmount: constants_1.DEFAULT_VAT_AMOUNT,
43
+ originalVatAmountCurrency: constants_1.DEFAULT_VAT_AMOUNT,
44
+ netAmount: params.invoice.amount,
45
+ netAmountCurrency: params.invoice.amount,
46
+ vatAmount: constants_1.DEFAULT_VAT_AMOUNT,
47
+ vatAmountCurrency: constants_1.DEFAULT_VAT_AMOUNT,
48
+ grossAmount: params.invoice.amount,
49
+ grossAmountCurrency: params.invoice.amount,
50
+ paymentTypeId: params.invoice.paymentType,
51
+ partner: {
52
+ isLegalPerson: params.invoice.partner.isLegalPerson,
53
+ partnerName: params.invoice.partner.partnerName,
54
+ countryCode: params.invoice.partner.countryCode,
55
+ countryName: params.invoice.partner.countryName,
56
+ countyCode: params.invoice.partner.countyCode,
57
+ countyName: params.invoice.partner.countyName,
58
+ cityName: params.invoice.partner.cityName,
59
+ addressDetails: params.invoice.partner.addressDetails,
60
+ },
61
+ invoiceDetails: [
62
+ {
63
+ itemExternalId: params.invoice.itemId,
64
+ measureUnitId: params.invoice.measureUnitId ?? measureUnit_1.MeasureUnit.PIECE,
65
+ quantity: params.invoice.quantity ?? constants_1.DEFAULT_INVOICE_QUANTITY,
66
+ unitPrice: params.invoice.amount,
67
+ originalNetAmount: params.invoice.amount,
68
+ originalNetAmountCurrency: params.invoice.amount,
69
+ originalVatAmount: constants_1.DEFAULT_VAT_AMOUNT,
70
+ originalVatAmountCurrency: constants_1.DEFAULT_VAT_AMOUNT,
71
+ netAmount: params.invoice.amount,
72
+ netAmountCurrency: params.invoice.amount,
73
+ vatAmount: constants_1.DEFAULT_VAT_AMOUNT,
74
+ vatAmountCurrency: constants_1.DEFAULT_VAT_AMOUNT,
75
+ grossAmount: params.invoice.amount,
76
+ grossAmountCurrency: params.invoice.amount,
77
+ },
78
+ ],
79
+ };
80
+ try {
81
+ const response = await axios_1.default.post(url, body, {
82
+ headers: {
83
+ Authorization: `Bearer ${params.bearerToken}`,
84
+ 'Content-Type': 'application/json',
85
+ },
86
+ timeout: constants_1.HTTP_REQUEST_TIMEOUT_MS,
87
+ });
88
+ return response.data.externalId;
89
+ }
90
+ catch (error) {
91
+ const axiosError = error;
92
+ const errorMessage = axiosError.response?.data?.Message || axiosError.message;
93
+ keezLogger.error(`Error encountered while creating invoice: ${errorMessage}`);
94
+ throw new KeezError_1.KeezApiError(`Failed to create invoice: ${errorMessage}`, axiosError.response?.status, error);
95
+ }
96
+ }
97
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create.js","sourceRoot":"","sources":["../../../../src/api/invoices/create.ts"],"names":[],"mappings":"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","sourcesContent":["import axios, { AxiosError } from 'axios';\nimport { logger } from '@/helpers/logger';\nimport { InvoiceRequest } from '@/dto/createInvoiceRequest';\nimport { KeezApiError } from '@/errors/KeezError';\nimport {\n    HTTP_REQUEST_TIMEOUT_MS,\n    DATE_PAD_LENGTH,\n    MONTH_INDEX_OFFSET,\n    DECIMAL_RADIX,\n    DEFAULT_VAT_AMOUNT,\n    DEFAULT_INVOICE_QUANTITY,\n} from '@/config/constants';\nimport { MeasureUnit } from '@/config/measureUnit';\n\nconst keezLogger = logger.child({\n    _library: 'KeezWrapper',\n    _method: 'Invoices',\n});\n\n/**\n * baseDomain - The base domain for the API\n * appId - The application ID\n * appClientId - The application client ID\n * bearerToken - The bearer token obtained at the authentication stage\n * itemId - The item ID\n */\ninterface CreateInvoiceParams {\n    readonly baseDomain: string;\n    readonly appId: string;\n    readonly appClientId: string;\n    readonly bearerToken: string;\n    readonly invoice: InvoiceRequest;\n}\n\n/**\n * Helper to get current date in YYYYMMDD format\n */\nfunction getCurrentDateNumber(): number {\n    const now = new Date();\n    const year = now.getFullYear();\n    const month = String(now.getMonth() + MONTH_INDEX_OFFSET).padStart(DATE_PAD_LENGTH, '0');\n    const day = String(now.getDate()).padStart(DATE_PAD_LENGTH, '0');\n    return parseInt(`${year}${month}${day}`, DECIMAL_RADIX);\n}\n\n/**\n * Create an invoice\n * @param params as defined in the interface\n * @returns {Promise<string>} - The external ID of the created invoice\n */\nexport async function apiCreateInvoice(params: CreateInvoiceParams): Promise<string> {\n    const url = `${params.baseDomain}/api/v1.0/public-api/${params.appClientId}/invoices`;\n    const currentDate = getCurrentDateNumber();\n\n    const body = {\n        series: params.invoice.series,\n        documentDate: params.invoice.documentDate ?? currentDate,\n        dueDate: params.invoice.dueDate ?? currentDate,\n        vatOnCollection: params.invoice.vatOnCollection ?? false,\n        currencyCode: params.invoice.currencyCode,\n        originalNetAmount: params.invoice.amount,\n        originalNetAmountCurrency: params.invoice.amount,\n        originalVatAmount: DEFAULT_VAT_AMOUNT,\n        originalVatAmountCurrency: DEFAULT_VAT_AMOUNT,\n        netAmount: params.invoice.amount,\n        netAmountCurrency: params.invoice.amount,\n        vatAmount: DEFAULT_VAT_AMOUNT,\n        vatAmountCurrency: DEFAULT_VAT_AMOUNT,\n        grossAmount: params.invoice.amount,\n        grossAmountCurrency: params.invoice.amount,\n        paymentTypeId: params.invoice.paymentType,\n        partner: {\n            isLegalPerson: params.invoice.partner.isLegalPerson,\n            partnerName: params.invoice.partner.partnerName,\n            countryCode: params.invoice.partner.countryCode,\n            countryName: params.invoice.partner.countryName,\n            countyCode: params.invoice.partner.countyCode,\n            countyName: params.invoice.partner.countyName,\n            cityName: params.invoice.partner.cityName,\n            addressDetails: params.invoice.partner.addressDetails,\n        },\n        invoiceDetails: [\n            {\n                itemExternalId: params.invoice.itemId,\n                measureUnitId: params.invoice.measureUnitId ?? MeasureUnit.PIECE,\n                quantity: params.invoice.quantity ?? DEFAULT_INVOICE_QUANTITY,\n                unitPrice: params.invoice.amount,\n                originalNetAmount: params.invoice.amount,\n                originalNetAmountCurrency: params.invoice.amount,\n                originalVatAmount: DEFAULT_VAT_AMOUNT,\n                originalVatAmountCurrency: DEFAULT_VAT_AMOUNT,\n                netAmount: params.invoice.amount,\n                netAmountCurrency: params.invoice.amount,\n                vatAmount: DEFAULT_VAT_AMOUNT,\n                vatAmountCurrency: DEFAULT_VAT_AMOUNT,\n                grossAmount: params.invoice.amount,\n                grossAmountCurrency: params.invoice.amount,\n            },\n        ],\n    };\n\n    try {\n        const response = await axios.post(url, body, {\n            headers: {\n                Authorization: `Bearer ${params.bearerToken}`,\n                'Content-Type': 'application/json',\n            },\n            timeout: HTTP_REQUEST_TIMEOUT_MS,\n        });\n\n        return response.data.externalId;\n    } catch (error) {\n        const axiosError = error as AxiosError<{ Message?: string }>;\n        const errorMessage = axiosError.response?.data?.Message || axiosError.message;\n        keezLogger.error(`Error encountered while creating invoice: ${errorMessage}`);\n        throw new KeezApiError(`Failed to create invoice: ${errorMessage}`, axiosError.response?.status, error);\n    }\n}\n"]}
@@ -0,0 +1,33 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.apiDeleteInvoice = apiDeleteInvoice;
7
+ const axios_1 = __importDefault(require("axios"));
8
+ const logger_1 = require("../../helpers/logger");
9
+ const KeezError_1 = require("../../errors/KeezError");
10
+ const constants_1 = require("../../config/constants");
11
+ const keezLogger = logger_1.logger.child({ _library: 'KeezWrapper', _method: 'Invoices' });
12
+ async function apiDeleteInvoice(params) {
13
+ const url = `${params.baseDomain}/api/v1.0/public-api/${params.appClientId}/invoices`;
14
+ try {
15
+ await axios_1.default.delete(url, {
16
+ headers: {
17
+ Authorization: `Bearer ${params.bearerToken}`,
18
+ 'Content-Type': 'application/json',
19
+ },
20
+ data: {
21
+ externalId: params.invoiceId,
22
+ },
23
+ timeout: constants_1.HTTP_REQUEST_TIMEOUT_MS,
24
+ });
25
+ }
26
+ catch (error) {
27
+ const axiosError = error;
28
+ const errorMessage = axiosError.response?.data || axiosError.message;
29
+ keezLogger.error(`Error encountered while deleting invoice (${params.invoiceId}): ${JSON.stringify(errorMessage)}`);
30
+ throw new KeezError_1.KeezApiError(`Failed to delete invoice: ${JSON.stringify(errorMessage)}`, axiosError.response?.status, error);
31
+ }
32
+ }
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVsZXRlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2FwaS9pbnZvaWNlcy9kZWxldGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFlQSw0Q0EwQkM7QUF6Q0Qsa0RBQTBDO0FBQzFDLDZDQUEwQztBQUMxQyxrREFBa0Q7QUFDbEQsa0RBQTZEO0FBRTdELE1BQU0sVUFBVSxHQUFHLGVBQU0sQ0FBQyxLQUFLLENBQUMsRUFBRSxRQUFRLEVBQUUsYUFBYSxFQUFFLE9BQU8sRUFBRSxVQUFVLEVBQUUsQ0FBQyxDQUFDO0FBVTNFLEtBQUssVUFBVSxnQkFBZ0IsQ0FBQyxNQUEyQjtJQUM5RCxNQUFNLEdBQUcsR0FBRyxHQUFHLE1BQU0sQ0FBQyxVQUFVLHdCQUF3QixNQUFNLENBQUMsV0FBVyxXQUFXLENBQUM7SUFFdEYsSUFBSSxDQUFDO1FBQ0QsTUFBTSxlQUFLLENBQUMsTUFBTSxDQUFDLEdBQUcsRUFBRTtZQUNwQixPQUFPLEVBQUU7Z0JBQ0wsYUFBYSxFQUFFLFVBQVUsTUFBTSxDQUFDLFdBQVcsRUFBRTtnQkFDN0MsY0FBYyxFQUFFLGtCQUFrQjthQUNyQztZQUNELElBQUksRUFBRTtnQkFDRixVQUFVLEVBQUUsTUFBTSxDQUFDLFNBQVM7YUFDL0I7WUFDRCxPQUFPLEVBQUUsbUNBQXVCO1NBQ25DLENBQUMsQ0FBQztJQUNQLENBQUM7SUFBQyxPQUFPLEtBQUssRUFBRSxDQUFDO1FBQ2IsTUFBTSxVQUFVLEdBQUcsS0FBbUIsQ0FBQztRQUN2QyxNQUFNLFlBQVksR0FBRyxVQUFVLENBQUMsUUFBUSxFQUFFLElBQUksSUFBSSxVQUFVLENBQUMsT0FBTyxDQUFDO1FBQ3JFLFVBQVUsQ0FBQyxLQUFLLENBQ1osNkNBQTZDLE1BQU0sQ0FBQyxTQUFTLE1BQU0sSUFBSSxDQUFDLFNBQVMsQ0FBQyxZQUFZLENBQUMsRUFBRSxDQUNwRyxDQUFDO1FBQ0YsTUFBTSxJQUFJLHdCQUFZLENBQ2xCLDZCQUE2QixJQUFJLENBQUMsU0FBUyxDQUFDLFlBQVksQ0FBQyxFQUFFLEVBQzNELFVBQVUsQ0FBQyxRQUFRLEVBQUUsTUFBTSxFQUMzQixLQUFLLENBQ1IsQ0FBQztJQUNOLENBQUM7QUFDTCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGF4aW9zLCB7IEF4aW9zRXJyb3IgfSBmcm9tICdheGlvcyc7XG5pbXBvcnQgeyBsb2dnZXIgfSBmcm9tICdAL2hlbHBlcnMvbG9nZ2VyJztcbmltcG9ydCB7IEtlZXpBcGlFcnJvciB9IGZyb20gJ0AvZXJyb3JzL0tlZXpFcnJvcic7XG5pbXBvcnQgeyBIVFRQX1JFUVVFU1RfVElNRU9VVF9NUyB9IGZyb20gJ0AvY29uZmlnL2NvbnN0YW50cyc7XG5cbmNvbnN0IGtlZXpMb2dnZXIgPSBsb2dnZXIuY2hpbGQoeyBfbGlicmFyeTogJ0tlZXpXcmFwcGVyJywgX21ldGhvZDogJ0ludm9pY2VzJyB9KTtcblxuaW50ZXJmYWNlIERlbGV0ZUludm9pY2VQYXJhbXMge1xuICAgIHJlYWRvbmx5IGJhc2VEb21haW46IHN0cmluZztcbiAgICByZWFkb25seSBhcHBJZDogc3RyaW5nO1xuICAgIHJlYWRvbmx5IGFwcENsaWVudElkOiBzdHJpbmc7XG4gICAgcmVhZG9ubHkgYmVhcmVyVG9rZW46IHN0cmluZztcbiAgICByZWFkb25seSBpbnZvaWNlSWQ6IHN0cmluZztcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGFwaURlbGV0ZUludm9pY2UocGFyYW1zOiBEZWxldGVJbnZvaWNlUGFyYW1zKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgY29uc3QgdXJsID0gYCR7cGFyYW1zLmJhc2VEb21haW59L2FwaS92MS4wL3B1YmxpYy1hcGkvJHtwYXJhbXMuYXBwQ2xpZW50SWR9L2ludm9pY2VzYDtcblxuICAgIHRyeSB7XG4gICAgICAgIGF3YWl0IGF4aW9zLmRlbGV0ZSh1cmwsIHtcbiAgICAgICAgICAgIGhlYWRlcnM6IHtcbiAgICAgICAgICAgICAgICBBdXRob3JpemF0aW9uOiBgQmVhcmVyICR7cGFyYW1zLmJlYXJlclRva2VufWAsXG4gICAgICAgICAgICAgICAgJ0NvbnRlbnQtVHlwZSc6ICdhcHBsaWNhdGlvbi9qc29uJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICBkYXRhOiB7XG4gICAgICAgICAgICAgICAgZXh0ZXJuYWxJZDogcGFyYW1zLmludm9pY2VJZCxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICB0aW1lb3V0OiBIVFRQX1JFUVVFU1RfVElNRU9VVF9NUyxcbiAgICAgICAgfSk7XG4gICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgICAgY29uc3QgYXhpb3NFcnJvciA9IGVycm9yIGFzIEF4aW9zRXJyb3I7XG4gICAgICAgIGNvbnN0IGVycm9yTWVzc2FnZSA9IGF4aW9zRXJyb3IucmVzcG9uc2U/LmRhdGEgfHwgYXhpb3NFcnJvci5tZXNzYWdlO1xuICAgICAgICBrZWV6TG9nZ2VyLmVycm9yKFxuICAgICAgICAgICAgYEVycm9yIGVuY291bnRlcmVkIHdoaWxlIGRlbGV0aW5nIGludm9pY2UgKCR7cGFyYW1zLmludm9pY2VJZH0pOiAke0pTT04uc3RyaW5naWZ5KGVycm9yTWVzc2FnZSl9YFxuICAgICAgICApO1xuICAgICAgICB0aHJvdyBuZXcgS2VlekFwaUVycm9yKFxuICAgICAgICAgICAgYEZhaWxlZCB0byBkZWxldGUgaW52b2ljZTogJHtKU09OLnN0cmluZ2lmeShlcnJvck1lc3NhZ2UpfWAsXG4gICAgICAgICAgICBheGlvc0Vycm9yLnJlc3BvbnNlPy5zdGF0dXMsXG4gICAgICAgICAgICBlcnJvclxuICAgICAgICApO1xuICAgIH1cbn1cbiJdfQ==