@pokash/n8n-nodes-ksef 0.2.16 → 0.2.17

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 (645) hide show
  1. package/package.json +5 -12
  2. package/node_modules/@oozcitak/dom/LICENSE +0 -21
  3. package/node_modules/@oozcitak/dom/README.md +0 -32
  4. package/node_modules/@oozcitak/dom/lib/algorithm/AbortAlgorithm.d.ts +0 -21
  5. package/node_modules/@oozcitak/dom/lib/algorithm/AbortAlgorithm.js +0 -79
  6. package/node_modules/@oozcitak/dom/lib/algorithm/AbortAlgorithm.js.map +0 -1
  7. package/node_modules/@oozcitak/dom/lib/algorithm/AttrAlgorithm.d.ts +0 -8
  8. package/node_modules/@oozcitak/dom/lib/algorithm/AttrAlgorithm.js +0 -23
  9. package/node_modules/@oozcitak/dom/lib/algorithm/AttrAlgorithm.js.map +0 -1
  10. package/node_modules/@oozcitak/dom/lib/algorithm/BoundaryPointAlgorithm.d.ts +0 -8
  11. package/node_modules/@oozcitak/dom/lib/algorithm/BoundaryPointAlgorithm.js +0 -76
  12. package/node_modules/@oozcitak/dom/lib/algorithm/BoundaryPointAlgorithm.js.map +0 -1
  13. package/node_modules/@oozcitak/dom/lib/algorithm/CharacterDataAlgorithm.d.ts +0 -19
  14. package/node_modules/@oozcitak/dom/lib/algorithm/CharacterDataAlgorithm.js +0 -140
  15. package/node_modules/@oozcitak/dom/lib/algorithm/CharacterDataAlgorithm.js.map +0 -1
  16. package/node_modules/@oozcitak/dom/lib/algorithm/CreateAlgorithm.d.ts +0 -192
  17. package/node_modules/@oozcitak/dom/lib/algorithm/CreateAlgorithm.js +0 -303
  18. package/node_modules/@oozcitak/dom/lib/algorithm/CreateAlgorithm.js.map +0 -1
  19. package/node_modules/@oozcitak/dom/lib/algorithm/CustomElementAlgorithm.d.ts +0 -61
  20. package/node_modules/@oozcitak/dom/lib/algorithm/CustomElementAlgorithm.js +0 -108
  21. package/node_modules/@oozcitak/dom/lib/algorithm/CustomElementAlgorithm.js.map +0 -1
  22. package/node_modules/@oozcitak/dom/lib/algorithm/DOMAlgorithm.d.ts +0 -72
  23. package/node_modules/@oozcitak/dom/lib/algorithm/DOMAlgorithm.js +0 -288
  24. package/node_modules/@oozcitak/dom/lib/algorithm/DOMAlgorithm.js.map +0 -1
  25. package/node_modules/@oozcitak/dom/lib/algorithm/DOMTokenListAlgorithm.d.ts +0 -21
  26. package/node_modules/@oozcitak/dom/lib/algorithm/DOMTokenListAlgorithm.js +0 -61
  27. package/node_modules/@oozcitak/dom/lib/algorithm/DOMTokenListAlgorithm.js.map +0 -1
  28. package/node_modules/@oozcitak/dom/lib/algorithm/DocumentAlgorithm.d.ts +0 -29
  29. package/node_modules/@oozcitak/dom/lib/algorithm/DocumentAlgorithm.js +0 -161
  30. package/node_modules/@oozcitak/dom/lib/algorithm/DocumentAlgorithm.js.map +0 -1
  31. package/node_modules/@oozcitak/dom/lib/algorithm/ElementAlgorithm.d.ts +0 -121
  32. package/node_modules/@oozcitak/dom/lib/algorithm/ElementAlgorithm.js +0 -608
  33. package/node_modules/@oozcitak/dom/lib/algorithm/ElementAlgorithm.js.map +0 -1
  34. package/node_modules/@oozcitak/dom/lib/algorithm/EventAlgorithm.d.ts +0 -146
  35. package/node_modules/@oozcitak/dom/lib/algorithm/EventAlgorithm.js +0 -995
  36. package/node_modules/@oozcitak/dom/lib/algorithm/EventAlgorithm.js.map +0 -1
  37. package/node_modules/@oozcitak/dom/lib/algorithm/EventTargetAlgorithm.d.ts +0 -33
  38. package/node_modules/@oozcitak/dom/lib/algorithm/EventTargetAlgorithm.js +0 -142
  39. package/node_modules/@oozcitak/dom/lib/algorithm/EventTargetAlgorithm.js.map +0 -1
  40. package/node_modules/@oozcitak/dom/lib/algorithm/MutationAlgorithm.d.ts +0 -66
  41. package/node_modules/@oozcitak/dom/lib/algorithm/MutationAlgorithm.js +0 -1173
  42. package/node_modules/@oozcitak/dom/lib/algorithm/MutationAlgorithm.js.map +0 -1
  43. package/node_modules/@oozcitak/dom/lib/algorithm/MutationObserverAlgorithm.d.ts +0 -43
  44. package/node_modules/@oozcitak/dom/lib/algorithm/MutationObserverAlgorithm.js +0 -276
  45. package/node_modules/@oozcitak/dom/lib/algorithm/MutationObserverAlgorithm.js.map +0 -1
  46. package/node_modules/@oozcitak/dom/lib/algorithm/NamespaceAlgorithm.d.ts +0 -25
  47. package/node_modules/@oozcitak/dom/lib/algorithm/NamespaceAlgorithm.js +0 -85
  48. package/node_modules/@oozcitak/dom/lib/algorithm/NamespaceAlgorithm.js.map +0 -1
  49. package/node_modules/@oozcitak/dom/lib/algorithm/NodeAlgorithm.d.ts +0 -68
  50. package/node_modules/@oozcitak/dom/lib/algorithm/NodeAlgorithm.js +0 -543
  51. package/node_modules/@oozcitak/dom/lib/algorithm/NodeAlgorithm.js.map +0 -1
  52. package/node_modules/@oozcitak/dom/lib/algorithm/NodeIteratorAlgorithm.d.ts +0 -15
  53. package/node_modules/@oozcitak/dom/lib/algorithm/NodeIteratorAlgorithm.js +0 -105
  54. package/node_modules/@oozcitak/dom/lib/algorithm/NodeIteratorAlgorithm.js.map +0 -1
  55. package/node_modules/@oozcitak/dom/lib/algorithm/OrderedSetAlgorithm.d.ts +0 -27
  56. package/node_modules/@oozcitak/dom/lib/algorithm/OrderedSetAlgorithm.js +0 -125
  57. package/node_modules/@oozcitak/dom/lib/algorithm/OrderedSetAlgorithm.js.map +0 -1
  58. package/node_modules/@oozcitak/dom/lib/algorithm/ParentNodeAlgorithm.d.ts +0 -9
  59. package/node_modules/@oozcitak/dom/lib/algorithm/ParentNodeAlgorithm.js +0 -69
  60. package/node_modules/@oozcitak/dom/lib/algorithm/ParentNodeAlgorithm.js.map +0 -1
  61. package/node_modules/@oozcitak/dom/lib/algorithm/RangeAlgorithm.d.ts +0 -82
  62. package/node_modules/@oozcitak/dom/lib/algorithm/RangeAlgorithm.js +0 -829
  63. package/node_modules/@oozcitak/dom/lib/algorithm/RangeAlgorithm.js.map +0 -1
  64. package/node_modules/@oozcitak/dom/lib/algorithm/SelectorsAlgorithm.d.ts +0 -8
  65. package/node_modules/@oozcitak/dom/lib/algorithm/SelectorsAlgorithm.js +0 -21
  66. package/node_modules/@oozcitak/dom/lib/algorithm/SelectorsAlgorithm.js.map +0 -1
  67. package/node_modules/@oozcitak/dom/lib/algorithm/ShadowTreeAlgorithm.d.ts +0 -57
  68. package/node_modules/@oozcitak/dom/lib/algorithm/ShadowTreeAlgorithm.js +0 -316
  69. package/node_modules/@oozcitak/dom/lib/algorithm/ShadowTreeAlgorithm.js.map +0 -1
  70. package/node_modules/@oozcitak/dom/lib/algorithm/TextAlgorithm.d.ts +0 -30
  71. package/node_modules/@oozcitak/dom/lib/algorithm/TextAlgorithm.js +0 -226
  72. package/node_modules/@oozcitak/dom/lib/algorithm/TextAlgorithm.js.map +0 -1
  73. package/node_modules/@oozcitak/dom/lib/algorithm/TraversalAlgorithm.d.ts +0 -8
  74. package/node_modules/@oozcitak/dom/lib/algorithm/TraversalAlgorithm.js +0 -62
  75. package/node_modules/@oozcitak/dom/lib/algorithm/TraversalAlgorithm.js.map +0 -1
  76. package/node_modules/@oozcitak/dom/lib/algorithm/TreeAlgorithm.d.ts +0 -268
  77. package/node_modules/@oozcitak/dom/lib/algorithm/TreeAlgorithm.js +0 -853
  78. package/node_modules/@oozcitak/dom/lib/algorithm/TreeAlgorithm.js.map +0 -1
  79. package/node_modules/@oozcitak/dom/lib/algorithm/TreeWalkerAlgorithm.d.ts +0 -17
  80. package/node_modules/@oozcitak/dom/lib/algorithm/TreeWalkerAlgorithm.js +0 -147
  81. package/node_modules/@oozcitak/dom/lib/algorithm/TreeWalkerAlgorithm.js.map +0 -1
  82. package/node_modules/@oozcitak/dom/lib/algorithm/WebIDLAlgorithm.d.ts +0 -8
  83. package/node_modules/@oozcitak/dom/lib/algorithm/WebIDLAlgorithm.js +0 -14
  84. package/node_modules/@oozcitak/dom/lib/algorithm/WebIDLAlgorithm.js.map +0 -1
  85. package/node_modules/@oozcitak/dom/lib/algorithm/XMLAlgorithm.d.ts +0 -25
  86. package/node_modules/@oozcitak/dom/lib/algorithm/XMLAlgorithm.js +0 -164
  87. package/node_modules/@oozcitak/dom/lib/algorithm/XMLAlgorithm.js.map +0 -1
  88. package/node_modules/@oozcitak/dom/lib/algorithm/index.d.ts +0 -28
  89. package/node_modules/@oozcitak/dom/lib/algorithm/index.js +0 -34
  90. package/node_modules/@oozcitak/dom/lib/algorithm/index.js.map +0 -1
  91. package/node_modules/@oozcitak/dom/lib/dom/AbortControllerImpl.d.ts +0 -15
  92. package/node_modules/@oozcitak/dom/lib/dom/AbortControllerImpl.js +0 -32
  93. package/node_modules/@oozcitak/dom/lib/dom/AbortControllerImpl.js.map +0 -1
  94. package/node_modules/@oozcitak/dom/lib/dom/AbortSignalImpl.d.ts +0 -23
  95. package/node_modules/@oozcitak/dom/lib/dom/AbortSignalImpl.js +0 -59
  96. package/node_modules/@oozcitak/dom/lib/dom/AbortSignalImpl.js.map +0 -1
  97. package/node_modules/@oozcitak/dom/lib/dom/AbstractRangeImpl.d.ts +0 -23
  98. package/node_modules/@oozcitak/dom/lib/dom/AbstractRangeImpl.js +0 -70
  99. package/node_modules/@oozcitak/dom/lib/dom/AbstractRangeImpl.js.map +0 -1
  100. package/node_modules/@oozcitak/dom/lib/dom/AttrImpl.d.ts +0 -45
  101. package/node_modules/@oozcitak/dom/lib/dom/AttrImpl.js +0 -118
  102. package/node_modules/@oozcitak/dom/lib/dom/AttrImpl.js.map +0 -1
  103. package/node_modules/@oozcitak/dom/lib/dom/CDATASectionImpl.d.ts +0 -21
  104. package/node_modules/@oozcitak/dom/lib/dom/CDATASectionImpl.js +0 -51
  105. package/node_modules/@oozcitak/dom/lib/dom/CDATASectionImpl.js.map +0 -1
  106. package/node_modules/@oozcitak/dom/lib/dom/CharacterDataImpl.d.ts +0 -35
  107. package/node_modules/@oozcitak/dom/lib/dom/CharacterDataImpl.js +0 -132
  108. package/node_modules/@oozcitak/dom/lib/dom/CharacterDataImpl.js.map +0 -1
  109. package/node_modules/@oozcitak/dom/lib/dom/ChildNodeImpl.d.ts +0 -16
  110. package/node_modules/@oozcitak/dom/lib/dom/ChildNodeImpl.js +0 -165
  111. package/node_modules/@oozcitak/dom/lib/dom/ChildNodeImpl.js.map +0 -1
  112. package/node_modules/@oozcitak/dom/lib/dom/CommentImpl.d.ts +0 -21
  113. package/node_modules/@oozcitak/dom/lib/dom/CommentImpl.js +0 -52
  114. package/node_modules/@oozcitak/dom/lib/dom/CommentImpl.js.map +0 -1
  115. package/node_modules/@oozcitak/dom/lib/dom/CustomEventImpl.d.ts +0 -16
  116. package/node_modules/@oozcitak/dom/lib/dom/CustomEventImpl.js +0 -60
  117. package/node_modules/@oozcitak/dom/lib/dom/CustomEventImpl.js.map +0 -1
  118. package/node_modules/@oozcitak/dom/lib/dom/DOMException.d.ts +0 -171
  119. package/node_modules/@oozcitak/dom/lib/dom/DOMException.js +0 -347
  120. package/node_modules/@oozcitak/dom/lib/dom/DOMException.js.map +0 -1
  121. package/node_modules/@oozcitak/dom/lib/dom/DOMImpl.d.ts +0 -48
  122. package/node_modules/@oozcitak/dom/lib/dom/DOMImpl.js +0 -100
  123. package/node_modules/@oozcitak/dom/lib/dom/DOMImpl.js.map +0 -1
  124. package/node_modules/@oozcitak/dom/lib/dom/DOMImplementationImpl.d.ts +0 -29
  125. package/node_modules/@oozcitak/dom/lib/dom/DOMImplementationImpl.js +0 -149
  126. package/node_modules/@oozcitak/dom/lib/dom/DOMImplementationImpl.js.map +0 -1
  127. package/node_modules/@oozcitak/dom/lib/dom/DOMTokenListImpl.d.ts +0 -46
  128. package/node_modules/@oozcitak/dom/lib/dom/DOMTokenListImpl.js +0 -312
  129. package/node_modules/@oozcitak/dom/lib/dom/DOMTokenListImpl.js.map +0 -1
  130. package/node_modules/@oozcitak/dom/lib/dom/DocumentFragmentImpl.d.ts +0 -32
  131. package/node_modules/@oozcitak/dom/lib/dom/DocumentFragmentImpl.js +0 -103
  132. package/node_modules/@oozcitak/dom/lib/dom/DocumentFragmentImpl.js.map +0 -1
  133. package/node_modules/@oozcitak/dom/lib/dom/DocumentImpl.d.ts +0 -116
  134. package/node_modules/@oozcitak/dom/lib/dom/DocumentImpl.js +0 -545
  135. package/node_modules/@oozcitak/dom/lib/dom/DocumentImpl.js.map +0 -1
  136. package/node_modules/@oozcitak/dom/lib/dom/DocumentOrShadowRootImpl.d.ts +0 -11
  137. package/node_modules/@oozcitak/dom/lib/dom/DocumentOrShadowRootImpl.js +0 -17
  138. package/node_modules/@oozcitak/dom/lib/dom/DocumentOrShadowRootImpl.js.map +0 -1
  139. package/node_modules/@oozcitak/dom/lib/dom/DocumentTypeImpl.d.ts +0 -39
  140. package/node_modules/@oozcitak/dom/lib/dom/DocumentTypeImpl.js +0 -109
  141. package/node_modules/@oozcitak/dom/lib/dom/DocumentTypeImpl.js.map +0 -1
  142. package/node_modules/@oozcitak/dom/lib/dom/ElementImpl.d.ts +0 -132
  143. package/node_modules/@oozcitak/dom/lib/dom/ElementImpl.js +0 -714
  144. package/node_modules/@oozcitak/dom/lib/dom/ElementImpl.js.map +0 -1
  145. package/node_modules/@oozcitak/dom/lib/dom/EventImpl.d.ts +0 -74
  146. package/node_modules/@oozcitak/dom/lib/dom/EventImpl.js +0 -313
  147. package/node_modules/@oozcitak/dom/lib/dom/EventImpl.js.map +0 -1
  148. package/node_modules/@oozcitak/dom/lib/dom/EventTargetImpl.d.ts +0 -30
  149. package/node_modules/@oozcitak/dom/lib/dom/EventTargetImpl.js +0 -133
  150. package/node_modules/@oozcitak/dom/lib/dom/EventTargetImpl.js.map +0 -1
  151. package/node_modules/@oozcitak/dom/lib/dom/HTMLCollectionImpl.d.ts +0 -44
  152. package/node_modules/@oozcitak/dom/lib/dom/HTMLCollectionImpl.js +0 -157
  153. package/node_modules/@oozcitak/dom/lib/dom/HTMLCollectionImpl.js.map +0 -1
  154. package/node_modules/@oozcitak/dom/lib/dom/MutationObserverImpl.d.ts +0 -22
  155. package/node_modules/@oozcitak/dom/lib/dom/MutationObserverImpl.js +0 -184
  156. package/node_modules/@oozcitak/dom/lib/dom/MutationObserverImpl.js.map +0 -1
  157. package/node_modules/@oozcitak/dom/lib/dom/MutationRecordImpl.d.ts +0 -73
  158. package/node_modules/@oozcitak/dom/lib/dom/MutationRecordImpl.js +0 -116
  159. package/node_modules/@oozcitak/dom/lib/dom/MutationRecordImpl.js.map +0 -1
  160. package/node_modules/@oozcitak/dom/lib/dom/NamedNodeMapImpl.d.ts +0 -34
  161. package/node_modules/@oozcitak/dom/lib/dom/NamedNodeMapImpl.js +0 -112
  162. package/node_modules/@oozcitak/dom/lib/dom/NamedNodeMapImpl.js.map +0 -1
  163. package/node_modules/@oozcitak/dom/lib/dom/NodeFilterImpl.d.ts +0 -50
  164. package/node_modules/@oozcitak/dom/lib/dom/NodeFilterImpl.js +0 -64
  165. package/node_modules/@oozcitak/dom/lib/dom/NodeFilterImpl.js.map +0 -1
  166. package/node_modules/@oozcitak/dom/lib/dom/NodeImpl.d.ts +0 -252
  167. package/node_modules/@oozcitak/dom/lib/dom/NodeImpl.js +0 -891
  168. package/node_modules/@oozcitak/dom/lib/dom/NodeImpl.js.map +0 -1
  169. package/node_modules/@oozcitak/dom/lib/dom/NodeIteratorImpl.d.ts +0 -34
  170. package/node_modules/@oozcitak/dom/lib/dom/NodeIteratorImpl.js +0 -86
  171. package/node_modules/@oozcitak/dom/lib/dom/NodeIteratorImpl.js.map +0 -1
  172. package/node_modules/@oozcitak/dom/lib/dom/NodeListImpl.d.ts +0 -46
  173. package/node_modules/@oozcitak/dom/lib/dom/NodeListImpl.js +0 -198
  174. package/node_modules/@oozcitak/dom/lib/dom/NodeListImpl.js.map +0 -1
  175. package/node_modules/@oozcitak/dom/lib/dom/NodeListStaticImpl.d.ts +0 -49
  176. package/node_modules/@oozcitak/dom/lib/dom/NodeListStaticImpl.js +0 -188
  177. package/node_modules/@oozcitak/dom/lib/dom/NodeListStaticImpl.js.map +0 -1
  178. package/node_modules/@oozcitak/dom/lib/dom/NonDocumentTypeChildNodeImpl.d.ts +0 -12
  179. package/node_modules/@oozcitak/dom/lib/dom/NonDocumentTypeChildNodeImpl.js +0 -53
  180. package/node_modules/@oozcitak/dom/lib/dom/NonDocumentTypeChildNodeImpl.js.map +0 -1
  181. package/node_modules/@oozcitak/dom/lib/dom/NonElementParentNodeImpl.d.ts +0 -9
  182. package/node_modules/@oozcitak/dom/lib/dom/NonElementParentNodeImpl.js +0 -31
  183. package/node_modules/@oozcitak/dom/lib/dom/NonElementParentNodeImpl.js.map +0 -1
  184. package/node_modules/@oozcitak/dom/lib/dom/ParentNodeImpl.d.ts +0 -24
  185. package/node_modules/@oozcitak/dom/lib/dom/ParentNodeImpl.js +0 -158
  186. package/node_modules/@oozcitak/dom/lib/dom/ParentNodeImpl.js.map +0 -1
  187. package/node_modules/@oozcitak/dom/lib/dom/ProcessingInstructionImpl.d.ts +0 -25
  188. package/node_modules/@oozcitak/dom/lib/dom/ProcessingInstructionImpl.js +0 -59
  189. package/node_modules/@oozcitak/dom/lib/dom/ProcessingInstructionImpl.js.map +0 -1
  190. package/node_modules/@oozcitak/dom/lib/dom/RangeImpl.d.ts +0 -71
  191. package/node_modules/@oozcitak/dom/lib/dom/RangeImpl.js +0 -649
  192. package/node_modules/@oozcitak/dom/lib/dom/RangeImpl.js.map +0 -1
  193. package/node_modules/@oozcitak/dom/lib/dom/ShadowRootImpl.d.ts +0 -33
  194. package/node_modules/@oozcitak/dom/lib/dom/ShadowRootImpl.js +0 -82
  195. package/node_modules/@oozcitak/dom/lib/dom/ShadowRootImpl.js.map +0 -1
  196. package/node_modules/@oozcitak/dom/lib/dom/SlotableImpl.d.ts +0 -16
  197. package/node_modules/@oozcitak/dom/lib/dom/SlotableImpl.js +0 -35
  198. package/node_modules/@oozcitak/dom/lib/dom/SlotableImpl.js.map +0 -1
  199. package/node_modules/@oozcitak/dom/lib/dom/StaticRangeImpl.d.ts +0 -13
  200. package/node_modules/@oozcitak/dom/lib/dom/StaticRangeImpl.js +0 -48
  201. package/node_modules/@oozcitak/dom/lib/dom/StaticRangeImpl.js.map +0 -1
  202. package/node_modules/@oozcitak/dom/lib/dom/TextImpl.d.ts +0 -28
  203. package/node_modules/@oozcitak/dom/lib/dom/TextImpl.js +0 -109
  204. package/node_modules/@oozcitak/dom/lib/dom/TextImpl.js.map +0 -1
  205. package/node_modules/@oozcitak/dom/lib/dom/TraverserImpl.d.ts +0 -23
  206. package/node_modules/@oozcitak/dom/lib/dom/TraverserImpl.js +0 -41
  207. package/node_modules/@oozcitak/dom/lib/dom/TraverserImpl.js.map +0 -1
  208. package/node_modules/@oozcitak/dom/lib/dom/TreeWalkerImpl.d.ts +0 -36
  209. package/node_modules/@oozcitak/dom/lib/dom/TreeWalkerImpl.js +0 -249
  210. package/node_modules/@oozcitak/dom/lib/dom/TreeWalkerImpl.js.map +0 -1
  211. package/node_modules/@oozcitak/dom/lib/dom/WindowImpl.d.ts +0 -26
  212. package/node_modules/@oozcitak/dom/lib/dom/WindowImpl.js +0 -57
  213. package/node_modules/@oozcitak/dom/lib/dom/WindowImpl.js.map +0 -1
  214. package/node_modules/@oozcitak/dom/lib/dom/XMLDocumentImpl.d.ts +0 -11
  215. package/node_modules/@oozcitak/dom/lib/dom/XMLDocumentImpl.js +0 -31
  216. package/node_modules/@oozcitak/dom/lib/dom/XMLDocumentImpl.js.map +0 -1
  217. package/node_modules/@oozcitak/dom/lib/dom/index.d.ts +0 -36
  218. package/node_modules/@oozcitak/dom/lib/dom/index.js +0 -102
  219. package/node_modules/@oozcitak/dom/lib/dom/index.js.map +0 -1
  220. package/node_modules/@oozcitak/dom/lib/dom/interfaces.d.ts +0 -2218
  221. package/node_modules/@oozcitak/dom/lib/dom/interfaces.js +0 -91
  222. package/node_modules/@oozcitak/dom/lib/dom/interfaces.js.map +0 -1
  223. package/node_modules/@oozcitak/dom/lib/index.d.ts +0 -3
  224. package/node_modules/@oozcitak/dom/lib/index.js +0 -11
  225. package/node_modules/@oozcitak/dom/lib/index.js.map +0 -1
  226. package/node_modules/@oozcitak/dom/lib/parser/DOMParserImpl.d.ts +0 -11
  227. package/node_modules/@oozcitak/dom/lib/parser/DOMParserImpl.js +0 -37
  228. package/node_modules/@oozcitak/dom/lib/parser/DOMParserImpl.js.map +0 -1
  229. package/node_modules/@oozcitak/dom/lib/parser/XMLParserImpl.d.ts +0 -26
  230. package/node_modules/@oozcitak/dom/lib/parser/XMLParserImpl.js +0 -240
  231. package/node_modules/@oozcitak/dom/lib/parser/XMLParserImpl.js.map +0 -1
  232. package/node_modules/@oozcitak/dom/lib/parser/XMLStringLexer.d.ts +0 -159
  233. package/node_modules/@oozcitak/dom/lib/parser/XMLStringLexer.js +0 -512
  234. package/node_modules/@oozcitak/dom/lib/parser/XMLStringLexer.js.map +0 -1
  235. package/node_modules/@oozcitak/dom/lib/parser/index.d.ts +0 -1
  236. package/node_modules/@oozcitak/dom/lib/parser/index.js +0 -6
  237. package/node_modules/@oozcitak/dom/lib/parser/index.js.map +0 -1
  238. package/node_modules/@oozcitak/dom/lib/parser/interfaces.d.ts +0 -131
  239. package/node_modules/@oozcitak/dom/lib/parser/interfaces.js +0 -18
  240. package/node_modules/@oozcitak/dom/lib/parser/interfaces.js.map +0 -1
  241. package/node_modules/@oozcitak/dom/lib/serializer/LocalNameSet.d.ts +0 -27
  242. package/node_modules/@oozcitak/dom/lib/serializer/LocalNameSet.js +0 -56
  243. package/node_modules/@oozcitak/dom/lib/serializer/LocalNameSet.js.map +0 -1
  244. package/node_modules/@oozcitak/dom/lib/serializer/NamespacePrefixMap.d.ts +0 -52
  245. package/node_modules/@oozcitak/dom/lib/serializer/NamespacePrefixMap.js +0 -151
  246. package/node_modules/@oozcitak/dom/lib/serializer/NamespacePrefixMap.js.map +0 -1
  247. package/node_modules/@oozcitak/dom/lib/serializer/XMLSerializerImpl.d.ts +0 -166
  248. package/node_modules/@oozcitak/dom/lib/serializer/XMLSerializerImpl.js +0 -1479
  249. package/node_modules/@oozcitak/dom/lib/serializer/XMLSerializerImpl.js.map +0 -1
  250. package/node_modules/@oozcitak/dom/lib/serializer/index.d.ts +0 -1
  251. package/node_modules/@oozcitak/dom/lib/serializer/index.js +0 -6
  252. package/node_modules/@oozcitak/dom/lib/serializer/index.js.map +0 -1
  253. package/node_modules/@oozcitak/dom/lib/serializer/interfaces.d.ts +0 -15
  254. package/node_modules/@oozcitak/dom/lib/serializer/interfaces.js +0 -3
  255. package/node_modules/@oozcitak/dom/lib/serializer/interfaces.js.map +0 -1
  256. package/node_modules/@oozcitak/dom/lib/util/Cast.d.ts +0 -12
  257. package/node_modules/@oozcitak/dom/lib/util/Cast.js +0 -26
  258. package/node_modules/@oozcitak/dom/lib/util/Cast.js.map +0 -1
  259. package/node_modules/@oozcitak/dom/lib/util/EmptySet.d.ts +0 -13
  260. package/node_modules/@oozcitak/dom/lib/util/EmptySet.js +0 -61
  261. package/node_modules/@oozcitak/dom/lib/util/EmptySet.js.map +0 -1
  262. package/node_modules/@oozcitak/dom/lib/util/Guard.d.ts +0 -135
  263. package/node_modules/@oozcitak/dom/lib/util/Guard.js +0 -192
  264. package/node_modules/@oozcitak/dom/lib/util/Guard.js.map +0 -1
  265. package/node_modules/@oozcitak/dom/lib/util/index.d.ts +0 -3
  266. package/node_modules/@oozcitak/dom/lib/util/index.js +0 -9
  267. package/node_modules/@oozcitak/dom/lib/util/index.js.map +0 -1
  268. package/node_modules/@oozcitak/dom/package.json +0 -72
  269. package/node_modules/@oozcitak/infra/LICENSE +0 -21
  270. package/node_modules/@oozcitak/infra/README.md +0 -13
  271. package/node_modules/@oozcitak/infra/lib/Base64.d.ts +0 -12
  272. package/node_modules/@oozcitak/infra/lib/Base64.js +0 -82
  273. package/node_modules/@oozcitak/infra/lib/Base64.js.map +0 -1
  274. package/node_modules/@oozcitak/infra/lib/Byte.d.ts +0 -6
  275. package/node_modules/@oozcitak/infra/lib/Byte.js +0 -15
  276. package/node_modules/@oozcitak/infra/lib/Byte.js.map +0 -1
  277. package/node_modules/@oozcitak/infra/lib/ByteSequence.d.ts +0 -45
  278. package/node_modules/@oozcitak/infra/lib/ByteSequence.js +0 -171
  279. package/node_modules/@oozcitak/infra/lib/ByteSequence.js.map +0 -1
  280. package/node_modules/@oozcitak/infra/lib/CodePoints.d.ts +0 -82
  281. package/node_modules/@oozcitak/infra/lib/CodePoints.js +0 -85
  282. package/node_modules/@oozcitak/infra/lib/CodePoints.js.map +0 -1
  283. package/node_modules/@oozcitak/infra/lib/JSON.d.ts +0 -24
  284. package/node_modules/@oozcitak/infra/lib/JSON.js +0 -123
  285. package/node_modules/@oozcitak/infra/lib/JSON.js.map +0 -1
  286. package/node_modules/@oozcitak/infra/lib/List.d.ts +0 -101
  287. package/node_modules/@oozcitak/infra/lib/List.js +0 -325
  288. package/node_modules/@oozcitak/infra/lib/List.js.map +0 -1
  289. package/node_modules/@oozcitak/infra/lib/Map.d.ts +0 -87
  290. package/node_modules/@oozcitak/infra/lib/Map.js +0 -308
  291. package/node_modules/@oozcitak/infra/lib/Map.js.map +0 -1
  292. package/node_modules/@oozcitak/infra/lib/Namespace.d.ts +0 -6
  293. package/node_modules/@oozcitak/infra/lib/Namespace.js +0 -9
  294. package/node_modules/@oozcitak/infra/lib/Namespace.js.map +0 -1
  295. package/node_modules/@oozcitak/infra/lib/Queue.d.ts +0 -13
  296. package/node_modules/@oozcitak/infra/lib/Queue.js +0 -22
  297. package/node_modules/@oozcitak/infra/lib/Queue.js.map +0 -1
  298. package/node_modules/@oozcitak/infra/lib/Set.d.ts +0 -136
  299. package/node_modules/@oozcitak/infra/lib/Set.js +0 -467
  300. package/node_modules/@oozcitak/infra/lib/Set.js.map +0 -1
  301. package/node_modules/@oozcitak/infra/lib/Stack.d.ts +0 -13
  302. package/node_modules/@oozcitak/infra/lib/Stack.js +0 -22
  303. package/node_modules/@oozcitak/infra/lib/Stack.js.map +0 -1
  304. package/node_modules/@oozcitak/infra/lib/String.d.ts +0 -129
  305. package/node_modules/@oozcitak/infra/lib/String.js +0 -472
  306. package/node_modules/@oozcitak/infra/lib/String.js.map +0 -1
  307. package/node_modules/@oozcitak/infra/lib/index.d.ts +0 -13
  308. package/node_modules/@oozcitak/infra/lib/index.js +0 -34
  309. package/node_modules/@oozcitak/infra/lib/index.js.map +0 -1
  310. package/node_modules/@oozcitak/infra/package.json +0 -54
  311. package/node_modules/@oozcitak/url/LICENSE +0 -21
  312. package/node_modules/@oozcitak/url/README.md +0 -27
  313. package/node_modules/@oozcitak/url/lib/URLAlgorithm.d.ts +0 -267
  314. package/node_modules/@oozcitak/url/lib/URLAlgorithm.js +0 -2758
  315. package/node_modules/@oozcitak/url/lib/URLAlgorithm.js.map +0 -1
  316. package/node_modules/@oozcitak/url/lib/URLImpl.d.ts +0 -53
  317. package/node_modules/@oozcitak/url/lib/URLImpl.js +0 -377
  318. package/node_modules/@oozcitak/url/lib/URLImpl.js.map +0 -1
  319. package/node_modules/@oozcitak/url/lib/URLSearchParamsImpl.d.ts +0 -38
  320. package/node_modules/@oozcitak/url/lib/URLSearchParamsImpl.js +0 -303
  321. package/node_modules/@oozcitak/url/lib/URLSearchParamsImpl.js.map +0 -1
  322. package/node_modules/@oozcitak/url/lib/index.d.ts +0 -2
  323. package/node_modules/@oozcitak/url/lib/index.js +0 -7
  324. package/node_modules/@oozcitak/url/lib/index.js.map +0 -1
  325. package/node_modules/@oozcitak/url/lib/interfaces.d.ts +0 -195
  326. package/node_modules/@oozcitak/url/lib/interfaces.js +0 -31
  327. package/node_modules/@oozcitak/url/lib/interfaces.js.map +0 -1
  328. package/node_modules/@oozcitak/url/package.json +0 -55
  329. package/node_modules/@oozcitak/util/LICENSE +0 -21
  330. package/node_modules/@oozcitak/util/README.md +0 -10
  331. package/node_modules/@oozcitak/util/lib/CompareCache.d.ts +0 -32
  332. package/node_modules/@oozcitak/util/lib/CompareCache.js +0 -59
  333. package/node_modules/@oozcitak/util/lib/CompareCache.js.map +0 -1
  334. package/node_modules/@oozcitak/util/lib/FixedSizeSet.d.ts +0 -64
  335. package/node_modules/@oozcitak/util/lib/FixedSizeSet.js +0 -174
  336. package/node_modules/@oozcitak/util/lib/FixedSizeSet.js.map +0 -1
  337. package/node_modules/@oozcitak/util/lib/Lazy.d.ts +0 -18
  338. package/node_modules/@oozcitak/util/lib/Lazy.js +0 -34
  339. package/node_modules/@oozcitak/util/lib/Lazy.js.map +0 -1
  340. package/node_modules/@oozcitak/util/lib/ObjectCache.d.ts +0 -71
  341. package/node_modules/@oozcitak/util/lib/ObjectCache.js +0 -181
  342. package/node_modules/@oozcitak/util/lib/ObjectCache.js.map +0 -1
  343. package/node_modules/@oozcitak/util/lib/StringWalker.d.ts +0 -49
  344. package/node_modules/@oozcitak/util/lib/StringWalker.js +0 -105
  345. package/node_modules/@oozcitak/util/lib/StringWalker.js.map +0 -1
  346. package/node_modules/@oozcitak/util/lib/index.d.ts +0 -178
  347. package/node_modules/@oozcitak/util/lib/index.js +0 -439
  348. package/node_modules/@oozcitak/util/lib/index.js.map +0 -1
  349. package/node_modules/@oozcitak/util/package.json +0 -50
  350. package/node_modules/@xmldom/is-dom-node/LICENSE.md +0 -21
  351. package/node_modules/@xmldom/is-dom-node/README.md +0 -91
  352. package/node_modules/@xmldom/is-dom-node/dist/index.d.ts +0 -33
  353. package/node_modules/@xmldom/is-dom-node/dist/index.js +0 -91
  354. package/node_modules/@xmldom/is-dom-node/dist/index.js.map +0 -1
  355. package/node_modules/@xmldom/is-dom-node/package.json +0 -69
  356. package/node_modules/@xmldom/xmldom/CHANGELOG.md +0 -468
  357. package/node_modules/@xmldom/xmldom/LICENSE +0 -8
  358. package/node_modules/@xmldom/xmldom/SECURITY.md +0 -50
  359. package/node_modules/@xmldom/xmldom/index.d.ts +0 -43
  360. package/node_modules/@xmldom/xmldom/lib/.eslintrc.yml +0 -2
  361. package/node_modules/@xmldom/xmldom/lib/conventions.js +0 -203
  362. package/node_modules/@xmldom/xmldom/lib/dom-parser.js +0 -322
  363. package/node_modules/@xmldom/xmldom/lib/dom.js +0 -1879
  364. package/node_modules/@xmldom/xmldom/lib/entities.js +0 -2166
  365. package/node_modules/@xmldom/xmldom/lib/index.js +0 -4
  366. package/node_modules/@xmldom/xmldom/lib/sax.js +0 -662
  367. package/node_modules/@xmldom/xmldom/package.json +0 -71
  368. package/node_modules/@xmldom/xmldom/readme.md +0 -356
  369. package/node_modules/esprima/ChangeLog +0 -235
  370. package/node_modules/esprima/LICENSE.BSD +0 -21
  371. package/node_modules/esprima/README.md +0 -46
  372. package/node_modules/esprima/bin/esparse.js +0 -139
  373. package/node_modules/esprima/bin/esvalidate.js +0 -236
  374. package/node_modules/esprima/dist/esprima.js +0 -6709
  375. package/node_modules/esprima/package.json +0 -112
  376. package/node_modules/node-forge/LICENSE +0 -331
  377. package/node_modules/node-forge/README.md +0 -2071
  378. package/node_modules/node-forge/dist/forge.all.min.js +0 -2
  379. package/node_modules/node-forge/dist/forge.all.min.js.map +0 -1
  380. package/node_modules/node-forge/dist/forge.min.js +0 -2
  381. package/node_modules/node-forge/dist/forge.min.js.map +0 -1
  382. package/node_modules/node-forge/dist/prime.worker.min.js +0 -2
  383. package/node_modules/node-forge/dist/prime.worker.min.js.map +0 -1
  384. package/node_modules/node-forge/flash/swf/SocketPool.swf +0 -0
  385. package/node_modules/node-forge/lib/aes.js +0 -1091
  386. package/node_modules/node-forge/lib/aesCipherSuites.js +0 -282
  387. package/node_modules/node-forge/lib/asn1-validator.js +0 -91
  388. package/node_modules/node-forge/lib/asn1.js +0 -1503
  389. package/node_modules/node-forge/lib/baseN.js +0 -186
  390. package/node_modules/node-forge/lib/cipher.js +0 -230
  391. package/node_modules/node-forge/lib/cipherModes.js +0 -999
  392. package/node_modules/node-forge/lib/des.js +0 -496
  393. package/node_modules/node-forge/lib/ed25519.js +0 -1072
  394. package/node_modules/node-forge/lib/forge.js +0 -13
  395. package/node_modules/node-forge/lib/form.js +0 -149
  396. package/node_modules/node-forge/lib/hmac.js +0 -146
  397. package/node_modules/node-forge/lib/http.js +0 -1346
  398. package/node_modules/node-forge/lib/index.all.js +0 -16
  399. package/node_modules/node-forge/lib/index.js +0 -33
  400. package/node_modules/node-forge/lib/jsbn.js +0 -1264
  401. package/node_modules/node-forge/lib/kem.js +0 -168
  402. package/node_modules/node-forge/lib/log.js +0 -319
  403. package/node_modules/node-forge/lib/md.all.js +0 -13
  404. package/node_modules/node-forge/lib/md.js +0 -11
  405. package/node_modules/node-forge/lib/md5.js +0 -289
  406. package/node_modules/node-forge/lib/mgf.js +0 -12
  407. package/node_modules/node-forge/lib/mgf1.js +0 -57
  408. package/node_modules/node-forge/lib/oids.js +0 -179
  409. package/node_modules/node-forge/lib/pbe.js +0 -1023
  410. package/node_modules/node-forge/lib/pbkdf2.js +0 -211
  411. package/node_modules/node-forge/lib/pem.js +0 -237
  412. package/node_modules/node-forge/lib/pkcs1.js +0 -276
  413. package/node_modules/node-forge/lib/pkcs12.js +0 -1078
  414. package/node_modules/node-forge/lib/pkcs7.js +0 -1260
  415. package/node_modules/node-forge/lib/pkcs7asn1.js +0 -410
  416. package/node_modules/node-forge/lib/pki.js +0 -102
  417. package/node_modules/node-forge/lib/prime.js +0 -297
  418. package/node_modules/node-forge/lib/prime.worker.js +0 -168
  419. package/node_modules/node-forge/lib/prng.js +0 -419
  420. package/node_modules/node-forge/lib/pss.js +0 -241
  421. package/node_modules/node-forge/lib/random.js +0 -191
  422. package/node_modules/node-forge/lib/rc2.js +0 -410
  423. package/node_modules/node-forge/lib/rsa.js +0 -1949
  424. package/node_modules/node-forge/lib/sha1.js +0 -319
  425. package/node_modules/node-forge/lib/sha256.js +0 -327
  426. package/node_modules/node-forge/lib/sha512.js +0 -561
  427. package/node_modules/node-forge/lib/socket.js +0 -287
  428. package/node_modules/node-forge/lib/ssh.js +0 -236
  429. package/node_modules/node-forge/lib/tls.js +0 -4282
  430. package/node_modules/node-forge/lib/tlssocket.js +0 -249
  431. package/node_modules/node-forge/lib/util.js +0 -2652
  432. package/node_modules/node-forge/lib/x509.js +0 -3242
  433. package/node_modules/node-forge/lib/xhr.js +0 -738
  434. package/node_modules/node-forge/package.json +0 -123
  435. package/node_modules/sprintf-js/.npmignore +0 -1
  436. package/node_modules/sprintf-js/LICENSE +0 -24
  437. package/node_modules/sprintf-js/README.md +0 -88
  438. package/node_modules/sprintf-js/bower.json +0 -14
  439. package/node_modules/sprintf-js/demo/angular.html +0 -20
  440. package/node_modules/sprintf-js/dist/angular-sprintf.min.js +0 -4
  441. package/node_modules/sprintf-js/dist/angular-sprintf.min.js.map +0 -1
  442. package/node_modules/sprintf-js/dist/angular-sprintf.min.map +0 -1
  443. package/node_modules/sprintf-js/dist/sprintf.min.js +0 -4
  444. package/node_modules/sprintf-js/dist/sprintf.min.js.map +0 -1
  445. package/node_modules/sprintf-js/dist/sprintf.min.map +0 -1
  446. package/node_modules/sprintf-js/gruntfile.js +0 -36
  447. package/node_modules/sprintf-js/package.json +0 -22
  448. package/node_modules/sprintf-js/src/angular-sprintf.js +0 -18
  449. package/node_modules/sprintf-js/src/sprintf.js +0 -208
  450. package/node_modules/sprintf-js/test/test.js +0 -82
  451. package/node_modules/xml-crypto/LICENSE +0 -22
  452. package/node_modules/xml-crypto/README.md +0 -557
  453. package/node_modules/xml-crypto/lib/c14n-canonicalization.d.ts +0 -39
  454. package/node_modules/xml-crypto/lib/c14n-canonicalization.js +0 -230
  455. package/node_modules/xml-crypto/lib/c14n-canonicalization.js.map +0 -1
  456. package/node_modules/xml-crypto/lib/enveloped-signature.d.ts +0 -7
  457. package/node_modules/xml-crypto/lib/enveloped-signature.js +0 -43
  458. package/node_modules/xml-crypto/lib/enveloped-signature.js.map +0 -1
  459. package/node_modules/xml-crypto/lib/exclusive-canonicalization.d.ts +0 -38
  460. package/node_modules/xml-crypto/lib/exclusive-canonicalization.js +0 -246
  461. package/node_modules/xml-crypto/lib/exclusive-canonicalization.js.map +0 -1
  462. package/node_modules/xml-crypto/lib/hash-algorithms.d.ts +0 -13
  463. package/node_modules/xml-crypto/lib/hash-algorithms.js +0 -47
  464. package/node_modules/xml-crypto/lib/hash-algorithms.js.map +0 -1
  465. package/node_modules/xml-crypto/lib/index.d.ts +0 -5
  466. package/node_modules/xml-crypto/lib/index.js +0 -28
  467. package/node_modules/xml-crypto/lib/index.js.map +0 -1
  468. package/node_modules/xml-crypto/lib/signature-algorithms.d.ts +0 -47
  469. package/node_modules/xml-crypto/lib/signature-algorithms.js +0 -86
  470. package/node_modules/xml-crypto/lib/signature-algorithms.js.map +0 -1
  471. package/node_modules/xml-crypto/lib/signed-xml.d.ts +0 -225
  472. package/node_modules/xml-crypto/lib/signed-xml.js +0 -960
  473. package/node_modules/xml-crypto/lib/signed-xml.js.map +0 -1
  474. package/node_modules/xml-crypto/lib/types.d.ts +0 -125
  475. package/node_modules/xml-crypto/lib/types.js +0 -57
  476. package/node_modules/xml-crypto/lib/types.js.map +0 -1
  477. package/node_modules/xml-crypto/lib/utils.d.ts +0 -65
  478. package/node_modules/xml-crypto/lib/utils.js +0 -256
  479. package/node_modules/xml-crypto/lib/utils.js.map +0 -1
  480. package/node_modules/xml-crypto/node_modules/xpath/LICENSE +0 -22
  481. package/node_modules/xml-crypto/node_modules/xpath/README.md +0 -133
  482. package/node_modules/xml-crypto/node_modules/xpath/docs/XPathEvaluator.md +0 -62
  483. package/node_modules/xml-crypto/node_modules/xpath/docs/XPathResult.md +0 -47
  484. package/node_modules/xml-crypto/node_modules/xpath/docs/function resolvers.md +0 -88
  485. package/node_modules/xml-crypto/node_modules/xpath/docs/namespace resolvers.md +0 -69
  486. package/node_modules/xml-crypto/node_modules/xpath/docs/parsed expressions.md +0 -21
  487. package/node_modules/xml-crypto/node_modules/xpath/docs/variable resolvers.md +0 -89
  488. package/node_modules/xml-crypto/node_modules/xpath/docs/xpath methods.md +0 -39
  489. package/node_modules/xml-crypto/node_modules/xpath/package.json +0 -39
  490. package/node_modules/xml-crypto/node_modules/xpath/test.js +0 -1186
  491. package/node_modules/xml-crypto/node_modules/xpath/xpath.d.ts +0 -51
  492. package/node_modules/xml-crypto/node_modules/xpath/xpath.js +0 -4938
  493. package/node_modules/xml-crypto/package.json +0 -73
  494. package/node_modules/xmlbuilder2/CHANGELOG.md +0 -309
  495. package/node_modules/xmlbuilder2/LICENSE +0 -21
  496. package/node_modules/xmlbuilder2/README.md +0 -183
  497. package/node_modules/xmlbuilder2/lib/builder/BuilderFunctions.d.ts +0 -236
  498. package/node_modules/xmlbuilder2/lib/builder/BuilderFunctions.js +0 -108
  499. package/node_modules/xmlbuilder2/lib/builder/BuilderFunctions.js.map +0 -1
  500. package/node_modules/xmlbuilder2/lib/builder/BuilderFunctionsCB.d.ts +0 -17
  501. package/node_modules/xmlbuilder2/lib/builder/BuilderFunctionsCB.js +0 -26
  502. package/node_modules/xmlbuilder2/lib/builder/BuilderFunctionsCB.js.map +0 -1
  503. package/node_modules/xmlbuilder2/lib/builder/XMLBuilderCBImpl.d.ts +0 -124
  504. package/node_modules/xmlbuilder2/lib/builder/XMLBuilderCBImpl.js +0 -782
  505. package/node_modules/xmlbuilder2/lib/builder/XMLBuilderCBImpl.js.map +0 -1
  506. package/node_modules/xmlbuilder2/lib/builder/XMLBuilderImpl.d.ts +0 -143
  507. package/node_modules/xmlbuilder2/lib/builder/XMLBuilderImpl.js +0 -841
  508. package/node_modules/xmlbuilder2/lib/builder/XMLBuilderImpl.js.map +0 -1
  509. package/node_modules/xmlbuilder2/lib/builder/dom.d.ts +0 -8
  510. package/node_modules/xmlbuilder2/lib/builder/dom.js +0 -67
  511. package/node_modules/xmlbuilder2/lib/builder/dom.js.map +0 -1
  512. package/node_modules/xmlbuilder2/lib/builder/index.d.ts +0 -4
  513. package/node_modules/xmlbuilder2/lib/builder/index.js +0 -15
  514. package/node_modules/xmlbuilder2/lib/builder/index.js.map +0 -1
  515. package/node_modules/xmlbuilder2/lib/constants.d.ts +0 -1
  516. package/node_modules/xmlbuilder2/lib/constants.js +0 -4
  517. package/node_modules/xmlbuilder2/lib/constants.js.map +0 -1
  518. package/node_modules/xmlbuilder2/lib/index.d.ts +0 -1
  519. package/node_modules/xmlbuilder2/lib/index.js +0 -10
  520. package/node_modules/xmlbuilder2/lib/index.js.map +0 -1
  521. package/node_modules/xmlbuilder2/lib/interfaces.d.ts +0 -1355
  522. package/node_modules/xmlbuilder2/lib/interfaces.js +0 -76
  523. package/node_modules/xmlbuilder2/lib/interfaces.js.map +0 -1
  524. package/node_modules/xmlbuilder2/lib/readers/BaseReader.d.ts +0 -109
  525. package/node_modules/xmlbuilder2/lib/readers/BaseReader.js +0 -167
  526. package/node_modules/xmlbuilder2/lib/readers/BaseReader.js.map +0 -1
  527. package/node_modules/xmlbuilder2/lib/readers/JSONReader.d.ts +0 -14
  528. package/node_modules/xmlbuilder2/lib/readers/JSONReader.js +0 -38
  529. package/node_modules/xmlbuilder2/lib/readers/JSONReader.js.map +0 -1
  530. package/node_modules/xmlbuilder2/lib/readers/ObjectReader.d.ts +0 -15
  531. package/node_modules/xmlbuilder2/lib/readers/ObjectReader.js +0 -168
  532. package/node_modules/xmlbuilder2/lib/readers/ObjectReader.js.map +0 -1
  533. package/node_modules/xmlbuilder2/lib/readers/XMLReader.d.ts +0 -14
  534. package/node_modules/xmlbuilder2/lib/readers/XMLReader.js +0 -206
  535. package/node_modules/xmlbuilder2/lib/readers/XMLReader.js.map +0 -1
  536. package/node_modules/xmlbuilder2/lib/readers/YAMLReader.d.ts +0 -14
  537. package/node_modules/xmlbuilder2/lib/readers/YAMLReader.js +0 -44
  538. package/node_modules/xmlbuilder2/lib/readers/YAMLReader.js.map +0 -1
  539. package/node_modules/xmlbuilder2/lib/readers/index.d.ts +0 -4
  540. package/node_modules/xmlbuilder2/lib/readers/index.js +0 -11
  541. package/node_modules/xmlbuilder2/lib/readers/index.js.map +0 -1
  542. package/node_modules/xmlbuilder2/lib/writers/BaseCBWriter.d.ts +0 -110
  543. package/node_modules/xmlbuilder2/lib/writers/BaseCBWriter.js +0 -23
  544. package/node_modules/xmlbuilder2/lib/writers/BaseCBWriter.js.map +0 -1
  545. package/node_modules/xmlbuilder2/lib/writers/BaseWriter.d.ts +0 -276
  546. package/node_modules/xmlbuilder2/lib/writers/BaseWriter.js +0 -1603
  547. package/node_modules/xmlbuilder2/lib/writers/BaseWriter.js.map +0 -1
  548. package/node_modules/xmlbuilder2/lib/writers/JSONCBWriter.d.ts +0 -68
  549. package/node_modules/xmlbuilder2/lib/writers/JSONCBWriter.js +0 -172
  550. package/node_modules/xmlbuilder2/lib/writers/JSONCBWriter.js.map +0 -1
  551. package/node_modules/xmlbuilder2/lib/writers/JSONWriter.d.ts +0 -67
  552. package/node_modules/xmlbuilder2/lib/writers/JSONWriter.js +0 -222
  553. package/node_modules/xmlbuilder2/lib/writers/JSONWriter.js.map +0 -1
  554. package/node_modules/xmlbuilder2/lib/writers/MapWriter.d.ts +0 -27
  555. package/node_modules/xmlbuilder2/lib/writers/MapWriter.js +0 -84
  556. package/node_modules/xmlbuilder2/lib/writers/MapWriter.js.map +0 -1
  557. package/node_modules/xmlbuilder2/lib/writers/ObjectWriter.d.ts +0 -56
  558. package/node_modules/xmlbuilder2/lib/writers/ObjectWriter.js +0 -483
  559. package/node_modules/xmlbuilder2/lib/writers/ObjectWriter.js.map +0 -1
  560. package/node_modules/xmlbuilder2/lib/writers/XMLCBWriter.d.ts +0 -51
  561. package/node_modules/xmlbuilder2/lib/writers/XMLCBWriter.js +0 -165
  562. package/node_modules/xmlbuilder2/lib/writers/XMLCBWriter.js.map +0 -1
  563. package/node_modules/xmlbuilder2/lib/writers/XMLWriter.d.ts +0 -60
  564. package/node_modules/xmlbuilder2/lib/writers/XMLWriter.js +0 -236
  565. package/node_modules/xmlbuilder2/lib/writers/XMLWriter.js.map +0 -1
  566. package/node_modules/xmlbuilder2/lib/writers/YAMLCBWriter.d.ts +0 -61
  567. package/node_modules/xmlbuilder2/lib/writers/YAMLCBWriter.js +0 -161
  568. package/node_modules/xmlbuilder2/lib/writers/YAMLCBWriter.js.map +0 -1
  569. package/node_modules/xmlbuilder2/lib/writers/YAMLWriter.d.ts +0 -55
  570. package/node_modules/xmlbuilder2/lib/writers/YAMLWriter.js +0 -186
  571. package/node_modules/xmlbuilder2/lib/writers/YAMLWriter.js.map +0 -1
  572. package/node_modules/xmlbuilder2/lib/writers/index.d.ts +0 -5
  573. package/node_modules/xmlbuilder2/lib/writers/index.js +0 -13
  574. package/node_modules/xmlbuilder2/lib/writers/index.js.map +0 -1
  575. package/node_modules/xmlbuilder2/lib/xmlbuilder2.min.js +0 -8
  576. package/node_modules/xmlbuilder2/node_modules/argparse/CHANGELOG.md +0 -185
  577. package/node_modules/xmlbuilder2/node_modules/argparse/LICENSE +0 -21
  578. package/node_modules/xmlbuilder2/node_modules/argparse/README.md +0 -257
  579. package/node_modules/xmlbuilder2/node_modules/argparse/index.js +0 -3
  580. package/node_modules/xmlbuilder2/node_modules/argparse/lib/action/append/constant.js +0 -47
  581. package/node_modules/xmlbuilder2/node_modules/argparse/lib/action/append.js +0 -53
  582. package/node_modules/xmlbuilder2/node_modules/argparse/lib/action/count.js +0 -40
  583. package/node_modules/xmlbuilder2/node_modules/argparse/lib/action/help.js +0 -47
  584. package/node_modules/xmlbuilder2/node_modules/argparse/lib/action/store/constant.js +0 -43
  585. package/node_modules/xmlbuilder2/node_modules/argparse/lib/action/store/false.js +0 -27
  586. package/node_modules/xmlbuilder2/node_modules/argparse/lib/action/store/true.js +0 -26
  587. package/node_modules/xmlbuilder2/node_modules/argparse/lib/action/store.js +0 -50
  588. package/node_modules/xmlbuilder2/node_modules/argparse/lib/action/subparsers.js +0 -149
  589. package/node_modules/xmlbuilder2/node_modules/argparse/lib/action/version.js +0 -47
  590. package/node_modules/xmlbuilder2/node_modules/argparse/lib/action.js +0 -146
  591. package/node_modules/xmlbuilder2/node_modules/argparse/lib/action_container.js +0 -482
  592. package/node_modules/xmlbuilder2/node_modules/argparse/lib/argparse.js +0 -14
  593. package/node_modules/xmlbuilder2/node_modules/argparse/lib/argument/error.js +0 -50
  594. package/node_modules/xmlbuilder2/node_modules/argparse/lib/argument/exclusive.js +0 -54
  595. package/node_modules/xmlbuilder2/node_modules/argparse/lib/argument/group.js +0 -75
  596. package/node_modules/xmlbuilder2/node_modules/argparse/lib/argument_parser.js +0 -1161
  597. package/node_modules/xmlbuilder2/node_modules/argparse/lib/const.js +0 -21
  598. package/node_modules/xmlbuilder2/node_modules/argparse/lib/help/added_formatters.js +0 -87
  599. package/node_modules/xmlbuilder2/node_modules/argparse/lib/help/formatter.js +0 -795
  600. package/node_modules/xmlbuilder2/node_modules/argparse/lib/namespace.js +0 -76
  601. package/node_modules/xmlbuilder2/node_modules/argparse/lib/utils.js +0 -57
  602. package/node_modules/xmlbuilder2/node_modules/argparse/package.json +0 -34
  603. package/node_modules/xmlbuilder2/node_modules/js-yaml/CHANGELOG.md +0 -557
  604. package/node_modules/xmlbuilder2/node_modules/js-yaml/LICENSE +0 -21
  605. package/node_modules/xmlbuilder2/node_modules/js-yaml/README.md +0 -299
  606. package/node_modules/xmlbuilder2/node_modules/js-yaml/bin/js-yaml.js +0 -132
  607. package/node_modules/xmlbuilder2/node_modules/js-yaml/dist/js-yaml.js +0 -3989
  608. package/node_modules/xmlbuilder2/node_modules/js-yaml/dist/js-yaml.min.js +0 -1
  609. package/node_modules/xmlbuilder2/node_modules/js-yaml/index.js +0 -7
  610. package/node_modules/xmlbuilder2/node_modules/js-yaml/lib/js-yaml/common.js +0 -59
  611. package/node_modules/xmlbuilder2/node_modules/js-yaml/lib/js-yaml/dumper.js +0 -850
  612. package/node_modules/xmlbuilder2/node_modules/js-yaml/lib/js-yaml/exception.js +0 -43
  613. package/node_modules/xmlbuilder2/node_modules/js-yaml/lib/js-yaml/loader.js +0 -1644
  614. package/node_modules/xmlbuilder2/node_modules/js-yaml/lib/js-yaml/mark.js +0 -76
  615. package/node_modules/xmlbuilder2/node_modules/js-yaml/lib/js-yaml/schema/core.js +0 -18
  616. package/node_modules/xmlbuilder2/node_modules/js-yaml/lib/js-yaml/schema/default_full.js +0 -25
  617. package/node_modules/xmlbuilder2/node_modules/js-yaml/lib/js-yaml/schema/default_safe.js +0 -28
  618. package/node_modules/xmlbuilder2/node_modules/js-yaml/lib/js-yaml/schema/failsafe.js +0 -17
  619. package/node_modules/xmlbuilder2/node_modules/js-yaml/lib/js-yaml/schema/json.js +0 -25
  620. package/node_modules/xmlbuilder2/node_modules/js-yaml/lib/js-yaml/schema.js +0 -108
  621. package/node_modules/xmlbuilder2/node_modules/js-yaml/lib/js-yaml/type/binary.js +0 -138
  622. package/node_modules/xmlbuilder2/node_modules/js-yaml/lib/js-yaml/type/bool.js +0 -35
  623. package/node_modules/xmlbuilder2/node_modules/js-yaml/lib/js-yaml/type/float.js +0 -116
  624. package/node_modules/xmlbuilder2/node_modules/js-yaml/lib/js-yaml/type/int.js +0 -173
  625. package/node_modules/xmlbuilder2/node_modules/js-yaml/lib/js-yaml/type/js/function.js +0 -93
  626. package/node_modules/xmlbuilder2/node_modules/js-yaml/lib/js-yaml/type/js/regexp.js +0 -60
  627. package/node_modules/xmlbuilder2/node_modules/js-yaml/lib/js-yaml/type/js/undefined.js +0 -28
  628. package/node_modules/xmlbuilder2/node_modules/js-yaml/lib/js-yaml/type/map.js +0 -8
  629. package/node_modules/xmlbuilder2/node_modules/js-yaml/lib/js-yaml/type/merge.js +0 -12
  630. package/node_modules/xmlbuilder2/node_modules/js-yaml/lib/js-yaml/type/null.js +0 -34
  631. package/node_modules/xmlbuilder2/node_modules/js-yaml/lib/js-yaml/type/omap.js +0 -44
  632. package/node_modules/xmlbuilder2/node_modules/js-yaml/lib/js-yaml/type/pairs.js +0 -53
  633. package/node_modules/xmlbuilder2/node_modules/js-yaml/lib/js-yaml/type/seq.js +0 -8
  634. package/node_modules/xmlbuilder2/node_modules/js-yaml/lib/js-yaml/type/set.js +0 -29
  635. package/node_modules/xmlbuilder2/node_modules/js-yaml/lib/js-yaml/type/str.js +0 -8
  636. package/node_modules/xmlbuilder2/node_modules/js-yaml/lib/js-yaml/type/timestamp.js +0 -88
  637. package/node_modules/xmlbuilder2/node_modules/js-yaml/lib/js-yaml/type.js +0 -61
  638. package/node_modules/xmlbuilder2/node_modules/js-yaml/lib/js-yaml.js +0 -39
  639. package/node_modules/xmlbuilder2/node_modules/js-yaml/package.json +0 -49
  640. package/node_modules/xmlbuilder2/package.json +0 -82
  641. package/node_modules/xpath/LICENSE +0 -22
  642. package/node_modules/xpath/README.md +0 -133
  643. package/node_modules/xpath/package.json +0 -43
  644. package/node_modules/xpath/xpath.d.ts +0 -51
  645. package/node_modules/xpath/xpath.js +0 -5041
@@ -1,1260 +0,0 @@
1
- /**
2
- * Javascript implementation of PKCS#7 v1.5.
3
- *
4
- * @author Stefan Siegl
5
- * @author Dave Longley
6
- *
7
- * Copyright (c) 2012 Stefan Siegl <stesie@brokenpipe.de>
8
- * Copyright (c) 2012-2015 Digital Bazaar, Inc.
9
- *
10
- * Currently this implementation only supports ContentType of EnvelopedData,
11
- * EncryptedData, or SignedData at the root level. The top level elements may
12
- * contain only a ContentInfo of ContentType Data, i.e. plain data. Further
13
- * nesting is not (yet) supported.
14
- *
15
- * The Forge validators for PKCS #7's ASN.1 structures are available from
16
- * a separate file pkcs7asn1.js, since those are referenced from other
17
- * PKCS standards like PKCS #12.
18
- */
19
- var forge = require('./forge');
20
- require('./aes');
21
- require('./asn1');
22
- require('./des');
23
- require('./oids');
24
- require('./pem');
25
- require('./pkcs7asn1');
26
- require('./random');
27
- require('./util');
28
- require('./x509');
29
-
30
- // shortcut for ASN.1 API
31
- var asn1 = forge.asn1;
32
-
33
- // shortcut for PKCS#7 API
34
- var p7 = module.exports = forge.pkcs7 = forge.pkcs7 || {};
35
-
36
- /**
37
- * Converts a PKCS#7 message from PEM format.
38
- *
39
- * @param pem the PEM-formatted PKCS#7 message.
40
- *
41
- * @return the PKCS#7 message.
42
- */
43
- p7.messageFromPem = function(pem) {
44
- var msg = forge.pem.decode(pem)[0];
45
-
46
- if(msg.type !== 'PKCS7') {
47
- var error = new Error('Could not convert PKCS#7 message from PEM; PEM ' +
48
- 'header type is not "PKCS#7".');
49
- error.headerType = msg.type;
50
- throw error;
51
- }
52
- if(msg.procType && msg.procType.type === 'ENCRYPTED') {
53
- throw new Error('Could not convert PKCS#7 message from PEM; PEM is encrypted.');
54
- }
55
-
56
- // convert DER to ASN.1 object
57
- var obj = asn1.fromDer(msg.body);
58
-
59
- return p7.messageFromAsn1(obj);
60
- };
61
-
62
- /**
63
- * Converts a PKCS#7 message to PEM format.
64
- *
65
- * @param msg The PKCS#7 message object
66
- * @param maxline The maximum characters per line, defaults to 64.
67
- *
68
- * @return The PEM-formatted PKCS#7 message.
69
- */
70
- p7.messageToPem = function(msg, maxline) {
71
- // convert to ASN.1, then DER, then PEM-encode
72
- var pemObj = {
73
- type: 'PKCS7',
74
- body: asn1.toDer(msg.toAsn1()).getBytes()
75
- };
76
- return forge.pem.encode(pemObj, {maxline: maxline});
77
- };
78
-
79
- /**
80
- * Converts a PKCS#7 message from an ASN.1 object.
81
- *
82
- * @param obj the ASN.1 representation of a ContentInfo.
83
- *
84
- * @return the PKCS#7 message.
85
- */
86
- p7.messageFromAsn1 = function(obj) {
87
- // validate root level ContentInfo and capture data
88
- var capture = {};
89
- var errors = [];
90
- if(!asn1.validate(obj, p7.asn1.contentInfoValidator, capture, errors)) {
91
- var error = new Error('Cannot read PKCS#7 message. ' +
92
- 'ASN.1 object is not an PKCS#7 ContentInfo.');
93
- error.errors = errors;
94
- throw error;
95
- }
96
-
97
- var contentType = asn1.derToOid(capture.contentType);
98
- var msg;
99
-
100
- switch(contentType) {
101
- case forge.pki.oids.envelopedData:
102
- msg = p7.createEnvelopedData();
103
- break;
104
-
105
- case forge.pki.oids.encryptedData:
106
- msg = p7.createEncryptedData();
107
- break;
108
-
109
- case forge.pki.oids.signedData:
110
- msg = p7.createSignedData();
111
- break;
112
-
113
- default:
114
- throw new Error('Cannot read PKCS#7 message. ContentType with OID ' +
115
- contentType + ' is not (yet) supported.');
116
- }
117
-
118
- msg.fromAsn1(capture.content.value[0]);
119
- return msg;
120
- };
121
-
122
- p7.createSignedData = function() {
123
- var msg = null;
124
- msg = {
125
- type: forge.pki.oids.signedData,
126
- version: 1,
127
- certificates: [],
128
- crls: [],
129
- // TODO: add json-formatted signer stuff here?
130
- signers: [],
131
- // populated during sign()
132
- digestAlgorithmIdentifiers: [],
133
- contentInfo: null,
134
- signerInfos: [],
135
-
136
- fromAsn1: function(obj) {
137
- // validate SignedData content block and capture data.
138
- _fromAsn1(msg, obj, p7.asn1.signedDataValidator);
139
- msg.certificates = [];
140
- msg.crls = [];
141
- msg.digestAlgorithmIdentifiers = [];
142
- msg.contentInfo = null;
143
- msg.signerInfos = [];
144
-
145
- if(msg.rawCapture.certificates) {
146
- var certs = msg.rawCapture.certificates.value;
147
- for(var i = 0; i < certs.length; ++i) {
148
- msg.certificates.push(forge.pki.certificateFromAsn1(certs[i]));
149
- }
150
- }
151
-
152
- // TODO: parse crls
153
- },
154
-
155
- toAsn1: function() {
156
- // degenerate case with no content
157
- if(!msg.contentInfo) {
158
- msg.sign();
159
- }
160
-
161
- var certs = [];
162
- for(var i = 0; i < msg.certificates.length; ++i) {
163
- certs.push(forge.pki.certificateToAsn1(msg.certificates[i]));
164
- }
165
-
166
- var crls = [];
167
- // TODO: implement CRLs
168
-
169
- // [0] SignedData
170
- var signedData = asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [
171
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [
172
- // Version
173
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,
174
- asn1.integerToDer(msg.version).getBytes()),
175
- // DigestAlgorithmIdentifiers
176
- asn1.create(
177
- asn1.Class.UNIVERSAL, asn1.Type.SET, true,
178
- msg.digestAlgorithmIdentifiers),
179
- // ContentInfo
180
- msg.contentInfo
181
- ])
182
- ]);
183
- if(certs.length > 0) {
184
- // [0] IMPLICIT ExtendedCertificatesAndCertificates OPTIONAL
185
- signedData.value[0].value.push(
186
- asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, certs));
187
- }
188
- if(crls.length > 0) {
189
- // [1] IMPLICIT CertificateRevocationLists OPTIONAL
190
- signedData.value[0].value.push(
191
- asn1.create(asn1.Class.CONTEXT_SPECIFIC, 1, true, crls));
192
- }
193
- // SignerInfos
194
- signedData.value[0].value.push(
195
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SET, true,
196
- msg.signerInfos));
197
-
198
- // ContentInfo
199
- return asn1.create(
200
- asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [
201
- // ContentType
202
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,
203
- asn1.oidToDer(msg.type).getBytes()),
204
- // [0] SignedData
205
- signedData
206
- ]);
207
- },
208
-
209
- /**
210
- * Add (another) entity to list of signers.
211
- *
212
- * Note: If authenticatedAttributes are provided, then, per RFC 2315,
213
- * they must include at least two attributes: content type and
214
- * message digest. The message digest attribute value will be
215
- * auto-calculated during signing and will be ignored if provided.
216
- *
217
- * Here's an example of providing these two attributes:
218
- *
219
- * forge.pkcs7.createSignedData();
220
- * p7.addSigner({
221
- * issuer: cert.issuer.attributes,
222
- * serialNumber: cert.serialNumber,
223
- * key: privateKey,
224
- * digestAlgorithm: forge.pki.oids.sha1,
225
- * authenticatedAttributes: [{
226
- * type: forge.pki.oids.contentType,
227
- * value: forge.pki.oids.data
228
- * }, {
229
- * type: forge.pki.oids.messageDigest
230
- * }]
231
- * });
232
- *
233
- * TODO: Support [subjectKeyIdentifier] as signer's ID.
234
- *
235
- * @param signer the signer information:
236
- * key the signer's private key.
237
- * [certificate] a certificate containing the public key
238
- * associated with the signer's private key; use this option as
239
- * an alternative to specifying signer.issuer and
240
- * signer.serialNumber.
241
- * [issuer] the issuer attributes (eg: cert.issuer.attributes).
242
- * [serialNumber] the signer's certificate's serial number in
243
- * hexadecimal (eg: cert.serialNumber).
244
- * [digestAlgorithm] the message digest OID, as a string, to use
245
- * (eg: forge.pki.oids.sha1).
246
- * [authenticatedAttributes] an optional array of attributes
247
- * to also sign along with the content.
248
- */
249
- addSigner: function(signer) {
250
- var issuer = signer.issuer;
251
- var serialNumber = signer.serialNumber;
252
- if(signer.certificate) {
253
- var cert = signer.certificate;
254
- if(typeof cert === 'string') {
255
- cert = forge.pki.certificateFromPem(cert);
256
- }
257
- issuer = cert.issuer.attributes;
258
- serialNumber = cert.serialNumber;
259
- }
260
- var key = signer.key;
261
- if(!key) {
262
- throw new Error(
263
- 'Could not add PKCS#7 signer; no private key specified.');
264
- }
265
- if(typeof key === 'string') {
266
- key = forge.pki.privateKeyFromPem(key);
267
- }
268
-
269
- // ensure OID known for digest algorithm
270
- var digestAlgorithm = signer.digestAlgorithm || forge.pki.oids.sha1;
271
- switch(digestAlgorithm) {
272
- case forge.pki.oids.sha1:
273
- case forge.pki.oids.sha256:
274
- case forge.pki.oids.sha384:
275
- case forge.pki.oids.sha512:
276
- case forge.pki.oids.md5:
277
- break;
278
- default:
279
- throw new Error(
280
- 'Could not add PKCS#7 signer; unknown message digest algorithm: ' +
281
- digestAlgorithm);
282
- }
283
-
284
- // if authenticatedAttributes is present, then the attributes
285
- // must contain at least PKCS #9 content-type and message-digest
286
- var authenticatedAttributes = signer.authenticatedAttributes || [];
287
- if(authenticatedAttributes.length > 0) {
288
- var contentType = false;
289
- var messageDigest = false;
290
- for(var i = 0; i < authenticatedAttributes.length; ++i) {
291
- var attr = authenticatedAttributes[i];
292
- if(!contentType && attr.type === forge.pki.oids.contentType) {
293
- contentType = true;
294
- if(messageDigest) {
295
- break;
296
- }
297
- continue;
298
- }
299
- if(!messageDigest && attr.type === forge.pki.oids.messageDigest) {
300
- messageDigest = true;
301
- if(contentType) {
302
- break;
303
- }
304
- continue;
305
- }
306
- }
307
-
308
- if(!contentType || !messageDigest) {
309
- throw new Error('Invalid signer.authenticatedAttributes. If ' +
310
- 'signer.authenticatedAttributes is specified, then it must ' +
311
- 'contain at least two attributes, PKCS #9 content-type and ' +
312
- 'PKCS #9 message-digest.');
313
- }
314
- }
315
-
316
- msg.signers.push({
317
- key: key,
318
- version: 1,
319
- issuer: issuer,
320
- serialNumber: serialNumber,
321
- digestAlgorithm: digestAlgorithm,
322
- signatureAlgorithm: forge.pki.oids.rsaEncryption,
323
- signature: null,
324
- authenticatedAttributes: authenticatedAttributes,
325
- unauthenticatedAttributes: []
326
- });
327
- },
328
-
329
- /**
330
- * Signs the content.
331
- * @param options Options to apply when signing:
332
- * [detached] boolean. If signing should be done in detached mode. Defaults to false.
333
- */
334
- sign: function(options) {
335
- options = options || {};
336
- // auto-generate content info
337
- if(typeof msg.content !== 'object' || msg.contentInfo === null) {
338
- // use Data ContentInfo
339
- msg.contentInfo = asn1.create(
340
- asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [
341
- // ContentType
342
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,
343
- asn1.oidToDer(forge.pki.oids.data).getBytes())
344
- ]);
345
-
346
- // add actual content, if present
347
- if('content' in msg) {
348
- var content;
349
- if(msg.content instanceof forge.util.ByteBuffer) {
350
- content = msg.content.bytes();
351
- } else if(typeof msg.content === 'string') {
352
- content = forge.util.encodeUtf8(msg.content);
353
- }
354
-
355
- if (options.detached) {
356
- msg.detachedContent = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, content);
357
- } else {
358
- msg.contentInfo.value.push(
359
- // [0] EXPLICIT content
360
- asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [
361
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,
362
- content)
363
- ]));
364
- }
365
- }
366
- }
367
-
368
- // no signers, return early (degenerate case for certificate container)
369
- if(msg.signers.length === 0) {
370
- return;
371
- }
372
-
373
- // generate digest algorithm identifiers
374
- var mds = addDigestAlgorithmIds();
375
-
376
- // generate signerInfos
377
- addSignerInfos(mds);
378
- },
379
-
380
- verify: function() {
381
- throw new Error('PKCS#7 signature verification not yet implemented.');
382
- },
383
-
384
- /**
385
- * Add a certificate.
386
- *
387
- * @param cert the certificate to add.
388
- */
389
- addCertificate: function(cert) {
390
- // convert from PEM
391
- if(typeof cert === 'string') {
392
- cert = forge.pki.certificateFromPem(cert);
393
- }
394
- msg.certificates.push(cert);
395
- },
396
-
397
- /**
398
- * Add a certificate revokation list.
399
- *
400
- * @param crl the certificate revokation list to add.
401
- */
402
- addCertificateRevokationList: function(crl) {
403
- throw new Error('PKCS#7 CRL support not yet implemented.');
404
- }
405
- };
406
- return msg;
407
-
408
- function addDigestAlgorithmIds() {
409
- var mds = {};
410
-
411
- for(var i = 0; i < msg.signers.length; ++i) {
412
- var signer = msg.signers[i];
413
- var oid = signer.digestAlgorithm;
414
- if(!(oid in mds)) {
415
- // content digest
416
- mds[oid] = forge.md[forge.pki.oids[oid]].create();
417
- }
418
- if(signer.authenticatedAttributes.length === 0) {
419
- // no custom attributes to digest; use content message digest
420
- signer.md = mds[oid];
421
- } else {
422
- // custom attributes to be digested; use own message digest
423
- // TODO: optimize to just copy message digest state if that
424
- // feature is ever supported with message digests
425
- signer.md = forge.md[forge.pki.oids[oid]].create();
426
- }
427
- }
428
-
429
- // add unique digest algorithm identifiers
430
- msg.digestAlgorithmIdentifiers = [];
431
- for(var oid in mds) {
432
- msg.digestAlgorithmIdentifiers.push(
433
- // AlgorithmIdentifier
434
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [
435
- // algorithm
436
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,
437
- asn1.oidToDer(oid).getBytes()),
438
- // parameters (null)
439
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')
440
- ]));
441
- }
442
-
443
- return mds;
444
- }
445
-
446
- function addSignerInfos(mds) {
447
- var content;
448
-
449
- if (msg.detachedContent) {
450
- // Signature has been made in detached mode.
451
- content = msg.detachedContent;
452
- } else {
453
- // Note: ContentInfo is a SEQUENCE with 2 values, second value is
454
- // the content field and is optional for a ContentInfo but required here
455
- // since signers are present
456
- // get ContentInfo content
457
- content = msg.contentInfo.value[1];
458
- // skip [0] EXPLICIT content wrapper
459
- content = content.value[0];
460
- }
461
-
462
- if(!content) {
463
- throw new Error(
464
- 'Could not sign PKCS#7 message; there is no content to sign.');
465
- }
466
-
467
- // get ContentInfo content type
468
- var contentType = asn1.derToOid(msg.contentInfo.value[0].value);
469
-
470
- // serialize content
471
- var bytes = asn1.toDer(content);
472
-
473
- // skip identifier and length per RFC 2315 9.3
474
- // skip identifier (1 byte)
475
- bytes.getByte();
476
- // read and discard length bytes
477
- asn1.getBerValueLength(bytes);
478
- bytes = bytes.getBytes();
479
-
480
- // digest content DER value bytes
481
- for(var oid in mds) {
482
- mds[oid].start().update(bytes);
483
- }
484
-
485
- // sign content
486
- var signingTime = new Date();
487
- for(var i = 0; i < msg.signers.length; ++i) {
488
- var signer = msg.signers[i];
489
-
490
- if(signer.authenticatedAttributes.length === 0) {
491
- // if ContentInfo content type is not "Data", then
492
- // authenticatedAttributes must be present per RFC 2315
493
- if(contentType !== forge.pki.oids.data) {
494
- throw new Error(
495
- 'Invalid signer; authenticatedAttributes must be present ' +
496
- 'when the ContentInfo content type is not PKCS#7 Data.');
497
- }
498
- } else {
499
- // process authenticated attributes
500
- // [0] IMPLICIT
501
- signer.authenticatedAttributesAsn1 = asn1.create(
502
- asn1.Class.CONTEXT_SPECIFIC, 0, true, []);
503
-
504
- // per RFC 2315, attributes are to be digested using a SET container
505
- // not the above [0] IMPLICIT container
506
- var attrsAsn1 = asn1.create(
507
- asn1.Class.UNIVERSAL, asn1.Type.SET, true, []);
508
-
509
- for(var ai = 0; ai < signer.authenticatedAttributes.length; ++ai) {
510
- var attr = signer.authenticatedAttributes[ai];
511
- if(attr.type === forge.pki.oids.messageDigest) {
512
- // use content message digest as value
513
- attr.value = mds[signer.digestAlgorithm].digest();
514
- } else if(attr.type === forge.pki.oids.signingTime) {
515
- // auto-populate signing time if not already set
516
- if(!attr.value) {
517
- attr.value = signingTime;
518
- }
519
- }
520
-
521
- // convert to ASN.1 and push onto Attributes SET (for signing) and
522
- // onto authenticatedAttributesAsn1 to complete SignedData ASN.1
523
- // TODO: optimize away duplication
524
- attrsAsn1.value.push(_attributeToAsn1(attr));
525
- signer.authenticatedAttributesAsn1.value.push(_attributeToAsn1(attr));
526
- }
527
-
528
- // DER-serialize and digest SET OF attributes only
529
- bytes = asn1.toDer(attrsAsn1).getBytes();
530
- signer.md.start().update(bytes);
531
- }
532
-
533
- // sign digest
534
- signer.signature = signer.key.sign(signer.md, 'RSASSA-PKCS1-V1_5');
535
- }
536
-
537
- // add signer info
538
- msg.signerInfos = _signersToAsn1(msg.signers);
539
- }
540
- };
541
-
542
- /**
543
- * Creates an empty PKCS#7 message of type EncryptedData.
544
- *
545
- * @return the message.
546
- */
547
- p7.createEncryptedData = function() {
548
- var msg = null;
549
- msg = {
550
- type: forge.pki.oids.encryptedData,
551
- version: 0,
552
- encryptedContent: {
553
- algorithm: forge.pki.oids['aes256-CBC']
554
- },
555
-
556
- /**
557
- * Reads an EncryptedData content block (in ASN.1 format)
558
- *
559
- * @param obj The ASN.1 representation of the EncryptedData content block
560
- */
561
- fromAsn1: function(obj) {
562
- // Validate EncryptedData content block and capture data.
563
- _fromAsn1(msg, obj, p7.asn1.encryptedDataValidator);
564
- },
565
-
566
- /**
567
- * Decrypt encrypted content
568
- *
569
- * @param key The (symmetric) key as a byte buffer
570
- */
571
- decrypt: function(key) {
572
- if(key !== undefined) {
573
- msg.encryptedContent.key = key;
574
- }
575
- _decryptContent(msg);
576
- }
577
- };
578
- return msg;
579
- };
580
-
581
- /**
582
- * Creates an empty PKCS#7 message of type EnvelopedData.
583
- *
584
- * @return the message.
585
- */
586
- p7.createEnvelopedData = function() {
587
- var msg = null;
588
- msg = {
589
- type: forge.pki.oids.envelopedData,
590
- version: 0,
591
- recipients: [],
592
- encryptedContent: {
593
- algorithm: forge.pki.oids['aes256-CBC']
594
- },
595
-
596
- /**
597
- * Reads an EnvelopedData content block (in ASN.1 format)
598
- *
599
- * @param obj the ASN.1 representation of the EnvelopedData content block.
600
- */
601
- fromAsn1: function(obj) {
602
- // validate EnvelopedData content block and capture data
603
- var capture = _fromAsn1(msg, obj, p7.asn1.envelopedDataValidator);
604
- msg.recipients = _recipientsFromAsn1(capture.recipientInfos.value);
605
- },
606
-
607
- toAsn1: function() {
608
- // ContentInfo
609
- return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [
610
- // ContentType
611
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,
612
- asn1.oidToDer(msg.type).getBytes()),
613
- // [0] EnvelopedData
614
- asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [
615
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [
616
- // Version
617
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,
618
- asn1.integerToDer(msg.version).getBytes()),
619
- // RecipientInfos
620
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SET, true,
621
- _recipientsToAsn1(msg.recipients)),
622
- // EncryptedContentInfo
623
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true,
624
- _encryptedContentToAsn1(msg.encryptedContent))
625
- ])
626
- ])
627
- ]);
628
- },
629
-
630
- /**
631
- * Find recipient by X.509 certificate's issuer.
632
- *
633
- * @param cert the certificate with the issuer to look for.
634
- *
635
- * @return the recipient object.
636
- */
637
- findRecipient: function(cert) {
638
- var sAttr = cert.issuer.attributes;
639
-
640
- for(var i = 0; i < msg.recipients.length; ++i) {
641
- var r = msg.recipients[i];
642
- var rAttr = r.issuer;
643
-
644
- if(r.serialNumber !== cert.serialNumber) {
645
- continue;
646
- }
647
-
648
- if(rAttr.length !== sAttr.length) {
649
- continue;
650
- }
651
-
652
- var match = true;
653
- for(var j = 0; j < sAttr.length; ++j) {
654
- if(rAttr[j].type !== sAttr[j].type ||
655
- rAttr[j].value !== sAttr[j].value) {
656
- match = false;
657
- break;
658
- }
659
- }
660
-
661
- if(match) {
662
- return r;
663
- }
664
- }
665
-
666
- return null;
667
- },
668
-
669
- /**
670
- * Decrypt enveloped content
671
- *
672
- * @param recipient The recipient object related to the private key
673
- * @param privKey The (RSA) private key object
674
- */
675
- decrypt: function(recipient, privKey) {
676
- if(msg.encryptedContent.key === undefined && recipient !== undefined &&
677
- privKey !== undefined) {
678
- switch(recipient.encryptedContent.algorithm) {
679
- case forge.pki.oids.rsaEncryption:
680
- case forge.pki.oids.desCBC:
681
- var key = privKey.decrypt(recipient.encryptedContent.content);
682
- msg.encryptedContent.key = forge.util.createBuffer(key);
683
- break;
684
-
685
- default:
686
- throw new Error('Unsupported asymmetric cipher, ' +
687
- 'OID ' + recipient.encryptedContent.algorithm);
688
- }
689
- }
690
-
691
- _decryptContent(msg);
692
- },
693
-
694
- /**
695
- * Add (another) entity to list of recipients.
696
- *
697
- * @param cert The certificate of the entity to add.
698
- */
699
- addRecipient: function(cert) {
700
- msg.recipients.push({
701
- version: 0,
702
- issuer: cert.issuer.attributes,
703
- serialNumber: cert.serialNumber,
704
- encryptedContent: {
705
- // We simply assume rsaEncryption here, since forge.pki only
706
- // supports RSA so far. If the PKI module supports other
707
- // ciphers one day, we need to modify this one as well.
708
- algorithm: forge.pki.oids.rsaEncryption,
709
- key: cert.publicKey
710
- }
711
- });
712
- },
713
-
714
- /**
715
- * Encrypt enveloped content.
716
- *
717
- * This function supports two optional arguments, cipher and key, which
718
- * can be used to influence symmetric encryption. Unless cipher is
719
- * provided, the cipher specified in encryptedContent.algorithm is used
720
- * (defaults to AES-256-CBC). If no key is provided, encryptedContent.key
721
- * is (re-)used. If that one's not set, a random key will be generated
722
- * automatically.
723
- *
724
- * @param [key] The key to be used for symmetric encryption.
725
- * @param [cipher] The OID of the symmetric cipher to use.
726
- */
727
- encrypt: function(key, cipher) {
728
- // Part 1: Symmetric encryption
729
- if(msg.encryptedContent.content === undefined) {
730
- cipher = cipher || msg.encryptedContent.algorithm;
731
- key = key || msg.encryptedContent.key;
732
-
733
- var keyLen, ivLen, ciphFn;
734
- switch(cipher) {
735
- case forge.pki.oids['aes128-CBC']:
736
- keyLen = 16;
737
- ivLen = 16;
738
- ciphFn = forge.aes.createEncryptionCipher;
739
- break;
740
-
741
- case forge.pki.oids['aes192-CBC']:
742
- keyLen = 24;
743
- ivLen = 16;
744
- ciphFn = forge.aes.createEncryptionCipher;
745
- break;
746
-
747
- case forge.pki.oids['aes256-CBC']:
748
- keyLen = 32;
749
- ivLen = 16;
750
- ciphFn = forge.aes.createEncryptionCipher;
751
- break;
752
-
753
- case forge.pki.oids['des-EDE3-CBC']:
754
- keyLen = 24;
755
- ivLen = 8;
756
- ciphFn = forge.des.createEncryptionCipher;
757
- break;
758
-
759
- default:
760
- throw new Error('Unsupported symmetric cipher, OID ' + cipher);
761
- }
762
-
763
- if(key === undefined) {
764
- key = forge.util.createBuffer(forge.random.getBytes(keyLen));
765
- } else if(key.length() != keyLen) {
766
- throw new Error('Symmetric key has wrong length; ' +
767
- 'got ' + key.length() + ' bytes, expected ' + keyLen + '.');
768
- }
769
-
770
- // Keep a copy of the key & IV in the object, so the caller can
771
- // use it for whatever reason.
772
- msg.encryptedContent.algorithm = cipher;
773
- msg.encryptedContent.key = key;
774
- msg.encryptedContent.parameter = forge.util.createBuffer(
775
- forge.random.getBytes(ivLen));
776
-
777
- var ciph = ciphFn(key);
778
- ciph.start(msg.encryptedContent.parameter.copy());
779
- ciph.update(msg.content);
780
-
781
- // The finish function does PKCS#7 padding by default, therefore
782
- // no action required by us.
783
- if(!ciph.finish()) {
784
- throw new Error('Symmetric encryption failed.');
785
- }
786
-
787
- msg.encryptedContent.content = ciph.output;
788
- }
789
-
790
- // Part 2: asymmetric encryption for each recipient
791
- for(var i = 0; i < msg.recipients.length; ++i) {
792
- var recipient = msg.recipients[i];
793
-
794
- // Nothing to do, encryption already done.
795
- if(recipient.encryptedContent.content !== undefined) {
796
- continue;
797
- }
798
-
799
- switch(recipient.encryptedContent.algorithm) {
800
- case forge.pki.oids.rsaEncryption:
801
- recipient.encryptedContent.content =
802
- recipient.encryptedContent.key.encrypt(
803
- msg.encryptedContent.key.data);
804
- break;
805
-
806
- default:
807
- throw new Error('Unsupported asymmetric cipher, OID ' +
808
- recipient.encryptedContent.algorithm);
809
- }
810
- }
811
- }
812
- };
813
- return msg;
814
- };
815
-
816
- /**
817
- * Converts a single recipient from an ASN.1 object.
818
- *
819
- * @param obj the ASN.1 RecipientInfo.
820
- *
821
- * @return the recipient object.
822
- */
823
- function _recipientFromAsn1(obj) {
824
- // validate EnvelopedData content block and capture data
825
- var capture = {};
826
- var errors = [];
827
- if(!asn1.validate(obj, p7.asn1.recipientInfoValidator, capture, errors)) {
828
- var error = new Error('Cannot read PKCS#7 RecipientInfo. ' +
829
- 'ASN.1 object is not an PKCS#7 RecipientInfo.');
830
- error.errors = errors;
831
- throw error;
832
- }
833
-
834
- return {
835
- version: capture.version.charCodeAt(0),
836
- issuer: forge.pki.RDNAttributesAsArray(capture.issuer),
837
- serialNumber: forge.util.createBuffer(capture.serial).toHex(),
838
- encryptedContent: {
839
- algorithm: asn1.derToOid(capture.encAlgorithm),
840
- parameter: capture.encParameter ? capture.encParameter.value : undefined,
841
- content: capture.encKey
842
- }
843
- };
844
- }
845
-
846
- /**
847
- * Converts a single recipient object to an ASN.1 object.
848
- *
849
- * @param obj the recipient object.
850
- *
851
- * @return the ASN.1 RecipientInfo.
852
- */
853
- function _recipientToAsn1(obj) {
854
- return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [
855
- // Version
856
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,
857
- asn1.integerToDer(obj.version).getBytes()),
858
- // IssuerAndSerialNumber
859
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [
860
- // Name
861
- forge.pki.distinguishedNameToAsn1({attributes: obj.issuer}),
862
- // Serial
863
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,
864
- forge.util.hexToBytes(obj.serialNumber))
865
- ]),
866
- // KeyEncryptionAlgorithmIdentifier
867
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [
868
- // Algorithm
869
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,
870
- asn1.oidToDer(obj.encryptedContent.algorithm).getBytes()),
871
- // Parameter, force NULL, only RSA supported for now.
872
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')
873
- ]),
874
- // EncryptedKey
875
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,
876
- obj.encryptedContent.content)
877
- ]);
878
- }
879
-
880
- /**
881
- * Map a set of RecipientInfo ASN.1 objects to recipient objects.
882
- *
883
- * @param infos an array of ASN.1 representations RecipientInfo (i.e. SET OF).
884
- *
885
- * @return an array of recipient objects.
886
- */
887
- function _recipientsFromAsn1(infos) {
888
- var ret = [];
889
- for(var i = 0; i < infos.length; ++i) {
890
- ret.push(_recipientFromAsn1(infos[i]));
891
- }
892
- return ret;
893
- }
894
-
895
- /**
896
- * Map an array of recipient objects to ASN.1 RecipientInfo objects.
897
- *
898
- * @param recipients an array of recipientInfo objects.
899
- *
900
- * @return an array of ASN.1 RecipientInfos.
901
- */
902
- function _recipientsToAsn1(recipients) {
903
- var ret = [];
904
- for(var i = 0; i < recipients.length; ++i) {
905
- ret.push(_recipientToAsn1(recipients[i]));
906
- }
907
- return ret;
908
- }
909
-
910
- /**
911
- * Converts a single signer from an ASN.1 object.
912
- *
913
- * @param obj the ASN.1 representation of a SignerInfo.
914
- *
915
- * @return the signer object.
916
- */
917
- function _signerFromAsn1(obj) {
918
- // validate EnvelopedData content block and capture data
919
- var capture = {};
920
- var errors = [];
921
- if(!asn1.validate(obj, p7.asn1.signerInfoValidator, capture, errors)) {
922
- var error = new Error('Cannot read PKCS#7 SignerInfo. ' +
923
- 'ASN.1 object is not an PKCS#7 SignerInfo.');
924
- error.errors = errors;
925
- throw error;
926
- }
927
-
928
- var rval = {
929
- version: capture.version.charCodeAt(0),
930
- issuer: forge.pki.RDNAttributesAsArray(capture.issuer),
931
- serialNumber: forge.util.createBuffer(capture.serial).toHex(),
932
- digestAlgorithm: asn1.derToOid(capture.digestAlgorithm),
933
- signatureAlgorithm: asn1.derToOid(capture.signatureAlgorithm),
934
- signature: capture.signature,
935
- authenticatedAttributes: [],
936
- unauthenticatedAttributes: []
937
- };
938
-
939
- // TODO: convert attributes
940
- var authenticatedAttributes = capture.authenticatedAttributes || [];
941
- var unauthenticatedAttributes = capture.unauthenticatedAttributes || [];
942
-
943
- return rval;
944
- }
945
-
946
- /**
947
- * Converts a single signerInfo object to an ASN.1 object.
948
- *
949
- * @param obj the signerInfo object.
950
- *
951
- * @return the ASN.1 representation of a SignerInfo.
952
- */
953
- function _signerToAsn1(obj) {
954
- // SignerInfo
955
- var rval = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [
956
- // version
957
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,
958
- asn1.integerToDer(obj.version).getBytes()),
959
- // issuerAndSerialNumber
960
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [
961
- // name
962
- forge.pki.distinguishedNameToAsn1({attributes: obj.issuer}),
963
- // serial
964
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,
965
- forge.util.hexToBytes(obj.serialNumber))
966
- ]),
967
- // digestAlgorithm
968
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [
969
- // algorithm
970
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,
971
- asn1.oidToDer(obj.digestAlgorithm).getBytes()),
972
- // parameters (null)
973
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')
974
- ])
975
- ]);
976
-
977
- // authenticatedAttributes (OPTIONAL)
978
- if(obj.authenticatedAttributesAsn1) {
979
- // add ASN.1 previously generated during signing
980
- rval.value.push(obj.authenticatedAttributesAsn1);
981
- }
982
-
983
- // digestEncryptionAlgorithm
984
- rval.value.push(asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [
985
- // algorithm
986
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,
987
- asn1.oidToDer(obj.signatureAlgorithm).getBytes()),
988
- // parameters (null)
989
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')
990
- ]));
991
-
992
- // encryptedDigest
993
- rval.value.push(asn1.create(
994
- asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, obj.signature));
995
-
996
- // unauthenticatedAttributes (OPTIONAL)
997
- if(obj.unauthenticatedAttributes.length > 0) {
998
- // [1] IMPLICIT
999
- var attrsAsn1 = asn1.create(asn1.Class.CONTEXT_SPECIFIC, 1, true, []);
1000
- for(var i = 0; i < obj.unauthenticatedAttributes.length; ++i) {
1001
- var attr = obj.unauthenticatedAttributes[i];
1002
- attrsAsn1.values.push(_attributeToAsn1(attr));
1003
- }
1004
- rval.value.push(attrsAsn1);
1005
- }
1006
-
1007
- return rval;
1008
- }
1009
-
1010
- /**
1011
- * Map a set of SignerInfo ASN.1 objects to an array of signer objects.
1012
- *
1013
- * @param signerInfoAsn1s an array of ASN.1 SignerInfos (i.e. SET OF).
1014
- *
1015
- * @return an array of signers objects.
1016
- */
1017
- function _signersFromAsn1(signerInfoAsn1s) {
1018
- var ret = [];
1019
- for(var i = 0; i < signerInfoAsn1s.length; ++i) {
1020
- ret.push(_signerFromAsn1(signerInfoAsn1s[i]));
1021
- }
1022
- return ret;
1023
- }
1024
-
1025
- /**
1026
- * Map an array of signer objects to ASN.1 objects.
1027
- *
1028
- * @param signers an array of signer objects.
1029
- *
1030
- * @return an array of ASN.1 SignerInfos.
1031
- */
1032
- function _signersToAsn1(signers) {
1033
- var ret = [];
1034
- for(var i = 0; i < signers.length; ++i) {
1035
- ret.push(_signerToAsn1(signers[i]));
1036
- }
1037
- return ret;
1038
- }
1039
-
1040
- /**
1041
- * Convert an attribute object to an ASN.1 Attribute.
1042
- *
1043
- * @param attr the attribute object.
1044
- *
1045
- * @return the ASN.1 Attribute.
1046
- */
1047
- function _attributeToAsn1(attr) {
1048
- var value;
1049
-
1050
- // TODO: generalize to support more attributes
1051
- if(attr.type === forge.pki.oids.contentType) {
1052
- value = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,
1053
- asn1.oidToDer(attr.value).getBytes());
1054
- } else if(attr.type === forge.pki.oids.messageDigest) {
1055
- value = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,
1056
- attr.value.bytes());
1057
- } else if(attr.type === forge.pki.oids.signingTime) {
1058
- /* Note per RFC 2985: Dates between 1 January 1950 and 31 December 2049
1059
- (inclusive) MUST be encoded as UTCTime. Any dates with year values
1060
- before 1950 or after 2049 MUST be encoded as GeneralizedTime. [Further,]
1061
- UTCTime values MUST be expressed in Greenwich Mean Time (Zulu) and MUST
1062
- include seconds (i.e., times are YYMMDDHHMMSSZ), even where the
1063
- number of seconds is zero. Midnight (GMT) must be represented as
1064
- "YYMMDD000000Z". */
1065
- // TODO: make these module-level constants
1066
- var jan_1_1950 = new Date('1950-01-01T00:00:00Z');
1067
- var jan_1_2050 = new Date('2050-01-01T00:00:00Z');
1068
- var date = attr.value;
1069
- if(typeof date === 'string') {
1070
- // try to parse date
1071
- var timestamp = Date.parse(date);
1072
- if(!isNaN(timestamp)) {
1073
- date = new Date(timestamp);
1074
- } else if(date.length === 13) {
1075
- // YYMMDDHHMMSSZ (13 chars for UTCTime)
1076
- date = asn1.utcTimeToDate(date);
1077
- } else {
1078
- // assume generalized time
1079
- date = asn1.generalizedTimeToDate(date);
1080
- }
1081
- }
1082
-
1083
- if(date >= jan_1_1950 && date < jan_1_2050) {
1084
- value = asn1.create(
1085
- asn1.Class.UNIVERSAL, asn1.Type.UTCTIME, false,
1086
- asn1.dateToUtcTime(date));
1087
- } else {
1088
- value = asn1.create(
1089
- asn1.Class.UNIVERSAL, asn1.Type.GENERALIZEDTIME, false,
1090
- asn1.dateToGeneralizedTime(date));
1091
- }
1092
- }
1093
-
1094
- // TODO: expose as common API call
1095
- // create a RelativeDistinguishedName set
1096
- // each value in the set is an AttributeTypeAndValue first
1097
- // containing the type (an OID) and second the value
1098
- return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [
1099
- // AttributeType
1100
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,
1101
- asn1.oidToDer(attr.type).getBytes()),
1102
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SET, true, [
1103
- // AttributeValue
1104
- value
1105
- ])
1106
- ]);
1107
- }
1108
-
1109
- /**
1110
- * Map messages encrypted content to ASN.1 objects.
1111
- *
1112
- * @param ec The encryptedContent object of the message.
1113
- *
1114
- * @return ASN.1 representation of the encryptedContent object (SEQUENCE).
1115
- */
1116
- function _encryptedContentToAsn1(ec) {
1117
- return [
1118
- // ContentType, always Data for the moment
1119
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,
1120
- asn1.oidToDer(forge.pki.oids.data).getBytes()),
1121
- // ContentEncryptionAlgorithmIdentifier
1122
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [
1123
- // Algorithm
1124
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,
1125
- asn1.oidToDer(ec.algorithm).getBytes()),
1126
- // Parameters (IV)
1127
- !ec.parameter ?
1128
- undefined :
1129
- asn1.create(
1130
- asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,
1131
- ec.parameter.getBytes())
1132
- ]),
1133
- // [0] EncryptedContent
1134
- asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [
1135
- asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,
1136
- ec.content.getBytes())
1137
- ])
1138
- ];
1139
- }
1140
-
1141
- /**
1142
- * Reads the "common part" of an PKCS#7 content block (in ASN.1 format)
1143
- *
1144
- * This function reads the "common part" of the PKCS#7 content blocks
1145
- * EncryptedData and EnvelopedData, i.e. version number and symmetrically
1146
- * encrypted content block.
1147
- *
1148
- * The result of the ASN.1 validate and capture process is returned
1149
- * to allow the caller to extract further data, e.g. the list of recipients
1150
- * in case of a EnvelopedData object.
1151
- *
1152
- * @param msg the PKCS#7 object to read the data to.
1153
- * @param obj the ASN.1 representation of the content block.
1154
- * @param validator the ASN.1 structure validator object to use.
1155
- *
1156
- * @return the value map captured by validator object.
1157
- */
1158
- function _fromAsn1(msg, obj, validator) {
1159
- var capture = {};
1160
- var errors = [];
1161
- if(!asn1.validate(obj, validator, capture, errors)) {
1162
- var error = new Error('Cannot read PKCS#7 message. ' +
1163
- 'ASN.1 object is not a supported PKCS#7 message.');
1164
- error.errors = error;
1165
- throw error;
1166
- }
1167
-
1168
- // Check contentType, so far we only support (raw) Data.
1169
- var contentType = asn1.derToOid(capture.contentType);
1170
- if(contentType !== forge.pki.oids.data) {
1171
- throw new Error('Unsupported PKCS#7 message. ' +
1172
- 'Only wrapped ContentType Data supported.');
1173
- }
1174
-
1175
- if(capture.encryptedContent) {
1176
- var content = '';
1177
- if(forge.util.isArray(capture.encryptedContent)) {
1178
- for(var i = 0; i < capture.encryptedContent.length; ++i) {
1179
- if(capture.encryptedContent[i].type !== asn1.Type.OCTETSTRING) {
1180
- throw new Error('Malformed PKCS#7 message, expecting encrypted ' +
1181
- 'content constructed of only OCTET STRING objects.');
1182
- }
1183
- content += capture.encryptedContent[i].value;
1184
- }
1185
- } else {
1186
- content = capture.encryptedContent;
1187
- }
1188
- msg.encryptedContent = {
1189
- algorithm: asn1.derToOid(capture.encAlgorithm),
1190
- parameter: forge.util.createBuffer(capture.encParameter.value),
1191
- content: forge.util.createBuffer(content)
1192
- };
1193
- }
1194
-
1195
- if(capture.content) {
1196
- var content = '';
1197
- if(forge.util.isArray(capture.content)) {
1198
- for(var i = 0; i < capture.content.length; ++i) {
1199
- if(capture.content[i].type !== asn1.Type.OCTETSTRING) {
1200
- throw new Error('Malformed PKCS#7 message, expecting ' +
1201
- 'content constructed of only OCTET STRING objects.');
1202
- }
1203
- content += capture.content[i].value;
1204
- }
1205
- } else {
1206
- content = capture.content;
1207
- }
1208
- msg.content = forge.util.createBuffer(content);
1209
- }
1210
-
1211
- msg.version = capture.version.charCodeAt(0);
1212
- msg.rawCapture = capture;
1213
-
1214
- return capture;
1215
- }
1216
-
1217
- /**
1218
- * Decrypt the symmetrically encrypted content block of the PKCS#7 message.
1219
- *
1220
- * Decryption is skipped in case the PKCS#7 message object already has a
1221
- * (decrypted) content attribute. The algorithm, key and cipher parameters
1222
- * (probably the iv) are taken from the encryptedContent attribute of the
1223
- * message object.
1224
- *
1225
- * @param The PKCS#7 message object.
1226
- */
1227
- function _decryptContent(msg) {
1228
- if(msg.encryptedContent.key === undefined) {
1229
- throw new Error('Symmetric key not available.');
1230
- }
1231
-
1232
- if(msg.content === undefined) {
1233
- var ciph;
1234
-
1235
- switch(msg.encryptedContent.algorithm) {
1236
- case forge.pki.oids['aes128-CBC']:
1237
- case forge.pki.oids['aes192-CBC']:
1238
- case forge.pki.oids['aes256-CBC']:
1239
- ciph = forge.aes.createDecryptionCipher(msg.encryptedContent.key);
1240
- break;
1241
-
1242
- case forge.pki.oids['desCBC']:
1243
- case forge.pki.oids['des-EDE3-CBC']:
1244
- ciph = forge.des.createDecryptionCipher(msg.encryptedContent.key);
1245
- break;
1246
-
1247
- default:
1248
- throw new Error('Unsupported symmetric cipher, OID ' +
1249
- msg.encryptedContent.algorithm);
1250
- }
1251
- ciph.start(msg.encryptedContent.parameter);
1252
- ciph.update(msg.encryptedContent.content);
1253
-
1254
- if(!ciph.finish()) {
1255
- throw new Error('Symmetric decryption failed.');
1256
- }
1257
-
1258
- msg.content = ciph.output;
1259
- }
1260
- }