@entur-partner/util 1.0.1 → 1.1.2

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.
package/CHANGELOG.md CHANGED
@@ -3,6 +3,28 @@
3
3
  All notable changes to this project will be documented in this file.
4
4
  See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
5
5
 
6
+ ## [1.1.2](https://bitbucket.org/enturas/entur-partner-packages/compare/@entur-partner/util@1.1.1...@entur-partner/util@1.1.2) (2022-02-10)
7
+
8
+ **Note:** Version bump only for package @entur-partner/util
9
+
10
+ ## [1.1.1](https://bitbucket.org/enturas/entur-partner-packages/compare/@entur-partner/util@1.1.0...@entur-partner/util@1.1.1) (2022-02-07)
11
+
12
+ ### Bug Fixes
13
+
14
+ - **deps:** pin dependencies ([840fa3d](https://bitbucket.org/enturas/entur-partner-packages/commits/840fa3d44ce62deea2a69131d30da4d979bc8fe9))
15
+
16
+ # [1.1.0](https://bitbucket.org/enturas/entur-partner-packages/compare/@entur-partner/util@1.0.2...@entur-partner/util@1.1.0) (2020-12-02)
17
+
18
+ ### Features
19
+
20
+ - add permissions checks ([c8a3e16](https://bitbucket.org/enturas/entur-partner-packages/commits/c8a3e16cb808d87edfb35908e6def30cfe85e09b))
21
+
22
+ ## [1.0.2](https://bitbucket.org/enturas/entur-partner-packages/compare/@entur-partner/util@1.0.1...@entur-partner/util@1.0.2) (2020-11-24)
23
+
24
+ ### Bug Fixes
25
+
26
+ - try fix date.test on windows ([52c856d](https://bitbucket.org/enturas/entur-partner-packages/commits/52c856dbda453b370a8a503b532cf04dd72426b9))
27
+
6
28
  ## [1.0.1](https://bitbucket.org/enturas/entur-partner-packages/compare/@entur-partner/util@1.0.0...@entur-partner/util@1.0.1) (2020-11-23)
7
29
 
8
30
  **Note:** Version bump only for package @entur-partner/util
package/dist/index.d.ts CHANGED
@@ -1,3 +1,4 @@
1
1
  export { assertIsDefined } from './assertions';
2
2
  export { isString, isFunction } from './helpers';
3
3
  export { localeDate, localeDateTime, isDateString, isDate } from './date';
4
+ export * from './permissions';
@@ -0,0 +1,4 @@
1
+ import { BusinessCapability } from '@entur-partner/permission-client-node';
2
+ export declare function hasAllPermissions(all: BusinessCapability[] | BusinessCapability, permissions: BusinessCapability[]): boolean;
3
+ export declare function hasOneOfPermissions(oneOf: BusinessCapability[], permissions: BusinessCapability[]): boolean;
4
+ export declare function hasPermissions(permissions: BusinessCapability[], requiredPermission: BusinessCapability): boolean;
@@ -55,7 +55,34 @@ var isDateString = function isDateString(dateString) {
55
55
  }
56
56
  };
57
57
 
58
+ function checkPermission(permission1, permission2) {
59
+ return permission1.access === permission2.access && permission1.operation === permission2.operation;
60
+ }
61
+
62
+ function hasAllPermissions(all, permissions) {
63
+ if (!Array.isArray(all)) {
64
+ all = [all];
65
+ }
66
+
67
+ return all.every(function (requiredPermission) {
68
+ return hasPermissions(permissions, requiredPermission);
69
+ });
70
+ }
71
+ function hasOneOfPermissions(oneOf, permissions) {
72
+ return oneOf.length > 0 ? oneOf.some(function (requiredPermission) {
73
+ return hasPermissions(permissions, requiredPermission);
74
+ }) : true;
75
+ }
76
+ function hasPermissions(permissions, requiredPermission) {
77
+ return permissions.some(function (userPermission) {
78
+ return checkPermission(requiredPermission, userPermission);
79
+ });
80
+ }
81
+
58
82
  exports.assertIsDefined = assertIsDefined;
83
+ exports.hasAllPermissions = hasAllPermissions;
84
+ exports.hasOneOfPermissions = hasOneOfPermissions;
85
+ exports.hasPermissions = hasPermissions;
59
86
  exports.isDate = isDate;
60
87
  exports.isDateString = isDateString;
61
88
  exports.isFunction = isFunction;
@@ -1 +1 @@
1
- {"version":3,"file":"util.cjs.development.js","sources":["../src/assertions.ts","../src/helpers.ts","../src/date.ts"],"sourcesContent":["export function assertIsDefined<T>(\n val: T,\n message?: string\n): asserts val is NonNullable<T> {\n if (val === undefined || val === null) {\n if (message) {\n throw new Error(message);\n }\n throw new Error(`Expected 'val' to be defined, but received ${val}`);\n }\n}\n","export function isFunction<T>(functionToCheck: any): functionToCheck is T {\n return (\n functionToCheck && {}.toString.call(functionToCheck) === '[object Function]'\n );\n}\n\nexport function isString(stringToCheck: any): stringToCheck is string {\n return typeof stringToCheck === 'string' || stringToCheck instanceof String;\n}\n","import { format, parseISO, isDate as isDateFn } from 'date-fns';\nimport { nb } from 'date-fns/locale';\n\nimport { isString } from './helpers';\n\nconst formatLocalDate = (date: Date, locale: string, formatString: string) => {\n const localeConfig = locale === 'nb' ? { locale: nb } : {};\n return format(date, formatString, localeConfig);\n};\n\nexport const localeDate = (date: Date | string, locale: string) => {\n const dateObject = isString(date) ? parseISO(date) : date;\n return formatLocalDate(dateObject, locale, 'P');\n};\n\nexport const localeDateTime = (date: Date | string, locale: string) => {\n const dateObject = isString(date) ? parseISO(date) : date;\n return formatLocalDate(dateObject, locale, 'P - p');\n};\n\n// Redefine is Date for better type checking\nexport function isDate(dateToCheck: any): dateToCheck is Date {\n return isDateFn(dateToCheck);\n}\n\nexport const isDateString = (dateString: string) => {\n try {\n const date = parseISO(dateString);\n if (isNaN(date.getTime())) {\n return false;\n }\n return true;\n } catch (e) {\n return false;\n }\n};\n"],"names":["assertIsDefined","val","message","undefined","Error","isFunction","functionToCheck","toString","call","isString","stringToCheck","String","formatLocalDate","date","locale","formatString","localeConfig","nb","format","localeDate","dateObject","parseISO","localeDateTime","isDate","dateToCheck","isDateFn","isDateString","dateString","isNaN","getTime","e"],"mappings":";;;;;;;SAAgBA,gBACdC,KACAC;AAEA,MAAID,GAAG,KAAKE,SAAR,IAAqBF,GAAG,KAAK,IAAjC,EAAuC;AACrC,QAAIC,OAAJ,EAAa;AACX,YAAM,IAAIE,KAAJ,CAAUF,OAAV,CAAN;AACD;;AACD,UAAM,IAAIE,KAAJ,iDAAwDH,GAAxD,CAAN;AACD;AACF;;SCVeI,WAAcC;AAC5B,SACEA,eAAe,IAAI,GAAGC,QAAH,CAAYC,IAAZ,CAAiBF,eAAjB,MAAsC,mBAD3D;AAGD;AAED,SAAgBG,SAASC;AACvB,SAAO,OAAOA,aAAP,KAAyB,QAAzB,IAAqCA,aAAa,YAAYC,MAArE;AACD;;ACHD,IAAMC,eAAe,GAAG,SAAlBA,eAAkB,CAACC,IAAD,EAAaC,QAAb,EAA6BC,YAA7B;AACtB,MAAMC,YAAY,GAAGF,QAAM,KAAK,IAAX,GAAkB;AAAEA,IAAAA,MAAM,EAAEG;AAAV,GAAlB,GAAmC,EAAxD;AACA,SAAOC,cAAM,CAACL,IAAD,EAAOE,YAAP,EAAqBC,YAArB,CAAb;AACD,CAHD;;AAKA,IAAaG,UAAU,GAAG,SAAbA,UAAa,CAACN,IAAD,EAAsBC,MAAtB;AACxB,MAAMM,UAAU,GAAGX,QAAQ,CAACI,IAAD,CAAR,GAAiBQ,gBAAQ,CAACR,IAAD,CAAzB,GAAkCA,IAArD;AACA,SAAOD,eAAe,CAACQ,UAAD,EAAaN,MAAb,EAAqB,GAArB,CAAtB;AACD,CAHM;AAKP,IAAaQ,cAAc,GAAG,SAAjBA,cAAiB,CAACT,IAAD,EAAsBC,MAAtB;AAC5B,MAAMM,UAAU,GAAGX,QAAQ,CAACI,IAAD,CAAR,GAAiBQ,gBAAQ,CAACR,IAAD,CAAzB,GAAkCA,IAArD;AACA,SAAOD,eAAe,CAACQ,UAAD,EAAaN,MAAb,EAAqB,OAArB,CAAtB;AACD,CAHM;;AAMP,SAAgBS,OAAOC;AACrB,SAAOC,cAAQ,CAACD,WAAD,CAAf;AACD;AAED,IAAaE,YAAY,GAAG,SAAfA,YAAe,CAACC,UAAD;AAC1B,MAAI;AACF,QAAMd,IAAI,GAAGQ,gBAAQ,CAACM,UAAD,CAArB;;AACA,QAAIC,KAAK,CAACf,IAAI,CAACgB,OAAL,EAAD,CAAT,EAA2B;AACzB,aAAO,KAAP;AACD;;AACD,WAAO,IAAP;AACD,GAND,CAME,OAAOC,CAAP,EAAU;AACV,WAAO,KAAP;AACD;AACF,CAVM;;;;;;;;;;"}
1
+ {"version":3,"file":"util.cjs.development.js","sources":["../src/assertions.ts","../src/helpers.ts","../src/date.ts","../src/permissions.ts"],"sourcesContent":["export function assertIsDefined<T>(\n val: T,\n message?: string\n): asserts val is NonNullable<T> {\n if (val === undefined || val === null) {\n if (message) {\n throw new Error(message);\n }\n throw new Error(`Expected 'val' to be defined, but received ${val}`);\n }\n}\n","export function isFunction<T>(functionToCheck: any): functionToCheck is T {\n return (\n functionToCheck && {}.toString.call(functionToCheck) === '[object Function]'\n );\n}\n\nexport function isString(stringToCheck: any): stringToCheck is string {\n return typeof stringToCheck === 'string' || stringToCheck instanceof String;\n}\n","import { format, parseISO, isDate as isDateFn } from 'date-fns';\nimport { nb } from 'date-fns/locale';\n\nimport { isString } from './helpers';\n\nconst formatLocalDate = (date: Date, locale: string, formatString: string) => {\n const localeConfig = locale === 'nb' ? { locale: nb } : {};\n return format(date, formatString, localeConfig);\n};\n\nexport const localeDate = (date: Date | string, locale: string) => {\n const dateObject = isString(date) ? parseISO(date) : date;\n return formatLocalDate(dateObject, locale, 'P');\n};\n\nexport const localeDateTime = (date: Date | string, locale: string) => {\n const dateObject = isString(date) ? parseISO(date) : date;\n return formatLocalDate(dateObject, locale, 'P - p');\n};\n\n// Redefine is Date for better type checking\nexport function isDate(dateToCheck: any): dateToCheck is Date {\n return isDateFn(dateToCheck);\n}\n\nexport const isDateString = (dateString: string) => {\n try {\n const date = parseISO(dateString);\n if (isNaN(date.getTime())) {\n return false;\n }\n return true;\n } catch (e) {\n return false;\n }\n};\n","import { BusinessCapability } from '@entur-partner/permission-client-node';\n\nfunction checkPermission(\n permission1: BusinessCapability,\n permission2: BusinessCapability\n) {\n return (\n permission1.access === permission2.access &&\n permission1.operation === permission2.operation\n );\n}\n\nexport function hasAllPermissions(\n all: BusinessCapability[] | BusinessCapability,\n permissions: BusinessCapability[]\n) {\n if (!Array.isArray(all)) {\n all = [all];\n }\n return all.every((requiredPermission) =>\n hasPermissions(permissions, requiredPermission)\n );\n}\n\nexport function hasOneOfPermissions(\n oneOf: BusinessCapability[],\n permissions: BusinessCapability[]\n) {\n return oneOf.length > 0\n ? oneOf.some((requiredPermission) =>\n hasPermissions(permissions, requiredPermission)\n )\n : true;\n}\n\nexport function hasPermissions(\n permissions: BusinessCapability[],\n requiredPermission: BusinessCapability\n) {\n return permissions.some((userPermission) =>\n checkPermission(requiredPermission, userPermission)\n );\n}\n"],"names":["assertIsDefined","val","message","undefined","Error","isFunction","functionToCheck","toString","call","isString","stringToCheck","String","formatLocalDate","date","locale","formatString","localeConfig","nb","format","localeDate","dateObject","parseISO","localeDateTime","isDate","dateToCheck","isDateFn","isDateString","dateString","isNaN","getTime","e","checkPermission","permission1","permission2","access","operation","hasAllPermissions","all","permissions","Array","isArray","every","requiredPermission","hasPermissions","hasOneOfPermissions","oneOf","length","some","userPermission"],"mappings":";;;;;;;SAAgBA,gBACdC,KACAC;AAEA,MAAID,GAAG,KAAKE,SAAR,IAAqBF,GAAG,KAAK,IAAjC,EAAuC;AACrC,QAAIC,OAAJ,EAAa;AACX,YAAM,IAAIE,KAAJ,CAAUF,OAAV,CAAN;AACD;;AACD,UAAM,IAAIE,KAAJ,iDAAwDH,GAAxD,CAAN;AACD;AACF;;SCVeI,WAAcC;AAC5B,SACEA,eAAe,IAAI,GAAGC,QAAH,CAAYC,IAAZ,CAAiBF,eAAjB,MAAsC,mBAD3D;AAGD;SAEeG,SAASC;AACvB,SAAO,OAAOA,aAAP,KAAyB,QAAzB,IAAqCA,aAAa,YAAYC,MAArE;AACD;;ACHD,IAAMC,eAAe,GAAG,SAAlBA,eAAkB,CAACC,IAAD,EAAaC,QAAb,EAA6BC,YAA7B;AACtB,MAAMC,YAAY,GAAGF,QAAM,KAAK,IAAX,GAAkB;AAAEA,IAAAA,MAAM,EAAEG;AAAV,GAAlB,GAAmC,EAAxD;AACA,SAAOC,cAAM,CAACL,IAAD,EAAOE,YAAP,EAAqBC,YAArB,CAAb;AACD,CAHD;;IAKaG,UAAU,GAAG,SAAbA,UAAa,CAACN,IAAD,EAAsBC,MAAtB;AACxB,MAAMM,UAAU,GAAGX,QAAQ,CAACI,IAAD,CAAR,GAAiBQ,gBAAQ,CAACR,IAAD,CAAzB,GAAkCA,IAArD;AACA,SAAOD,eAAe,CAACQ,UAAD,EAAaN,MAAb,EAAqB,GAArB,CAAtB;AACD;IAEYQ,cAAc,GAAG,SAAjBA,cAAiB,CAACT,IAAD,EAAsBC,MAAtB;AAC5B,MAAMM,UAAU,GAAGX,QAAQ,CAACI,IAAD,CAAR,GAAiBQ,gBAAQ,CAACR,IAAD,CAAzB,GAAkCA,IAArD;AACA,SAAOD,eAAe,CAACQ,UAAD,EAAaN,MAAb,EAAqB,OAArB,CAAtB;AACD;;SAGeS,OAAOC;AACrB,SAAOC,cAAQ,CAACD,WAAD,CAAf;AACD;IAEYE,YAAY,GAAG,SAAfA,YAAe,CAACC,UAAD;AAC1B,MAAI;AACF,QAAMd,IAAI,GAAGQ,gBAAQ,CAACM,UAAD,CAArB;;AACA,QAAIC,KAAK,CAACf,IAAI,CAACgB,OAAL,EAAD,CAAT,EAA2B;AACzB,aAAO,KAAP;AACD;;AACD,WAAO,IAAP;AACD,GAND,CAME,OAAOC,CAAP,EAAU;AACV,WAAO,KAAP;AACD;AACF;;ACjCD,SAASC,eAAT,CACEC,WADF,EAEEC,WAFF;AAIE,SACED,WAAW,CAACE,MAAZ,KAAuBD,WAAW,CAACC,MAAnC,IACAF,WAAW,CAACG,SAAZ,KAA0BF,WAAW,CAACE,SAFxC;AAID;;SAEeC,kBACdC,KACAC;AAEA,MAAI,CAACC,KAAK,CAACC,OAAN,CAAcH,GAAd,CAAL,EAAyB;AACvBA,IAAAA,GAAG,GAAG,CAACA,GAAD,CAAN;AACD;;AACD,SAAOA,GAAG,CAACI,KAAJ,CAAU,UAACC,kBAAD;AAAA,WACfC,cAAc,CAACL,WAAD,EAAcI,kBAAd,CADC;AAAA,GAAV,CAAP;AAGD;SAEeE,oBACdC,OACAP;AAEA,SAAOO,KAAK,CAACC,MAAN,GAAe,CAAf,GACHD,KAAK,CAACE,IAAN,CAAW,UAACL,kBAAD;AAAA,WACTC,cAAc,CAACL,WAAD,EAAcI,kBAAd,CADL;AAAA,GAAX,CADG,GAIH,IAJJ;AAKD;SAEeC,eACdL,aACAI;AAEA,SAAOJ,WAAW,CAACS,IAAZ,CAAiB,UAACC,cAAD;AAAA,WACtBjB,eAAe,CAACW,kBAAD,EAAqBM,cAArB,CADO;AAAA,GAAjB,CAAP;AAGD;;;;;;;;;;;;;"}
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("date-fns"),r=require("date-fns/locale");function t(e){return"string"==typeof e||e instanceof String}var n=function(t,n,o){return e.format(t,o,"nb"===n?{locale:r.nb}:{})};exports.assertIsDefined=function(e,r){if(null==e){if(r)throw new Error(r);throw new Error("Expected 'val' to be defined, but received "+e)}},exports.isDate=function(r){return e.isDate(r)},exports.isDateString=function(r){try{var t=e.parseISO(r);return!isNaN(t.getTime())}catch(e){return!1}},exports.isFunction=function(e){return e&&"[object Function]"==={}.toString.call(e)},exports.isString=t,exports.localeDate=function(r,o){var i=t(r)?e.parseISO(r):r;return n(i,o,"P")},exports.localeDateTime=function(r,o){var i=t(r)?e.parseISO(r):r;return n(i,o,"P - p")};
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("date-fns"),r=require("date-fns/locale");function t(e){return"string"==typeof e||e instanceof String}var n=function(t,n,o){return e.format(t,o,"nb"===n?{locale:r.nb}:{})};function o(e,r){return e.some((function(e){return(t=r).access===(n=e).access&&t.operation===n.operation;var t,n}))}exports.assertIsDefined=function(e,r){if(null==e){if(r)throw new Error(r);throw new Error("Expected 'val' to be defined, but received "+e)}},exports.hasAllPermissions=function(e,r){return Array.isArray(e)||(e=[e]),e.every((function(e){return o(r,e)}))},exports.hasOneOfPermissions=function(e,r){return!(e.length>0)||e.some((function(e){return o(r,e)}))},exports.hasPermissions=o,exports.isDate=function(r){return e.isDate(r)},exports.isDateString=function(r){try{var t=e.parseISO(r);return!isNaN(t.getTime())}catch(e){return!1}},exports.isFunction=function(e){return e&&"[object Function]"==={}.toString.call(e)},exports.isString=t,exports.localeDate=function(r,o){var s=t(r)?e.parseISO(r):r;return n(s,o,"P")},exports.localeDateTime=function(r,o){var s=t(r)?e.parseISO(r):r;return n(s,o,"P - p")};
2
2
  //# sourceMappingURL=util.cjs.production.min.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"util.cjs.production.min.js","sources":["../src/helpers.ts","../src/date.ts","../src/assertions.ts"],"sourcesContent":["export function isFunction<T>(functionToCheck: any): functionToCheck is T {\n return (\n functionToCheck && {}.toString.call(functionToCheck) === '[object Function]'\n );\n}\n\nexport function isString(stringToCheck: any): stringToCheck is string {\n return typeof stringToCheck === 'string' || stringToCheck instanceof String;\n}\n","import { format, parseISO, isDate as isDateFn } from 'date-fns';\nimport { nb } from 'date-fns/locale';\n\nimport { isString } from './helpers';\n\nconst formatLocalDate = (date: Date, locale: string, formatString: string) => {\n const localeConfig = locale === 'nb' ? { locale: nb } : {};\n return format(date, formatString, localeConfig);\n};\n\nexport const localeDate = (date: Date | string, locale: string) => {\n const dateObject = isString(date) ? parseISO(date) : date;\n return formatLocalDate(dateObject, locale, 'P');\n};\n\nexport const localeDateTime = (date: Date | string, locale: string) => {\n const dateObject = isString(date) ? parseISO(date) : date;\n return formatLocalDate(dateObject, locale, 'P - p');\n};\n\n// Redefine is Date for better type checking\nexport function isDate(dateToCheck: any): dateToCheck is Date {\n return isDateFn(dateToCheck);\n}\n\nexport const isDateString = (dateString: string) => {\n try {\n const date = parseISO(dateString);\n if (isNaN(date.getTime())) {\n return false;\n }\n return true;\n } catch (e) {\n return false;\n }\n};\n","export function assertIsDefined<T>(\n val: T,\n message?: string\n): asserts val is NonNullable<T> {\n if (val === undefined || val === null) {\n if (message) {\n throw new Error(message);\n }\n throw new Error(`Expected 'val' to be defined, but received ${val}`);\n }\n}\n"],"names":["isString","stringToCheck","String","formatLocalDate","date","locale","formatString","format","nb","val","message","Error","dateToCheck","isDateFn","dateString","parseISO","isNaN","getTime","e","functionToCheck","toString","call","dateObject"],"mappings":"oIAMgBA,EAASC,SACS,iBAAlBA,GAA8BA,aAAyBC,WCFjEC,EAAkB,SAACC,EAAYC,EAAgBC,UAE5CC,SAAOH,EAAME,EADY,OAAXD,EAAkB,CAAEA,OAAQG,MAAO,sCCLxDC,EACAC,MAEID,MAAAA,EAAmC,IACjCC,QACI,IAAIC,MAAMD,SAEZ,IAAIC,oDAAoDF,6BDa3CG,UACdC,SAASD,yBAGU,SAACE,WAEnBV,EAAOW,WAASD,UAClBE,MAAMZ,EAAKa,WAIf,MAAOC,UACA,gCDjCmBC,UAE1BA,GAAyD,sBAAtC,GAAGC,SAASC,KAAKF,0CCQd,SAACf,EAAqBC,OACxCiB,EAAatB,EAASI,GAAQW,WAASX,GAAQA,SAC9CD,EAAgBmB,EAAYjB,EAAQ,6BAGf,SAACD,EAAqBC,OAC5CiB,EAAatB,EAASI,GAAQW,WAASX,GAAQA,SAC9CD,EAAgBmB,EAAYjB,EAAQ"}
1
+ {"version":3,"file":"util.cjs.production.min.js","sources":["../src/helpers.ts","../src/date.ts","../src/permissions.ts","../src/assertions.ts"],"sourcesContent":["export function isFunction<T>(functionToCheck: any): functionToCheck is T {\n return (\n functionToCheck && {}.toString.call(functionToCheck) === '[object Function]'\n );\n}\n\nexport function isString(stringToCheck: any): stringToCheck is string {\n return typeof stringToCheck === 'string' || stringToCheck instanceof String;\n}\n","import { format, parseISO, isDate as isDateFn } from 'date-fns';\nimport { nb } from 'date-fns/locale';\n\nimport { isString } from './helpers';\n\nconst formatLocalDate = (date: Date, locale: string, formatString: string) => {\n const localeConfig = locale === 'nb' ? { locale: nb } : {};\n return format(date, formatString, localeConfig);\n};\n\nexport const localeDate = (date: Date | string, locale: string) => {\n const dateObject = isString(date) ? parseISO(date) : date;\n return formatLocalDate(dateObject, locale, 'P');\n};\n\nexport const localeDateTime = (date: Date | string, locale: string) => {\n const dateObject = isString(date) ? parseISO(date) : date;\n return formatLocalDate(dateObject, locale, 'P - p');\n};\n\n// Redefine is Date for better type checking\nexport function isDate(dateToCheck: any): dateToCheck is Date {\n return isDateFn(dateToCheck);\n}\n\nexport const isDateString = (dateString: string) => {\n try {\n const date = parseISO(dateString);\n if (isNaN(date.getTime())) {\n return false;\n }\n return true;\n } catch (e) {\n return false;\n }\n};\n","import { BusinessCapability } from '@entur-partner/permission-client-node';\n\nfunction checkPermission(\n permission1: BusinessCapability,\n permission2: BusinessCapability\n) {\n return (\n permission1.access === permission2.access &&\n permission1.operation === permission2.operation\n );\n}\n\nexport function hasAllPermissions(\n all: BusinessCapability[] | BusinessCapability,\n permissions: BusinessCapability[]\n) {\n if (!Array.isArray(all)) {\n all = [all];\n }\n return all.every((requiredPermission) =>\n hasPermissions(permissions, requiredPermission)\n );\n}\n\nexport function hasOneOfPermissions(\n oneOf: BusinessCapability[],\n permissions: BusinessCapability[]\n) {\n return oneOf.length > 0\n ? oneOf.some((requiredPermission) =>\n hasPermissions(permissions, requiredPermission)\n )\n : true;\n}\n\nexport function hasPermissions(\n permissions: BusinessCapability[],\n requiredPermission: BusinessCapability\n) {\n return permissions.some((userPermission) =>\n checkPermission(requiredPermission, userPermission)\n );\n}\n","export function assertIsDefined<T>(\n val: T,\n message?: string\n): asserts val is NonNullable<T> {\n if (val === undefined || val === null) {\n if (message) {\n throw new Error(message);\n }\n throw new Error(`Expected 'val' to be defined, but received ${val}`);\n }\n}\n"],"names":["isString","stringToCheck","String","formatLocalDate","date","locale","formatString","format","nb","hasPermissions","permissions","requiredPermission","some","userPermission","permission1","access","permission2","operation","val","message","Error","all","Array","isArray","every","oneOf","length","dateToCheck","isDateFn","dateString","parseISO","isNaN","getTime","e","functionToCheck","toString","call","dateObject"],"mappings":"oIAMgBA,EAASC,SACS,iBAAlBA,GAA8BA,aAAyBC,OCFvE,IAAMC,EAAkB,SAACC,EAAYC,EAAgBC,UAE5CC,SAAOH,EAAME,EADY,OAAXD,EAAkB,CAAEA,OAAQG,MAAO,cC6B1CC,EACdC,EACAC,UAEOD,EAAYE,MAAK,SAACC,UApCzBC,EAqCkBH,GAjCJI,UAHdC,EAoCsCH,GAjCDE,QACnCD,EAAYG,YAAcD,EAAYC,UAN1C,IACEH,EACAE,sCCHAE,EACAC,MAEID,MAAAA,EAAmC,IACjCC,QACI,IAAIC,MAAMD,SAEZ,IAAIC,oDAAoDF,wCDKhEG,EACAX,UAEKY,MAAMC,QAAQF,KACjBA,EAAM,CAACA,IAEFA,EAAIG,OAAM,SAACb,UAChBF,EAAeC,EAAaC,4CAK9Bc,EACAf,WAEOe,EAAMC,OAAS,IAClBD,EAAMb,MAAK,SAACD,UACVF,EAAeC,EAAaC,wDDTbgB,UACdC,SAASD,yBAGU,SAACE,WAEnBzB,EAAO0B,WAASD,UAClBE,MAAM3B,EAAK4B,WAIf,MAAOC,UACA,gCDjCmBC,UAE1BA,GAAyD,sBAAtC,GAAGC,SAASC,KAAKF,0CCQd,SAAC9B,EAAqBC,OACxCgC,EAAarC,EAASI,GAAQ0B,WAAS1B,GAAQA,SAC9CD,EAAgBkC,EAAYhC,EAAQ,6BAGf,SAACD,EAAqBC,OAC5CgC,EAAarC,EAASI,GAAQ0B,WAAS1B,GAAQA,SAC9CD,EAAgBkC,EAAYhC,EAAQ"}
package/dist/util.esm.js CHANGED
@@ -51,5 +51,29 @@ var isDateString = function isDateString(dateString) {
51
51
  }
52
52
  };
53
53
 
54
- export { assertIsDefined, isDate, isDateString, isFunction, isString, localeDate, localeDateTime };
54
+ function checkPermission(permission1, permission2) {
55
+ return permission1.access === permission2.access && permission1.operation === permission2.operation;
56
+ }
57
+
58
+ function hasAllPermissions(all, permissions) {
59
+ if (!Array.isArray(all)) {
60
+ all = [all];
61
+ }
62
+
63
+ return all.every(function (requiredPermission) {
64
+ return hasPermissions(permissions, requiredPermission);
65
+ });
66
+ }
67
+ function hasOneOfPermissions(oneOf, permissions) {
68
+ return oneOf.length > 0 ? oneOf.some(function (requiredPermission) {
69
+ return hasPermissions(permissions, requiredPermission);
70
+ }) : true;
71
+ }
72
+ function hasPermissions(permissions, requiredPermission) {
73
+ return permissions.some(function (userPermission) {
74
+ return checkPermission(requiredPermission, userPermission);
75
+ });
76
+ }
77
+
78
+ export { assertIsDefined, hasAllPermissions, hasOneOfPermissions, hasPermissions, isDate, isDateString, isFunction, isString, localeDate, localeDateTime };
55
79
  //# sourceMappingURL=util.esm.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"util.esm.js","sources":["../src/assertions.ts","../src/helpers.ts","../src/date.ts"],"sourcesContent":["export function assertIsDefined<T>(\n val: T,\n message?: string\n): asserts val is NonNullable<T> {\n if (val === undefined || val === null) {\n if (message) {\n throw new Error(message);\n }\n throw new Error(`Expected 'val' to be defined, but received ${val}`);\n }\n}\n","export function isFunction<T>(functionToCheck: any): functionToCheck is T {\n return (\n functionToCheck && {}.toString.call(functionToCheck) === '[object Function]'\n );\n}\n\nexport function isString(stringToCheck: any): stringToCheck is string {\n return typeof stringToCheck === 'string' || stringToCheck instanceof String;\n}\n","import { format, parseISO, isDate as isDateFn } from 'date-fns';\nimport { nb } from 'date-fns/locale';\n\nimport { isString } from './helpers';\n\nconst formatLocalDate = (date: Date, locale: string, formatString: string) => {\n const localeConfig = locale === 'nb' ? { locale: nb } : {};\n return format(date, formatString, localeConfig);\n};\n\nexport const localeDate = (date: Date | string, locale: string) => {\n const dateObject = isString(date) ? parseISO(date) : date;\n return formatLocalDate(dateObject, locale, 'P');\n};\n\nexport const localeDateTime = (date: Date | string, locale: string) => {\n const dateObject = isString(date) ? parseISO(date) : date;\n return formatLocalDate(dateObject, locale, 'P - p');\n};\n\n// Redefine is Date for better type checking\nexport function isDate(dateToCheck: any): dateToCheck is Date {\n return isDateFn(dateToCheck);\n}\n\nexport const isDateString = (dateString: string) => {\n try {\n const date = parseISO(dateString);\n if (isNaN(date.getTime())) {\n return false;\n }\n return true;\n } catch (e) {\n return false;\n }\n};\n"],"names":["assertIsDefined","val","message","undefined","Error","isFunction","functionToCheck","toString","call","isString","stringToCheck","String","formatLocalDate","date","locale","formatString","localeConfig","nb","format","localeDate","dateObject","parseISO","localeDateTime","isDate","dateToCheck","isDateFn","isDateString","dateString","isNaN","getTime","e"],"mappings":";;;SAAgBA,gBACdC,KACAC;AAEA,MAAID,GAAG,KAAKE,SAAR,IAAqBF,GAAG,KAAK,IAAjC,EAAuC;AACrC,QAAIC,OAAJ,EAAa;AACX,YAAM,IAAIE,KAAJ,CAAUF,OAAV,CAAN;AACD;;AACD,UAAM,IAAIE,KAAJ,iDAAwDH,GAAxD,CAAN;AACD;AACF;;SCVeI,WAAcC;AAC5B,SACEA,eAAe,IAAI,GAAGC,QAAH,CAAYC,IAAZ,CAAiBF,eAAjB,MAAsC,mBAD3D;AAGD;AAED,SAAgBG,SAASC;AACvB,SAAO,OAAOA,aAAP,KAAyB,QAAzB,IAAqCA,aAAa,YAAYC,MAArE;AACD;;ACHD,IAAMC,eAAe,GAAG,SAAlBA,eAAkB,CAACC,IAAD,EAAaC,MAAb,EAA6BC,YAA7B;AACtB,MAAMC,YAAY,GAAGF,MAAM,KAAK,IAAX,GAAkB;AAAEA,IAAAA,MAAM,EAAEG;AAAV,GAAlB,GAAmC,EAAxD;AACA,SAAOC,MAAM,CAACL,IAAD,EAAOE,YAAP,EAAqBC,YAArB,CAAb;AACD,CAHD;;AAKA,IAAaG,UAAU,GAAG,SAAbA,UAAa,CAACN,IAAD,EAAsBC,MAAtB;AACxB,MAAMM,UAAU,GAAGX,QAAQ,CAACI,IAAD,CAAR,GAAiBQ,QAAQ,CAACR,IAAD,CAAzB,GAAkCA,IAArD;AACA,SAAOD,eAAe,CAACQ,UAAD,EAAaN,MAAb,EAAqB,GAArB,CAAtB;AACD,CAHM;AAKP,IAAaQ,cAAc,GAAG,SAAjBA,cAAiB,CAACT,IAAD,EAAsBC,MAAtB;AAC5B,MAAMM,UAAU,GAAGX,QAAQ,CAACI,IAAD,CAAR,GAAiBQ,QAAQ,CAACR,IAAD,CAAzB,GAAkCA,IAArD;AACA,SAAOD,eAAe,CAACQ,UAAD,EAAaN,MAAb,EAAqB,OAArB,CAAtB;AACD,CAHM;;AAMP,SAAgBS,OAAOC;AACrB,SAAOC,QAAQ,CAACD,WAAD,CAAf;AACD;AAED,IAAaE,YAAY,GAAG,SAAfA,YAAe,CAACC,UAAD;AAC1B,MAAI;AACF,QAAMd,IAAI,GAAGQ,QAAQ,CAACM,UAAD,CAArB;;AACA,QAAIC,KAAK,CAACf,IAAI,CAACgB,OAAL,EAAD,CAAT,EAA2B;AACzB,aAAO,KAAP;AACD;;AACD,WAAO,IAAP;AACD,GAND,CAME,OAAOC,CAAP,EAAU;AACV,WAAO,KAAP;AACD;AACF,CAVM;;;;"}
1
+ {"version":3,"file":"util.esm.js","sources":["../src/assertions.ts","../src/helpers.ts","../src/date.ts","../src/permissions.ts"],"sourcesContent":["export function assertIsDefined<T>(\n val: T,\n message?: string\n): asserts val is NonNullable<T> {\n if (val === undefined || val === null) {\n if (message) {\n throw new Error(message);\n }\n throw new Error(`Expected 'val' to be defined, but received ${val}`);\n }\n}\n","export function isFunction<T>(functionToCheck: any): functionToCheck is T {\n return (\n functionToCheck && {}.toString.call(functionToCheck) === '[object Function]'\n );\n}\n\nexport function isString(stringToCheck: any): stringToCheck is string {\n return typeof stringToCheck === 'string' || stringToCheck instanceof String;\n}\n","import { format, parseISO, isDate as isDateFn } from 'date-fns';\nimport { nb } from 'date-fns/locale';\n\nimport { isString } from './helpers';\n\nconst formatLocalDate = (date: Date, locale: string, formatString: string) => {\n const localeConfig = locale === 'nb' ? { locale: nb } : {};\n return format(date, formatString, localeConfig);\n};\n\nexport const localeDate = (date: Date | string, locale: string) => {\n const dateObject = isString(date) ? parseISO(date) : date;\n return formatLocalDate(dateObject, locale, 'P');\n};\n\nexport const localeDateTime = (date: Date | string, locale: string) => {\n const dateObject = isString(date) ? parseISO(date) : date;\n return formatLocalDate(dateObject, locale, 'P - p');\n};\n\n// Redefine is Date for better type checking\nexport function isDate(dateToCheck: any): dateToCheck is Date {\n return isDateFn(dateToCheck);\n}\n\nexport const isDateString = (dateString: string) => {\n try {\n const date = parseISO(dateString);\n if (isNaN(date.getTime())) {\n return false;\n }\n return true;\n } catch (e) {\n return false;\n }\n};\n","import { BusinessCapability } from '@entur-partner/permission-client-node';\n\nfunction checkPermission(\n permission1: BusinessCapability,\n permission2: BusinessCapability\n) {\n return (\n permission1.access === permission2.access &&\n permission1.operation === permission2.operation\n );\n}\n\nexport function hasAllPermissions(\n all: BusinessCapability[] | BusinessCapability,\n permissions: BusinessCapability[]\n) {\n if (!Array.isArray(all)) {\n all = [all];\n }\n return all.every((requiredPermission) =>\n hasPermissions(permissions, requiredPermission)\n );\n}\n\nexport function hasOneOfPermissions(\n oneOf: BusinessCapability[],\n permissions: BusinessCapability[]\n) {\n return oneOf.length > 0\n ? oneOf.some((requiredPermission) =>\n hasPermissions(permissions, requiredPermission)\n )\n : true;\n}\n\nexport function hasPermissions(\n permissions: BusinessCapability[],\n requiredPermission: BusinessCapability\n) {\n return permissions.some((userPermission) =>\n checkPermission(requiredPermission, userPermission)\n );\n}\n"],"names":["assertIsDefined","val","message","undefined","Error","isFunction","functionToCheck","toString","call","isString","stringToCheck","String","formatLocalDate","date","locale","formatString","localeConfig","nb","format","localeDate","dateObject","parseISO","localeDateTime","isDate","dateToCheck","isDateFn","isDateString","dateString","isNaN","getTime","e","checkPermission","permission1","permission2","access","operation","hasAllPermissions","all","permissions","Array","isArray","every","requiredPermission","hasPermissions","hasOneOfPermissions","oneOf","length","some","userPermission"],"mappings":";;;SAAgBA,gBACdC,KACAC;AAEA,MAAID,GAAG,KAAKE,SAAR,IAAqBF,GAAG,KAAK,IAAjC,EAAuC;AACrC,QAAIC,OAAJ,EAAa;AACX,YAAM,IAAIE,KAAJ,CAAUF,OAAV,CAAN;AACD;;AACD,UAAM,IAAIE,KAAJ,iDAAwDH,GAAxD,CAAN;AACD;AACF;;SCVeI,WAAcC;AAC5B,SACEA,eAAe,IAAI,GAAGC,QAAH,CAAYC,IAAZ,CAAiBF,eAAjB,MAAsC,mBAD3D;AAGD;SAEeG,SAASC;AACvB,SAAO,OAAOA,aAAP,KAAyB,QAAzB,IAAqCA,aAAa,YAAYC,MAArE;AACD;;ACHD,IAAMC,eAAe,GAAG,SAAlBA,eAAkB,CAACC,IAAD,EAAaC,MAAb,EAA6BC,YAA7B;AACtB,MAAMC,YAAY,GAAGF,MAAM,KAAK,IAAX,GAAkB;AAAEA,IAAAA,MAAM,EAAEG;AAAV,GAAlB,GAAmC,EAAxD;AACA,SAAOC,MAAM,CAACL,IAAD,EAAOE,YAAP,EAAqBC,YAArB,CAAb;AACD,CAHD;;IAKaG,UAAU,GAAG,SAAbA,UAAa,CAACN,IAAD,EAAsBC,MAAtB;AACxB,MAAMM,UAAU,GAAGX,QAAQ,CAACI,IAAD,CAAR,GAAiBQ,QAAQ,CAACR,IAAD,CAAzB,GAAkCA,IAArD;AACA,SAAOD,eAAe,CAACQ,UAAD,EAAaN,MAAb,EAAqB,GAArB,CAAtB;AACD;IAEYQ,cAAc,GAAG,SAAjBA,cAAiB,CAACT,IAAD,EAAsBC,MAAtB;AAC5B,MAAMM,UAAU,GAAGX,QAAQ,CAACI,IAAD,CAAR,GAAiBQ,QAAQ,CAACR,IAAD,CAAzB,GAAkCA,IAArD;AACA,SAAOD,eAAe,CAACQ,UAAD,EAAaN,MAAb,EAAqB,OAArB,CAAtB;AACD;;SAGeS,OAAOC;AACrB,SAAOC,QAAQ,CAACD,WAAD,CAAf;AACD;IAEYE,YAAY,GAAG,SAAfA,YAAe,CAACC,UAAD;AAC1B,MAAI;AACF,QAAMd,IAAI,GAAGQ,QAAQ,CAACM,UAAD,CAArB;;AACA,QAAIC,KAAK,CAACf,IAAI,CAACgB,OAAL,EAAD,CAAT,EAA2B;AACzB,aAAO,KAAP;AACD;;AACD,WAAO,IAAP;AACD,GAND,CAME,OAAOC,CAAP,EAAU;AACV,WAAO,KAAP;AACD;AACF;;ACjCD,SAASC,eAAT,CACEC,WADF,EAEEC,WAFF;AAIE,SACED,WAAW,CAACE,MAAZ,KAAuBD,WAAW,CAACC,MAAnC,IACAF,WAAW,CAACG,SAAZ,KAA0BF,WAAW,CAACE,SAFxC;AAID;;SAEeC,kBACdC,KACAC;AAEA,MAAI,CAACC,KAAK,CAACC,OAAN,CAAcH,GAAd,CAAL,EAAyB;AACvBA,IAAAA,GAAG,GAAG,CAACA,GAAD,CAAN;AACD;;AACD,SAAOA,GAAG,CAACI,KAAJ,CAAU,UAACC,kBAAD;AAAA,WACfC,cAAc,CAACL,WAAD,EAAcI,kBAAd,CADC;AAAA,GAAV,CAAP;AAGD;SAEeE,oBACdC,OACAP;AAEA,SAAOO,KAAK,CAACC,MAAN,GAAe,CAAf,GACHD,KAAK,CAACE,IAAN,CAAW,UAACL,kBAAD;AAAA,WACTC,cAAc,CAACL,WAAD,EAAcI,kBAAd,CADL;AAAA,GAAX,CADG,GAIH,IAJJ;AAKD;SAEeC,eACdL,aACAI;AAEA,SAAOJ,WAAW,CAACS,IAAZ,CAAiB,UAACC,cAAD;AAAA,WACtBjB,eAAe,CAACW,kBAAD,EAAqBM,cAArB,CADO;AAAA,GAAjB,CAAP;AAGD;;;;"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@entur-partner/util",
3
- "version": "1.0.1",
3
+ "version": "1.1.2",
4
4
  "license": "EUPL-1.2",
5
5
  "main": "dist/index.js",
6
6
  "module": "dist/util.esm.js",
@@ -17,14 +17,17 @@
17
17
  "access": "public"
18
18
  },
19
19
  "scripts": {
20
- "watch": "tsdx watch --noClean --verbose",
21
- "build": "tsdx build",
22
- "test": "tsdx test --env=jsdom --passWithNoTests",
23
- "lint": "tsdx lint"
20
+ "watch": "dts watch --noClean --verbose",
21
+ "build": "dts build",
22
+ "test": "dts test --env=jsdom --passWithNoTests",
23
+ "lint": "dts lint"
24
24
  },
25
25
  "dependencies": {
26
26
  "date-fns": "^2.16.1"
27
27
  },
28
+ "devDependencies": {
29
+ "@entur-partner/permission-client-node": "1.1.3"
30
+ },
28
31
  "jest": {
29
32
  "collectCoverageFrom": [
30
33
  "<rootDir>/src/**/*.{js,jsx,ts,tsx}"
@@ -35,5 +38,5 @@
35
38
  "reportFile": "jest-sonar-report.xml",
36
39
  "indent": 4
37
40
  },
38
- "gitHead": "605060b3dd6a7d0efe8c2be370abe8f3c8e8b240"
41
+ "gitHead": "ba34d91c553fbd985db00d3c8a4ea4d4dca75564"
39
42
  }