@financeable/lenders 0.5.8 → 0.7.0

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 (356) hide show
  1. package/FUNCTIONS.md +6 -4
  2. package/README.md +93 -44
  3. package/bin/mcp-server.js +348 -613
  4. package/bin/mcp-server.js.map +28 -29
  5. package/dist/commonjs/funcs/{createCommercialSubmission.d.ts → commercialSubmissionsCreate.d.ts} +2 -2
  6. package/dist/commonjs/funcs/commercialSubmissionsCreate.d.ts.map +1 -0
  7. package/dist/commonjs/funcs/{createCommercialSubmission.js → commercialSubmissionsCreate.js} +11 -6
  8. package/dist/commonjs/funcs/commercialSubmissionsCreate.js.map +1 -0
  9. package/dist/{esm/funcs/createConsumerSubmission.d.ts → commonjs/funcs/consumerSubmissionsCreate.d.ts} +2 -2
  10. package/dist/commonjs/funcs/{createDocumentsSubmission.d.ts.map → consumerSubmissionsCreate.d.ts.map} +1 -1
  11. package/dist/commonjs/funcs/{createConsumerSubmission.js → consumerSubmissionsCreate.js} +11 -6
  12. package/dist/commonjs/funcs/consumerSubmissionsCreate.js.map +1 -0
  13. package/dist/{esm/funcs/createDocumentsSubmission.d.ts → commonjs/funcs/documentsSubmissionsCreate.d.ts} +2 -2
  14. package/dist/{esm/funcs/createCommercialSubmission.d.ts.map → commonjs/funcs/documentsSubmissionsCreate.d.ts.map} +1 -1
  15. package/dist/commonjs/funcs/{createDocumentsSubmission.js → documentsSubmissionsCreate.js} +11 -6
  16. package/dist/commonjs/funcs/documentsSubmissionsCreate.js.map +1 -0
  17. package/dist/{esm/funcs/createPersonalSubmission.d.ts → commonjs/funcs/personalSubmissionsCreate.d.ts} +2 -2
  18. package/dist/{esm/funcs/createDocumentsSubmission.d.ts.map → commonjs/funcs/personalSubmissionsCreate.d.ts.map} +1 -1
  19. package/dist/commonjs/funcs/{createPersonalSubmission.js → personalSubmissionsCreate.js} +11 -6
  20. package/dist/commonjs/funcs/personalSubmissionsCreate.js.map +1 -0
  21. package/dist/commonjs/lib/config.d.ts +4 -3
  22. package/dist/commonjs/lib/config.d.ts.map +1 -1
  23. package/dist/commonjs/lib/config.js +3 -3
  24. package/dist/commonjs/lib/config.js.map +1 -1
  25. package/dist/commonjs/lib/env.d.ts +1 -0
  26. package/dist/commonjs/lib/env.d.ts.map +1 -1
  27. package/dist/commonjs/lib/env.js +1 -0
  28. package/dist/commonjs/lib/env.js.map +1 -1
  29. package/dist/commonjs/lib/security.d.ts +3 -0
  30. package/dist/commonjs/lib/security.d.ts.map +1 -1
  31. package/dist/commonjs/lib/security.js +29 -0
  32. package/dist/commonjs/lib/security.js.map +1 -1
  33. package/dist/commonjs/mcp-server/cli/start/command.d.ts.map +1 -1
  34. package/dist/commonjs/mcp-server/cli/start/command.js +8 -0
  35. package/dist/commonjs/mcp-server/cli/start/command.js.map +1 -1
  36. package/dist/commonjs/mcp-server/cli/start/impl.d.ts +1 -0
  37. package/dist/commonjs/mcp-server/cli/start/impl.d.ts.map +1 -1
  38. package/dist/commonjs/mcp-server/cli/start/impl.js +2 -0
  39. package/dist/commonjs/mcp-server/cli/start/impl.js.map +1 -1
  40. package/dist/commonjs/mcp-server/mcp-server.js +1 -1
  41. package/dist/commonjs/mcp-server/server.d.ts +1 -0
  42. package/dist/commonjs/mcp-server/server.d.ts.map +1 -1
  43. package/dist/commonjs/mcp-server/server.js +10 -9
  44. package/dist/commonjs/mcp-server/server.js.map +1 -1
  45. package/dist/commonjs/mcp-server/tools/{createCommercialSubmission.d.ts → commercialSubmissionsCreate.d.ts} +2 -2
  46. package/dist/commonjs/mcp-server/tools/commercialSubmissionsCreate.d.ts.map +1 -0
  47. package/dist/commonjs/mcp-server/tools/{createCommercialSubmission.js → commercialSubmissionsCreate.js} +6 -6
  48. package/dist/commonjs/mcp-server/tools/commercialSubmissionsCreate.js.map +1 -0
  49. package/dist/{esm/mcp-server/tools/createConsumerSubmission.d.ts → commonjs/mcp-server/tools/consumerSubmissionsCreate.d.ts} +2 -2
  50. package/dist/commonjs/mcp-server/tools/consumerSubmissionsCreate.d.ts.map +1 -0
  51. package/dist/commonjs/mcp-server/tools/{createConsumerSubmission.js → consumerSubmissionsCreate.js} +6 -6
  52. package/dist/commonjs/mcp-server/tools/{createDocumentsSubmission.js.map → consumerSubmissionsCreate.js.map} +1 -1
  53. package/dist/commonjs/mcp-server/tools/{createDocumentsSubmission.d.ts → documentsSubmissionsCreate.d.ts} +2 -2
  54. package/dist/commonjs/mcp-server/tools/documentsSubmissionsCreate.d.ts.map +1 -0
  55. package/dist/commonjs/mcp-server/tools/{createDocumentsSubmission.js → documentsSubmissionsCreate.js} +6 -6
  56. package/dist/commonjs/mcp-server/tools/{createCommercialSubmission.js.map → documentsSubmissionsCreate.js.map} +1 -1
  57. package/dist/{esm/mcp-server/tools/createPersonalSubmission.d.ts → commonjs/mcp-server/tools/personalSubmissionsCreate.d.ts} +2 -2
  58. package/dist/commonjs/mcp-server/tools/personalSubmissionsCreate.d.ts.map +1 -0
  59. package/dist/commonjs/mcp-server/tools/{createPersonalSubmission.js → personalSubmissionsCreate.js} +6 -6
  60. package/dist/commonjs/mcp-server/tools/personalSubmissionsCreate.js.map +1 -0
  61. package/dist/commonjs/models/components/forbiddenerror.d.ts +24 -7
  62. package/dist/commonjs/models/components/forbiddenerror.d.ts.map +1 -1
  63. package/dist/commonjs/models/components/forbiddenerror.js +27 -5
  64. package/dist/commonjs/models/components/forbiddenerror.js.map +1 -1
  65. package/dist/commonjs/models/components/index.d.ts +1 -0
  66. package/dist/commonjs/models/components/index.d.ts.map +1 -1
  67. package/dist/commonjs/models/components/index.js +1 -0
  68. package/dist/commonjs/models/components/index.js.map +1 -1
  69. package/dist/commonjs/models/components/lenders.d.ts +1 -0
  70. package/dist/commonjs/models/components/lenders.d.ts.map +1 -1
  71. package/dist/commonjs/models/components/lenders.js +1 -0
  72. package/dist/commonjs/models/components/lenders.js.map +1 -1
  73. package/dist/commonjs/models/components/security.d.ts +17 -0
  74. package/dist/commonjs/models/components/security.d.ts.map +1 -0
  75. package/dist/commonjs/models/components/security.js +67 -0
  76. package/dist/commonjs/models/components/security.js.map +1 -0
  77. package/dist/commonjs/models/components/unauthorizederror.d.ts +24 -7
  78. package/dist/commonjs/models/components/unauthorizederror.d.ts.map +1 -1
  79. package/dist/commonjs/models/components/unauthorizederror.js +29 -5
  80. package/dist/commonjs/models/components/unauthorizederror.js.map +1 -1
  81. package/dist/commonjs/models/errors/createcommercialsubmission.d.ts +35 -35
  82. package/dist/commonjs/models/errors/createcommercialsubmission.d.ts.map +1 -1
  83. package/dist/commonjs/models/errors/createcommercialsubmission.js +31 -31
  84. package/dist/commonjs/models/errors/createcommercialsubmission.js.map +1 -1
  85. package/dist/commonjs/models/errors/index.d.ts +0 -3
  86. package/dist/commonjs/models/errors/index.d.ts.map +1 -1
  87. package/dist/commonjs/models/errors/index.js +0 -3
  88. package/dist/commonjs/models/errors/index.js.map +1 -1
  89. package/dist/commonjs/models/operations/createconsumersubmission.d.ts +5 -5
  90. package/dist/commonjs/models/operations/createconsumersubmission.d.ts.map +1 -1
  91. package/dist/commonjs/models/operations/createconsumersubmission.js +7 -6
  92. package/dist/commonjs/models/operations/createconsumersubmission.js.map +1 -1
  93. package/dist/commonjs/models/operations/createdocumentssubmission.d.ts +5 -5
  94. package/dist/commonjs/models/operations/createdocumentssubmission.d.ts.map +1 -1
  95. package/dist/commonjs/models/operations/createdocumentssubmission.js +7 -6
  96. package/dist/commonjs/models/operations/createdocumentssubmission.js.map +1 -1
  97. package/dist/commonjs/models/operations/createpersonalsubmission.d.ts +5 -5
  98. package/dist/commonjs/models/operations/createpersonalsubmission.d.ts.map +1 -1
  99. package/dist/commonjs/models/operations/createpersonalsubmission.js +7 -6
  100. package/dist/commonjs/models/operations/createpersonalsubmission.js.map +1 -1
  101. package/dist/commonjs/sdk/commercial.d.ts +7 -0
  102. package/dist/commonjs/sdk/commercial.d.ts.map +1 -0
  103. package/dist/commonjs/sdk/commercial.js +15 -0
  104. package/dist/commonjs/sdk/commercial.js.map +1 -0
  105. package/dist/commonjs/sdk/consumer.d.ts +7 -0
  106. package/dist/commonjs/sdk/consumer.d.ts.map +1 -0
  107. package/dist/commonjs/sdk/consumer.js +15 -0
  108. package/dist/commonjs/sdk/consumer.js.map +1 -0
  109. package/dist/commonjs/sdk/documents.d.ts +7 -0
  110. package/dist/commonjs/sdk/documents.d.ts.map +1 -0
  111. package/dist/commonjs/sdk/documents.js +15 -0
  112. package/dist/commonjs/sdk/documents.js.map +1 -0
  113. package/dist/commonjs/sdk/financeablelendersdocumentssubmissions.d.ts +9 -0
  114. package/dist/commonjs/sdk/financeablelendersdocumentssubmissions.d.ts.map +1 -0
  115. package/dist/commonjs/sdk/financeablelendersdocumentssubmissions.js +19 -0
  116. package/dist/commonjs/sdk/financeablelendersdocumentssubmissions.js.map +1 -0
  117. package/dist/commonjs/sdk/financeablelenderspersonalsubmissions.d.ts +9 -0
  118. package/dist/commonjs/sdk/financeablelenderspersonalsubmissions.d.ts.map +1 -0
  119. package/dist/commonjs/sdk/financeablelenderspersonalsubmissions.js +19 -0
  120. package/dist/commonjs/sdk/financeablelenderspersonalsubmissions.js.map +1 -0
  121. package/dist/commonjs/sdk/financeablelenderssubmissions.d.ts +9 -0
  122. package/dist/commonjs/sdk/financeablelenderssubmissions.d.ts.map +1 -0
  123. package/dist/commonjs/sdk/financeablelenderssubmissions.js +19 -0
  124. package/dist/commonjs/sdk/financeablelenderssubmissions.js.map +1 -0
  125. package/dist/commonjs/sdk/personal.d.ts +7 -0
  126. package/dist/commonjs/sdk/personal.d.ts.map +1 -0
  127. package/dist/commonjs/sdk/personal.js +15 -0
  128. package/dist/commonjs/sdk/personal.js.map +1 -0
  129. package/dist/commonjs/sdk/sdk.d.ts +13 -18
  130. package/dist/commonjs/sdk/sdk.d.ts.map +1 -1
  131. package/dist/commonjs/sdk/sdk.js +12 -25
  132. package/dist/commonjs/sdk/sdk.js.map +1 -1
  133. package/dist/commonjs/sdk/submissions.d.ts +9 -0
  134. package/dist/commonjs/sdk/submissions.d.ts.map +1 -0
  135. package/dist/commonjs/sdk/submissions.js +19 -0
  136. package/dist/commonjs/sdk/submissions.js.map +1 -0
  137. package/dist/esm/funcs/{createCommercialSubmission.d.ts → commercialSubmissionsCreate.d.ts} +2 -2
  138. package/dist/esm/funcs/commercialSubmissionsCreate.d.ts.map +1 -0
  139. package/dist/esm/funcs/{createCommercialSubmission.js → commercialSubmissionsCreate.js} +10 -5
  140. package/dist/esm/funcs/commercialSubmissionsCreate.js.map +1 -0
  141. package/dist/{commonjs/funcs/createConsumerSubmission.d.ts → esm/funcs/consumerSubmissionsCreate.d.ts} +2 -2
  142. package/dist/esm/funcs/consumerSubmissionsCreate.d.ts.map +1 -0
  143. package/dist/esm/funcs/{createConsumerSubmission.js → consumerSubmissionsCreate.js} +10 -5
  144. package/dist/esm/funcs/consumerSubmissionsCreate.js.map +1 -0
  145. package/dist/{commonjs/funcs/createDocumentsSubmission.d.ts → esm/funcs/documentsSubmissionsCreate.d.ts} +2 -2
  146. package/dist/{commonjs/funcs/createCommercialSubmission.d.ts.map → esm/funcs/documentsSubmissionsCreate.d.ts.map} +1 -1
  147. package/dist/esm/funcs/{createDocumentsSubmission.js → documentsSubmissionsCreate.js} +10 -5
  148. package/dist/esm/funcs/documentsSubmissionsCreate.js.map +1 -0
  149. package/dist/{commonjs/funcs/createPersonalSubmission.d.ts → esm/funcs/personalSubmissionsCreate.d.ts} +2 -2
  150. package/dist/esm/funcs/personalSubmissionsCreate.d.ts.map +1 -0
  151. package/dist/esm/funcs/{createPersonalSubmission.js → personalSubmissionsCreate.js} +10 -5
  152. package/dist/esm/funcs/personalSubmissionsCreate.js.map +1 -0
  153. package/dist/esm/lib/config.d.ts +4 -3
  154. package/dist/esm/lib/config.d.ts.map +1 -1
  155. package/dist/esm/lib/config.js +3 -3
  156. package/dist/esm/lib/config.js.map +1 -1
  157. package/dist/esm/lib/env.d.ts +1 -0
  158. package/dist/esm/lib/env.d.ts.map +1 -1
  159. package/dist/esm/lib/env.js +1 -0
  160. package/dist/esm/lib/env.js.map +1 -1
  161. package/dist/esm/lib/security.d.ts +3 -0
  162. package/dist/esm/lib/security.d.ts.map +1 -1
  163. package/dist/esm/lib/security.js +27 -0
  164. package/dist/esm/lib/security.js.map +1 -1
  165. package/dist/esm/mcp-server/cli/start/command.d.ts.map +1 -1
  166. package/dist/esm/mcp-server/cli/start/command.js +8 -0
  167. package/dist/esm/mcp-server/cli/start/command.js.map +1 -1
  168. package/dist/esm/mcp-server/cli/start/impl.d.ts +1 -0
  169. package/dist/esm/mcp-server/cli/start/impl.d.ts.map +1 -1
  170. package/dist/esm/mcp-server/cli/start/impl.js +2 -0
  171. package/dist/esm/mcp-server/cli/start/impl.js.map +1 -1
  172. package/dist/esm/mcp-server/mcp-server.js +1 -1
  173. package/dist/esm/mcp-server/server.d.ts +1 -0
  174. package/dist/esm/mcp-server/server.d.ts.map +1 -1
  175. package/dist/esm/mcp-server/server.js +10 -9
  176. package/dist/esm/mcp-server/server.js.map +1 -1
  177. package/dist/esm/mcp-server/tools/{createCommercialSubmission.d.ts → commercialSubmissionsCreate.d.ts} +2 -2
  178. package/dist/esm/mcp-server/tools/commercialSubmissionsCreate.d.ts.map +1 -0
  179. package/dist/esm/mcp-server/tools/{createCommercialSubmission.js → commercialSubmissionsCreate.js} +5 -5
  180. package/dist/esm/mcp-server/tools/commercialSubmissionsCreate.js.map +1 -0
  181. package/dist/{commonjs/mcp-server/tools/createConsumerSubmission.d.ts → esm/mcp-server/tools/consumerSubmissionsCreate.d.ts} +2 -2
  182. package/dist/esm/mcp-server/tools/consumerSubmissionsCreate.d.ts.map +1 -0
  183. package/dist/esm/mcp-server/tools/{createConsumerSubmission.js → consumerSubmissionsCreate.js} +5 -5
  184. package/dist/esm/mcp-server/tools/{createDocumentsSubmission.js.map → consumerSubmissionsCreate.js.map} +1 -1
  185. package/dist/esm/mcp-server/tools/{createDocumentsSubmission.d.ts → documentsSubmissionsCreate.d.ts} +2 -2
  186. package/dist/esm/mcp-server/tools/documentsSubmissionsCreate.d.ts.map +1 -0
  187. package/dist/esm/mcp-server/tools/{createDocumentsSubmission.js → documentsSubmissionsCreate.js} +5 -5
  188. package/dist/esm/mcp-server/tools/{createCommercialSubmission.js.map → documentsSubmissionsCreate.js.map} +1 -1
  189. package/dist/{commonjs/mcp-server/tools/createPersonalSubmission.d.ts → esm/mcp-server/tools/personalSubmissionsCreate.d.ts} +2 -2
  190. package/dist/esm/mcp-server/tools/personalSubmissionsCreate.d.ts.map +1 -0
  191. package/dist/esm/mcp-server/tools/{createPersonalSubmission.js → personalSubmissionsCreate.js} +5 -5
  192. package/dist/esm/mcp-server/tools/personalSubmissionsCreate.js.map +1 -0
  193. package/dist/esm/models/components/forbiddenerror.d.ts +24 -7
  194. package/dist/esm/models/components/forbiddenerror.d.ts.map +1 -1
  195. package/dist/esm/models/components/forbiddenerror.js +24 -4
  196. package/dist/esm/models/components/forbiddenerror.js.map +1 -1
  197. package/dist/esm/models/components/index.d.ts +1 -0
  198. package/dist/esm/models/components/index.d.ts.map +1 -1
  199. package/dist/esm/models/components/index.js +1 -0
  200. package/dist/esm/models/components/index.js.map +1 -1
  201. package/dist/esm/models/components/lenders.d.ts +1 -0
  202. package/dist/esm/models/components/lenders.d.ts.map +1 -1
  203. package/dist/esm/models/components/lenders.js +1 -0
  204. package/dist/esm/models/components/lenders.js.map +1 -1
  205. package/dist/esm/models/components/security.d.ts +17 -0
  206. package/dist/esm/models/components/security.d.ts.map +1 -0
  207. package/dist/esm/models/components/security.js +29 -0
  208. package/dist/esm/models/components/security.js.map +1 -0
  209. package/dist/esm/models/components/unauthorizederror.d.ts +24 -7
  210. package/dist/esm/models/components/unauthorizederror.d.ts.map +1 -1
  211. package/dist/esm/models/components/unauthorizederror.js +26 -4
  212. package/dist/esm/models/components/unauthorizederror.js.map +1 -1
  213. package/dist/esm/models/errors/createcommercialsubmission.d.ts +35 -35
  214. package/dist/esm/models/errors/createcommercialsubmission.d.ts.map +1 -1
  215. package/dist/esm/models/errors/createcommercialsubmission.js +25 -25
  216. package/dist/esm/models/errors/createcommercialsubmission.js.map +1 -1
  217. package/dist/esm/models/errors/index.d.ts +0 -3
  218. package/dist/esm/models/errors/index.d.ts.map +1 -1
  219. package/dist/esm/models/errors/index.js +0 -3
  220. package/dist/esm/models/errors/index.js.map +1 -1
  221. package/dist/esm/models/operations/createconsumersubmission.d.ts +5 -5
  222. package/dist/esm/models/operations/createconsumersubmission.d.ts.map +1 -1
  223. package/dist/esm/models/operations/createconsumersubmission.js +6 -5
  224. package/dist/esm/models/operations/createconsumersubmission.js.map +1 -1
  225. package/dist/esm/models/operations/createdocumentssubmission.d.ts +5 -5
  226. package/dist/esm/models/operations/createdocumentssubmission.d.ts.map +1 -1
  227. package/dist/esm/models/operations/createdocumentssubmission.js +6 -5
  228. package/dist/esm/models/operations/createdocumentssubmission.js.map +1 -1
  229. package/dist/esm/models/operations/createpersonalsubmission.d.ts +5 -5
  230. package/dist/esm/models/operations/createpersonalsubmission.d.ts.map +1 -1
  231. package/dist/esm/models/operations/createpersonalsubmission.js +6 -5
  232. package/dist/esm/models/operations/createpersonalsubmission.js.map +1 -1
  233. package/dist/esm/sdk/commercial.d.ts +7 -0
  234. package/dist/esm/sdk/commercial.d.ts.map +1 -0
  235. package/dist/esm/sdk/commercial.js +11 -0
  236. package/dist/esm/sdk/commercial.js.map +1 -0
  237. package/dist/esm/sdk/consumer.d.ts +7 -0
  238. package/dist/esm/sdk/consumer.d.ts.map +1 -0
  239. package/dist/esm/sdk/consumer.js +11 -0
  240. package/dist/esm/sdk/consumer.js.map +1 -0
  241. package/dist/esm/sdk/documents.d.ts +7 -0
  242. package/dist/esm/sdk/documents.d.ts.map +1 -0
  243. package/dist/esm/sdk/documents.js +11 -0
  244. package/dist/esm/sdk/documents.js.map +1 -0
  245. package/dist/esm/sdk/financeablelendersdocumentssubmissions.d.ts +9 -0
  246. package/dist/esm/sdk/financeablelendersdocumentssubmissions.d.ts.map +1 -0
  247. package/dist/esm/sdk/financeablelendersdocumentssubmissions.js +15 -0
  248. package/dist/esm/sdk/financeablelendersdocumentssubmissions.js.map +1 -0
  249. package/dist/esm/sdk/financeablelenderspersonalsubmissions.d.ts +9 -0
  250. package/dist/esm/sdk/financeablelenderspersonalsubmissions.d.ts.map +1 -0
  251. package/dist/esm/sdk/financeablelenderspersonalsubmissions.js +15 -0
  252. package/dist/esm/sdk/financeablelenderspersonalsubmissions.js.map +1 -0
  253. package/dist/esm/sdk/financeablelenderssubmissions.d.ts +9 -0
  254. package/dist/esm/sdk/financeablelenderssubmissions.d.ts.map +1 -0
  255. package/dist/esm/sdk/financeablelenderssubmissions.js +15 -0
  256. package/dist/esm/sdk/financeablelenderssubmissions.js.map +1 -0
  257. package/dist/esm/sdk/personal.d.ts +7 -0
  258. package/dist/esm/sdk/personal.d.ts.map +1 -0
  259. package/dist/esm/sdk/personal.js +11 -0
  260. package/dist/esm/sdk/personal.js.map +1 -0
  261. package/dist/esm/sdk/sdk.d.ts +13 -18
  262. package/dist/esm/sdk/sdk.d.ts.map +1 -1
  263. package/dist/esm/sdk/sdk.js +12 -25
  264. package/dist/esm/sdk/sdk.js.map +1 -1
  265. package/dist/esm/sdk/submissions.d.ts +9 -0
  266. package/dist/esm/sdk/submissions.d.ts.map +1 -0
  267. package/dist/esm/sdk/submissions.js +15 -0
  268. package/dist/esm/sdk/submissions.js.map +1 -0
  269. package/examples/{createCommercialSubmission.example.ts → commercialSubmissionsCreate.example.ts} +5 -3
  270. package/jsr.json +1 -1
  271. package/package.json +1 -1
  272. package/src/funcs/{createCommercialSubmission.ts → commercialSubmissionsCreate.ts} +29 -35
  273. package/src/funcs/{createConsumerSubmission.ts → consumerSubmissionsCreate.ts} +29 -35
  274. package/src/funcs/{createDocumentsSubmission.ts → documentsSubmissionsCreate.ts} +29 -35
  275. package/src/funcs/{createPersonalSubmission.ts → personalSubmissionsCreate.ts} +29 -35
  276. package/src/lib/config.ts +5 -3
  277. package/src/lib/env.ts +4 -0
  278. package/src/lib/security.ts +39 -0
  279. package/src/mcp-server/cli/start/command.ts +8 -0
  280. package/src/mcp-server/cli/start/impl.ts +5 -0
  281. package/src/mcp-server/mcp-server.ts +1 -1
  282. package/src/mcp-server/server.ts +11 -9
  283. package/src/mcp-server/tools/{createCommercialSubmission.ts → commercialSubmissionsCreate.ts} +4 -4
  284. package/src/mcp-server/tools/{createConsumerSubmission.ts → consumerSubmissionsCreate.ts} +4 -4
  285. package/src/mcp-server/tools/{createDocumentsSubmission.ts → documentsSubmissionsCreate.ts} +4 -4
  286. package/src/mcp-server/tools/{createPersonalSubmission.ts → personalSubmissionsCreate.ts} +4 -4
  287. package/src/models/components/forbiddenerror.ts +63 -15
  288. package/src/models/components/index.ts +1 -0
  289. package/src/models/components/lenders.ts +1 -0
  290. package/src/models/components/security.ts +56 -0
  291. package/src/models/components/unauthorizederror.ts +54 -15
  292. package/src/models/errors/createcommercialsubmission.ts +145 -163
  293. package/src/models/errors/index.ts +0 -3
  294. package/src/models/operations/createconsumersubmission.ts +12 -13
  295. package/src/models/operations/createdocumentssubmission.ts +12 -13
  296. package/src/models/operations/createpersonalsubmission.ts +12 -13
  297. package/src/sdk/commercial.ts +13 -0
  298. package/src/sdk/consumer.ts +15 -0
  299. package/src/sdk/documents.ts +15 -0
  300. package/src/sdk/financeablelendersdocumentssubmissions.ts +24 -0
  301. package/src/sdk/financeablelenderspersonalsubmissions.ts +24 -0
  302. package/src/sdk/financeablelenderssubmissions.ts +24 -0
  303. package/src/sdk/personal.ts +15 -0
  304. package/src/sdk/sdk.ts +17 -55
  305. package/src/sdk/submissions.ts +24 -0
  306. package/dist/commonjs/funcs/createCommercialSubmission.js.map +0 -1
  307. package/dist/commonjs/funcs/createConsumerSubmission.d.ts.map +0 -1
  308. package/dist/commonjs/funcs/createConsumerSubmission.js.map +0 -1
  309. package/dist/commonjs/funcs/createDocumentsSubmission.js.map +0 -1
  310. package/dist/commonjs/funcs/createPersonalSubmission.d.ts.map +0 -1
  311. package/dist/commonjs/funcs/createPersonalSubmission.js.map +0 -1
  312. package/dist/commonjs/mcp-server/tools/createCommercialSubmission.d.ts.map +0 -1
  313. package/dist/commonjs/mcp-server/tools/createConsumerSubmission.d.ts.map +0 -1
  314. package/dist/commonjs/mcp-server/tools/createConsumerSubmission.js.map +0 -1
  315. package/dist/commonjs/mcp-server/tools/createDocumentsSubmission.d.ts.map +0 -1
  316. package/dist/commonjs/mcp-server/tools/createPersonalSubmission.d.ts.map +0 -1
  317. package/dist/commonjs/mcp-server/tools/createPersonalSubmission.js.map +0 -1
  318. package/dist/commonjs/models/errors/createconsumersubmission.d.ts +0 -214
  319. package/dist/commonjs/models/errors/createconsumersubmission.d.ts.map +0 -1
  320. package/dist/commonjs/models/errors/createconsumersubmission.js +0 -233
  321. package/dist/commonjs/models/errors/createconsumersubmission.js.map +0 -1
  322. package/dist/commonjs/models/errors/createdocumentssubmission.d.ts +0 -214
  323. package/dist/commonjs/models/errors/createdocumentssubmission.d.ts.map +0 -1
  324. package/dist/commonjs/models/errors/createdocumentssubmission.js +0 -233
  325. package/dist/commonjs/models/errors/createdocumentssubmission.js.map +0 -1
  326. package/dist/commonjs/models/errors/createpersonalsubmission.d.ts +0 -214
  327. package/dist/commonjs/models/errors/createpersonalsubmission.d.ts.map +0 -1
  328. package/dist/commonjs/models/errors/createpersonalsubmission.js +0 -233
  329. package/dist/commonjs/models/errors/createpersonalsubmission.js.map +0 -1
  330. package/dist/esm/funcs/createCommercialSubmission.js.map +0 -1
  331. package/dist/esm/funcs/createConsumerSubmission.d.ts.map +0 -1
  332. package/dist/esm/funcs/createConsumerSubmission.js.map +0 -1
  333. package/dist/esm/funcs/createDocumentsSubmission.js.map +0 -1
  334. package/dist/esm/funcs/createPersonalSubmission.d.ts.map +0 -1
  335. package/dist/esm/funcs/createPersonalSubmission.js.map +0 -1
  336. package/dist/esm/mcp-server/tools/createCommercialSubmission.d.ts.map +0 -1
  337. package/dist/esm/mcp-server/tools/createConsumerSubmission.d.ts.map +0 -1
  338. package/dist/esm/mcp-server/tools/createConsumerSubmission.js.map +0 -1
  339. package/dist/esm/mcp-server/tools/createDocumentsSubmission.d.ts.map +0 -1
  340. package/dist/esm/mcp-server/tools/createPersonalSubmission.d.ts.map +0 -1
  341. package/dist/esm/mcp-server/tools/createPersonalSubmission.js.map +0 -1
  342. package/dist/esm/models/errors/createconsumersubmission.d.ts +0 -214
  343. package/dist/esm/models/errors/createconsumersubmission.d.ts.map +0 -1
  344. package/dist/esm/models/errors/createconsumersubmission.js +0 -192
  345. package/dist/esm/models/errors/createconsumersubmission.js.map +0 -1
  346. package/dist/esm/models/errors/createdocumentssubmission.d.ts +0 -214
  347. package/dist/esm/models/errors/createdocumentssubmission.d.ts.map +0 -1
  348. package/dist/esm/models/errors/createdocumentssubmission.js +0 -192
  349. package/dist/esm/models/errors/createdocumentssubmission.js.map +0 -1
  350. package/dist/esm/models/errors/createpersonalsubmission.d.ts +0 -214
  351. package/dist/esm/models/errors/createpersonalsubmission.d.ts.map +0 -1
  352. package/dist/esm/models/errors/createpersonalsubmission.js +0 -192
  353. package/dist/esm/models/errors/createpersonalsubmission.js.map +0 -1
  354. package/src/models/errors/createconsumersubmission.ts +0 -445
  355. package/src/models/errors/createdocumentssubmission.ts +0 -445
  356. package/src/models/errors/createpersonalsubmission.ts +0 -445
package/FUNCTIONS.md CHANGED
@@ -20,14 +20,16 @@ specific category of applications.
20
20
 
21
21
  ```typescript
22
22
  import { FinanceableLendersCore } from "@financeable/lenders/core.js";
23
- import { createCommercialSubmission } from "@financeable/lenders/funcs/createCommercialSubmission.js";
23
+ import { commercialSubmissionsCreate } from "@financeable/lenders/funcs/commercialSubmissionsCreate.js";
24
24
 
25
25
  // Use `FinanceableLendersCore` for best tree-shaking performance.
26
26
  // You can create one instance of it to use across an application.
27
- const financeableLenders = new FinanceableLendersCore();
27
+ const financeableLenders = new FinanceableLendersCore({
28
+ apiKeyAuth: process.env["FINACEABLELENDERS_API_KEY_AUTH"] ?? "",
29
+ });
28
30
 
29
31
  async function run() {
30
- const res = await createCommercialSubmission(financeableLenders, {
32
+ const res = await commercialSubmissionsCreate(financeableLenders, {
31
33
  lender: "Moneyplace",
32
34
  requestBody: {
33
35
  id: "<id>",
@@ -38,7 +40,7 @@ async function run() {
38
40
  const { value: result } = res;
39
41
  console.log(result);
40
42
  } else {
41
- console.log("createCommercialSubmission failed:", res.error);
43
+ console.log("commercialSubmissionsCreate failed:", res.error);
42
44
  }
43
45
  }
44
46
 
package/README.md CHANGED
@@ -17,7 +17,17 @@ Developer-friendly & type-safe Typescript SDK specifically catered to leverage _
17
17
  <!-- Start Summary [summary] -->
18
18
  ## Summary
19
19
 
20
+ Financeable Lenders API: ## Authentication
20
21
 
22
+ All requests must include an API key in the `X-API-Key` request header.
23
+
24
+ Missing, malformed, or revoked keys return a JSON:API error document
25
+ (`application/vnd.api+json`) with HTTP `401 Unauthorized`. The error
26
+ object's `source.header` field is set to `X-API-Key` so clients can
27
+ identify which credential failed. Insufficient permissions for a valid
28
+ key return `403 Forbidden` with the same source convention.
29
+
30
+ Keys must never be sent in the query string or request body.
21
31
  <!-- End Summary [summary] -->
22
32
 
23
33
  <!-- Start Table of Contents [toc] -->
@@ -27,6 +37,7 @@ Developer-friendly & type-safe Typescript SDK specifically catered to leverage _
27
37
  * [SDK Installation](#sdk-installation)
28
38
  * [Requirements](#requirements)
29
39
  * [SDK Example Usage](#sdk-example-usage)
40
+ * [Authentication](#authentication)
30
41
  * [Available Resources and Operations](#available-resources-and-operations)
31
42
  * [Standalone functions](#standalone-functions)
32
43
  * [Retries](#retries)
@@ -93,7 +104,8 @@ Add the following server definition to your `claude_desktop_config.json` file:
93
104
  "args": [
94
105
  "-y", "--package", "@financeable/lenders",
95
106
  "--",
96
- "mcp", "start"
107
+ "mcp", "start",
108
+ "--api-key-auth", "..."
97
109
  ]
98
110
  }
99
111
  }
@@ -115,7 +127,8 @@ Create a `.cursor/mcp.json` file in your project root with the following content
115
127
  "args": [
116
128
  "-y", "--package", "@financeable/lenders",
117
129
  "--",
118
- "mcp", "start"
130
+ "mcp", "start",
131
+ "--api-key-auth", "..."
119
132
  ]
120
133
  }
121
134
  }
@@ -169,10 +182,12 @@ For supported JavaScript runtimes, please consult [RUNTIMES.md](RUNTIMES.md).
169
182
  ```typescript
170
183
  import { FinanceableLenders } from "@financeable/lenders";
171
184
 
172
- const financeableLenders = new FinanceableLenders();
185
+ const financeableLenders = new FinanceableLenders({
186
+ apiKeyAuth: process.env["FINACEABLELENDERS_API_KEY_AUTH"] ?? "",
187
+ });
173
188
 
174
189
  async function run() {
175
- const result = await financeableLenders.createCommercialSubmission({
190
+ const result = await financeableLenders.commercial.submissions.create({
176
191
  lender: "Moneyplace",
177
192
  requestBody: {
178
193
  id: "<id>",
@@ -188,18 +203,63 @@ run();
188
203
  ```
189
204
  <!-- End SDK Example Usage [usage] -->
190
205
 
206
+ <!-- Start Authentication [security] -->
207
+ ## Authentication
208
+
209
+ ### Per-Client Security Schemes
210
+
211
+ This SDK supports the following security scheme globally:
212
+
213
+ | Name | Type | Scheme | Environment Variable |
214
+ | ------------ | ------ | ------- | -------------------------------- |
215
+ | `apiKeyAuth` | apiKey | API key | `FINACEABLELENDERS_API_KEY_AUTH` |
216
+
217
+ To authenticate with the API the `apiKeyAuth` parameter must be set when initializing the SDK client instance. For example:
218
+ ```typescript
219
+ import { FinanceableLenders } from "@financeable/lenders";
220
+
221
+ const financeableLenders = new FinanceableLenders({
222
+ apiKeyAuth: process.env["FINACEABLELENDERS_API_KEY_AUTH"] ?? "",
223
+ });
224
+
225
+ async function run() {
226
+ const result = await financeableLenders.commercial.submissions.create({
227
+ lender: "Moneyplace",
228
+ requestBody: {
229
+ id: "<id>",
230
+ type: "commercial",
231
+ },
232
+ });
233
+
234
+ console.log(result);
235
+ }
236
+
237
+ run();
238
+
239
+ ```
240
+ <!-- End Authentication [security] -->
241
+
191
242
  <!-- Start Available Resources and Operations [operations] -->
192
243
  ## Available Resources and Operations
193
244
 
194
245
  <details open>
195
246
  <summary>Available methods</summary>
196
247
 
197
- ### [FinanceableLenders SDK](docs/sdks/financeablelenders/README.md)
248
+ ### [Commercial.Submissions](docs/sdks/submissions/README.md)
249
+
250
+ * [create](docs/sdks/submissions/README.md#create) - Create commercial submission route
198
251
 
199
- * [createCommercialSubmission](docs/sdks/financeablelenders/README.md#createcommercialsubmission) - Create commercial submission route
200
- * [createConsumerSubmission](docs/sdks/financeablelenders/README.md#createconsumersubmission) - Create consumer submission route
201
- * [createDocumentsSubmission](docs/sdks/financeablelenders/README.md#createdocumentssubmission) - Create documents submission route
202
- * [createPersonalSubmission](docs/sdks/financeablelenders/README.md#createpersonalsubmission) - Create personal submission route
252
+ ### [Consumer.Submissions](docs/sdks/financeablelenderssubmissions/README.md)
253
+
254
+ * [create](docs/sdks/financeablelenderssubmissions/README.md#create) - Create consumer submission route
255
+
256
+ ### [Documents.Submissions](docs/sdks/financeablelendersdocumentssubmissions/README.md)
257
+
258
+ * [create](docs/sdks/financeablelendersdocumentssubmissions/README.md#create) - Create documents submission route
259
+
260
+ ### [Personal.Submissions](docs/sdks/financeablelenderspersonalsubmissions/README.md)
261
+
262
+ * [create](docs/sdks/financeablelenderspersonalsubmissions/README.md#create) - Create personal submission route
203
263
 
204
264
  </details>
205
265
  <!-- End Available Resources and Operations [operations] -->
@@ -219,10 +279,10 @@ To read more about standalone functions, check [FUNCTIONS.md](./FUNCTIONS.md).
219
279
 
220
280
  <summary>Available standalone functions</summary>
221
281
 
222
- - [`createCommercialSubmission`](docs/sdks/financeablelenders/README.md#createcommercialsubmission) - Create commercial submission route
223
- - [`createConsumerSubmission`](docs/sdks/financeablelenders/README.md#createconsumersubmission) - Create consumer submission route
224
- - [`createDocumentsSubmission`](docs/sdks/financeablelenders/README.md#createdocumentssubmission) - Create documents submission route
225
- - [`createPersonalSubmission`](docs/sdks/financeablelenders/README.md#createpersonalsubmission) - Create personal submission route
282
+ - [`commercialSubmissionsCreate`](docs/sdks/submissions/README.md#create) - Create commercial submission route
283
+ - [`consumerSubmissionsCreate`](docs/sdks/financeablelenderssubmissions/README.md#create) - Create consumer submission route
284
+ - [`documentsSubmissionsCreate`](docs/sdks/financeablelendersdocumentssubmissions/README.md#create) - Create documents submission route
285
+ - [`personalSubmissionsCreate`](docs/sdks/financeablelenderspersonalsubmissions/README.md#create) - Create personal submission route
226
286
 
227
287
  </details>
228
288
  <!-- End Standalone functions [standalone-funcs] -->
@@ -236,10 +296,12 @@ To change the default retry strategy for a single API call, simply provide a ret
236
296
  ```typescript
237
297
  import { FinanceableLenders } from "@financeable/lenders";
238
298
 
239
- const financeableLenders = new FinanceableLenders();
299
+ const financeableLenders = new FinanceableLenders({
300
+ apiKeyAuth: process.env["FINACEABLELENDERS_API_KEY_AUTH"] ?? "",
301
+ });
240
302
 
241
303
  async function run() {
242
- const result = await financeableLenders.createCommercialSubmission({
304
+ const result = await financeableLenders.commercial.submissions.create({
243
305
  lender: "Moneyplace",
244
306
  requestBody: {
245
307
  id: "<id>",
@@ -280,10 +342,11 @@ const financeableLenders = new FinanceableLenders({
280
342
  },
281
343
  retryConnectionErrors: false,
282
344
  },
345
+ apiKeyAuth: process.env["FINACEABLELENDERS_API_KEY_AUTH"] ?? "",
283
346
  });
284
347
 
285
348
  async function run() {
286
- const result = await financeableLenders.createCommercialSubmission({
349
+ const result = await financeableLenders.commercial.submissions.create({
287
350
  lender: "Moneyplace",
288
351
  requestBody: {
289
352
  id: "<id>",
@@ -318,11 +381,13 @@ run();
318
381
  import { FinanceableLenders } from "@financeable/lenders";
319
382
  import * as errors from "@financeable/lenders/models/errors";
320
383
 
321
- const financeableLenders = new FinanceableLenders();
384
+ const financeableLenders = new FinanceableLenders({
385
+ apiKeyAuth: process.env["FINACEABLELENDERS_API_KEY_AUTH"] ?? "",
386
+ });
322
387
 
323
388
  async function run() {
324
389
  try {
325
- const result = await financeableLenders.createCommercialSubmission({
390
+ const result = await financeableLenders.commercial.submissions.create({
326
391
  lender: "Moneyplace",
327
392
  requestBody: {
328
393
  id: "<id>",
@@ -340,7 +405,7 @@ async function run() {
340
405
  console.log(error.headers);
341
406
 
342
407
  // Depending on the method different errors may be thrown
343
- if (error instanceof errors.CreateCommercialSubmissionResponseBody) {
408
+ if (error instanceof errors.ResponseBody) {
344
409
  console.log(error.data$.lender); // components.Lenders
345
410
  console.log(error.data$.errors); // ApiError[][]
346
411
  }
@@ -353,10 +418,15 @@ run();
353
418
  ```
354
419
 
355
420
  ### Error Classes
356
- **Primary error:**
421
+ **Primary errors:**
357
422
  * [`FinanceableLendersError`](./src/models/errors/financeablelenderserror.ts): The base class for HTTP error responses.
423
+ * [`ResponseBody`](./src/models/errors/responsebody.ts): The server could not understand the request due to invalid syntax. Status code `400`.
424
+ * [`ResponseResponseBody`](./src/models/errors/responseresponsebody.ts): Access is unauthorized. Status code `401`.
425
+ * [`Response403ResponseBody`](./src/models/errors/response403responsebody.ts): Access is forbidden. Status code `403`.
426
+ * [`Response404ResponseBody`](./src/models/errors/response404responsebody.ts): The server cannot find the requested resource. Status code `404`.
427
+ * [`Response500ResponseBody`](./src/models/errors/response500responsebody.ts): Server error. Status code `500`.
358
428
 
359
- <details><summary>Less common errors (26)</summary>
429
+ <details><summary>Less common errors (6)</summary>
360
430
 
361
431
  <br />
362
432
 
@@ -369,31 +439,9 @@ run();
369
439
 
370
440
 
371
441
  **Inherit from [`FinanceableLendersError`](./src/models/errors/financeablelenderserror.ts)**:
372
- * [`CreateCommercialSubmissionResponseBody`](./src/models/errors/createcommercialsubmissionresponsebody.ts): The server could not understand the request due to invalid syntax. Status code `400`. Applicable to 1 of 4 methods.*
373
- * [`CreateConsumerSubmissionResponseBody`](./src/models/errors/createconsumersubmissionresponsebody.ts): The server could not understand the request due to invalid syntax. Status code `400`. Applicable to 1 of 4 methods.*
374
- * [`CreateDocumentsSubmissionResponseBody`](./src/models/errors/createdocumentssubmissionresponsebody.ts): The server could not understand the request due to invalid syntax. Status code `400`. Applicable to 1 of 4 methods.*
375
- * [`CreatePersonalSubmissionResponseBody`](./src/models/errors/createpersonalsubmissionresponsebody.ts): The server could not understand the request due to invalid syntax. Status code `400`. Applicable to 1 of 4 methods.*
376
- * [`CreateCommercialSubmissionResponseResponseBody`](./src/models/errors/createcommercialsubmissionresponseresponsebody.ts): Access is unauthorized. Status code `401`. Applicable to 1 of 4 methods.*
377
- * [`CreateConsumerSubmissionResponseResponseBody`](./src/models/errors/createconsumersubmissionresponseresponsebody.ts): Access is unauthorized. Status code `401`. Applicable to 1 of 4 methods.*
378
- * [`CreateDocumentsSubmissionResponseResponseBody`](./src/models/errors/createdocumentssubmissionresponseresponsebody.ts): Access is unauthorized. Status code `401`. Applicable to 1 of 4 methods.*
379
- * [`CreatePersonalSubmissionResponseResponseBody`](./src/models/errors/createpersonalsubmissionresponseresponsebody.ts): Access is unauthorized. Status code `401`. Applicable to 1 of 4 methods.*
380
- * [`CreateCommercialSubmissionResponse403ResponseBody`](./src/models/errors/createcommercialsubmissionresponse403responsebody.ts): Access is forbidden. Status code `403`. Applicable to 1 of 4 methods.*
381
- * [`CreateConsumerSubmissionResponse403ResponseBody`](./src/models/errors/createconsumersubmissionresponse403responsebody.ts): Access is forbidden. Status code `403`. Applicable to 1 of 4 methods.*
382
- * [`CreateDocumentsSubmissionResponse403ResponseBody`](./src/models/errors/createdocumentssubmissionresponse403responsebody.ts): Access is forbidden. Status code `403`. Applicable to 1 of 4 methods.*
383
- * [`CreatePersonalSubmissionResponse403ResponseBody`](./src/models/errors/createpersonalsubmissionresponse403responsebody.ts): Access is forbidden. Status code `403`. Applicable to 1 of 4 methods.*
384
- * [`CreateCommercialSubmissionResponse404ResponseBody`](./src/models/errors/createcommercialsubmissionresponse404responsebody.ts): The server cannot find the requested resource. Status code `404`. Applicable to 1 of 4 methods.*
385
- * [`CreateConsumerSubmissionResponse404ResponseBody`](./src/models/errors/createconsumersubmissionresponse404responsebody.ts): The server cannot find the requested resource. Status code `404`. Applicable to 1 of 4 methods.*
386
- * [`CreateDocumentsSubmissionResponse404ResponseBody`](./src/models/errors/createdocumentssubmissionresponse404responsebody.ts): The server cannot find the requested resource. Status code `404`. Applicable to 1 of 4 methods.*
387
- * [`CreatePersonalSubmissionResponse404ResponseBody`](./src/models/errors/createpersonalsubmissionresponse404responsebody.ts): The server cannot find the requested resource. Status code `404`. Applicable to 1 of 4 methods.*
388
- * [`CreateCommercialSubmissionResponse500ResponseBody`](./src/models/errors/createcommercialsubmissionresponse500responsebody.ts): Server error. Status code `500`. Applicable to 1 of 4 methods.*
389
- * [`CreateConsumerSubmissionResponse500ResponseBody`](./src/models/errors/createconsumersubmissionresponse500responsebody.ts): Server error. Status code `500`. Applicable to 1 of 4 methods.*
390
- * [`CreateDocumentsSubmissionResponse500ResponseBody`](./src/models/errors/createdocumentssubmissionresponse500responsebody.ts): Server error. Status code `500`. Applicable to 1 of 4 methods.*
391
- * [`CreatePersonalSubmissionResponse500ResponseBody`](./src/models/errors/createpersonalsubmissionresponse500responsebody.ts): Server error. Status code `500`. Applicable to 1 of 4 methods.*
392
442
  * [`ResponseValidationError`](./src/models/errors/responsevalidationerror.ts): Type mismatch between the data returned from the server and the structure expected by the SDK. See `error.rawValue` for the raw value and `error.pretty()` for a nicely formatted multi-line string.
393
443
 
394
444
  </details>
395
-
396
- \* Check [the method documentation](#available-resources-and-operations) to see if the error is applicable.
397
445
  <!-- End Error Handling [errors] -->
398
446
 
399
447
  <!-- Start Server Selection [server] -->
@@ -407,10 +455,11 @@ import { FinanceableLenders } from "@financeable/lenders";
407
455
 
408
456
  const financeableLenders = new FinanceableLenders({
409
457
  serverURL: "https://aws.lenders.api.financeable.com.au/api/v1",
458
+ apiKeyAuth: process.env["FINACEABLELENDERS_API_KEY_AUTH"] ?? "",
410
459
  });
411
460
 
412
461
  async function run() {
413
- const result = await financeableLenders.createCommercialSubmission({
462
+ const result = await financeableLenders.commercial.submissions.create({
414
463
  lender: "Moneyplace",
415
464
  requestBody: {
416
465
  id: "<id>",