@dizzlkheinz/ynab-mcpb 0.13.1 → 0.15.1

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 (207) hide show
  1. package/.code/agents/01a13ef4-3f23-4f52-b33b-3585b73cfa60/error.txt +3 -0
  2. package/.code/agents/084fd32f-e298-4728-9103-a78d7dc39613/error.txt +3 -0
  3. package/.code/agents/0fed51e1-a943-4b97-a2a8-a6f0f27c844d/status.txt +1 -0
  4. package/.code/agents/1059b6bd-5ccd-4d83-a12c-7c9d89137399/error.txt +5 -0
  5. package/.code/agents/110/exec-call_F9BDNG7JfxKkq7Vc8ESAvdft.txt +1569 -0
  6. package/.code/agents/11ebcef3-b13f-4e44-ad80-d94a866804b7/error.txt +3 -0
  7. package/.code/agents/1398/exec-call_CjItcWMU1G6JoPshX62QvpaR.txt +2832 -0
  8. package/.code/agents/1398/exec-call_SUVq2ivmONQ5LMCmd7ngmOqr.txt +2709 -0
  9. package/.code/agents/1398/exec-call_SdNY4NOffdcC5pRYjVXHjPCK.txt +2832 -0
  10. package/.code/agents/1398/exec-call_qblJo9et1gsFFB63TtLOiji2.txt +2832 -0
  11. package/.code/agents/1398/exec-call_zaRrzlGz7GJcNzVfkAmML7Zg.txt +2709 -0
  12. package/.code/agents/171834fd-5905-42fc-bbcc-2c755145b0fc/status.txt +1 -0
  13. package/.code/agents/1724/exec-call_HvHQe0w5CCG3T7Q3ULT6MO3g.txt +5217 -0
  14. package/.code/agents/1724/exec-call_QwUNESVzfxxk78K1frh1Vahb.txt +2594 -0
  15. package/.code/agents/1724/exec-call_aJ1Xwz71XmIpD4SBxSHERzLe.txt +2594 -0
  16. package/.code/agents/1d7d7ab7-7473-4b69-8b97-6e914f56056a/result.txt +231 -0
  17. package/.code/agents/210/exec-call_0tQCsKNJ1WTuIchb8wlcFJpW.txt +2590 -0
  18. package/.code/agents/210/exec-call_8ZlY9cUc8Ft1twi4ch8UJ6IN.txt +5195 -0
  19. package/.code/agents/2188/exec-call_5HqayBxIteJtoI8oPTiLWgvJ.txt +286 -0
  20. package/.code/agents/2188/exec-call_XRbBKBq3adZe6dcppAvQtM7G.txt +218 -0
  21. package/.code/agents/2188/exec-call_ehA0SjpYtrUi6GJXmibLjp4i.txt +180 -0
  22. package/.code/agents/21902821-ecaf-4759-bb9d-222b90921af5/error.txt +3 -0
  23. package/.code/agents/232073be-aa0e-46da-b478-5b64dbf03cf5/status.txt +1 -0
  24. package/.code/agents/234ff534-2336-4771-a8d9-aa04421a63be/result.txt +747 -0
  25. package/.code/agents/253e2695-dc36-4022-b436-27655e0fc6c7/status.txt +1 -0
  26. package/.code/agents/2583/exec-call_M59I4eDjpjlBIWBiSxyS0YlJ.txt +2594 -0
  27. package/.code/agents/2583/exec-call_usLRGh7OhVHtsRBL4iUwRhjq.txt +2594 -0
  28. package/.code/agents/292aa3ff-dbab-470f-97c9-e7e8fd65e0db/result.txt +144 -0
  29. package/.code/agents/3134/exec-call_IgCAMGx19lWfuo8zfYIt5FFC.txt +416 -0
  30. package/.code/agents/3134/exec-call_IxvLR2Oo7kba2QTsI1gHVko8.txt +2590 -0
  31. package/.code/agents/3134/exec-call_jYvc8hksZChSiysbzKjl2ZbB.txt +2590 -0
  32. package/.code/agents/329/exec-call_4QdP3SfSO7HGPCwVcqZIth6s.txt +2590 -0
  33. package/.code/agents/472/exec-call_4AxzEEcWwkKhpqRB3bE8Ha4L.txt +790 -0
  34. package/.code/agents/472/exec-call_CB3LPYQA8QIZRi8I6kj4J17A.txt +766 -0
  35. package/.code/agents/472/exec-call_YeoUWvaFoktay2nqVUsa9KKX.txt +790 -0
  36. package/.code/agents/472/exec-call_jPWgKVquBBXTg0T3Lks5ZfkK.txt +2594 -0
  37. package/.code/agents/472/exec-call_qBkvunpGBDEHph2jPmTwtcsb.txt +1000 -0
  38. package/.code/agents/472/exec-call_v0ffRV1p0kTckBmJPzzHAEy0.txt +3489 -0
  39. package/.code/agents/472/exec-call_xAX5FXqWIlk02d9WubHbHWh8.txt +766 -0
  40. package/.code/agents/5346/exec-call_9q0muXUuLaucwEqI51Pt7idT.txt +2594 -0
  41. package/.code/agents/5346/exec-call_B2el3B79rVkq9LhWTI2VYlz7.txt +2456 -0
  42. package/.code/agents/5346/exec-call_BfX08f02qkZI9uJD5dvCvuoj.txt +2594 -0
  43. package/.code/agents/543328d0-61d6-4fd1-a723-bb168656e2e2/error.txt +18 -0
  44. package/.code/agents/5580c02c-1383-4d18-9cbd-cc8a06e3408d/result.txt +48 -0
  45. package/.code/agents/60ce1a22-5126-44b2-b977-1d5b56142a7b/status.txt +1 -0
  46. package/.code/agents/6215d9db-7fa9-4429-aeec-3835c3212291/error.txt +1 -0
  47. package/.code/agents/6743db55-30e5-4b4e-9366-a8214fc7f714/error.txt +1 -0
  48. package/.code/agents/6bf9591b-b9c9-422c-b0a5-e968c7d8422a/status.txt +1 -0
  49. package/.code/agents/7/exec-call_eww3GfdEiJZx61sJEQ9wNmt3.txt +1271 -0
  50. package/.code/agents/70/exec-call_owUtDMYiVgqDf8vsz1i32PFf.txt +1570 -0
  51. package/.code/agents/8/exec-call_UtrjAcLbhYLatxR4O97fZgnm.txt +2590 -0
  52. package/.code/agents/82490bc9-f34e-4b1b-8a8e-bccc2e6254f5/error.txt +3 -0
  53. package/.code/agents/841/exec-call_7nTNhSBCNjTDUIJv7py6CepO.txt +3299 -0
  54. package/.code/agents/841/exec-call_TLI0yUdUijuUAvI4o3DXEvHO.txt +3299 -0
  55. package/.code/agents/9/exec-call_XaABQT1hIlRpnKZ2uyBMWsTC.txt +1882 -0
  56. package/.code/agents/941/exec-call_GuGHRx7NNXWIDAnxUG2NEWPa.txt +2594 -0
  57. package/.code/agents/95d9fbab-19a2-48af-83f9-c792566a347f/error.txt +1 -0
  58. package/.code/agents/b0098cb8-cb32-4ada-9bc4-37c587518896/result.txt +170 -0
  59. package/.code/agents/b4fe59a4-81df-42e2-a112-0153e504faca/error.txt +1 -0
  60. package/.code/agents/bf4ce152-f623-49d7-aa52-c18631625c3c/error.txt +3 -0
  61. package/.code/agents/d7d1db75-d7eb-468e-adea-4ef4d916d187/status.txt +1 -0
  62. package/.code/agents/e2baa9c8-bac3-49e3-a39d-024333e6a990/status.txt +1 -0
  63. package/.code/agents/e350b8c3-8483-408c-b2bb-94515f492a11/error.txt +3 -0
  64. package/.code/agents/e63f9919-719f-4ad0-bccf-01b1a596e1e9/status.txt +1 -0
  65. package/.code/agents/e71695a8-3044-478d-8f12-ed13d02884c7/status.txt +1 -0
  66. package/.code/agents/f95b7464-3e25-4897-b153-c8dfd63fd605/error.txt +5 -0
  67. package/.code/agents/fa3c5ddf-cdf7-47a2-930a-b806c6363689/status.txt +1 -0
  68. package/.github/workflows/publish.yml +3 -3
  69. package/.github/workflows/release.yml +4 -0
  70. package/CHANGELOG.md +75 -0
  71. package/NUL +1 -0
  72. package/dist/bundle/index.cjs +65 -42
  73. package/dist/server/errorHandler.d.ts +2 -0
  74. package/dist/server/errorHandler.js +49 -5
  75. package/dist/tools/reconcileAdapter.js +10 -5
  76. package/dist/tools/reconciliation/analyzer.d.ts +8 -2
  77. package/dist/tools/reconciliation/analyzer.js +127 -409
  78. package/dist/tools/reconciliation/csvParser.d.ts +51 -0
  79. package/dist/tools/reconciliation/csvParser.js +413 -0
  80. package/dist/tools/reconciliation/executor.d.ts +8 -0
  81. package/dist/tools/reconciliation/executor.js +204 -58
  82. package/dist/tools/reconciliation/index.d.ts +7 -7
  83. package/dist/tools/reconciliation/index.js +115 -39
  84. package/dist/tools/reconciliation/matcher.d.ts +24 -3
  85. package/dist/tools/reconciliation/matcher.js +175 -133
  86. package/dist/tools/reconciliation/recommendationEngine.js +22 -18
  87. package/dist/tools/reconciliation/reportFormatter.js +9 -8
  88. package/dist/tools/reconciliation/signDetector.d.ts +2 -0
  89. package/dist/tools/reconciliation/signDetector.js +54 -0
  90. package/dist/tools/reconciliation/types.d.ts +20 -34
  91. package/dist/tools/reconciliation/types.js +1 -7
  92. package/dist/tools/reconciliation/ynabAdapter.d.ts +4 -0
  93. package/dist/tools/reconciliation/ynabAdapter.js +15 -0
  94. package/dist/types/reconciliation.d.ts +24 -0
  95. package/dist/types/reconciliation.js +1 -0
  96. package/docs/guides/ARCHITECTURE.md +12 -129
  97. package/docs/plans/2025-11-21-v014-hardening.md +153 -0
  98. package/docs/plans/reconciliation-v2-redesign.md +1571 -0
  99. package/package.json +6 -1
  100. package/scripts/test-recommendations.ts +1 -1
  101. package/src/__tests__/tools/reconciliation/csvParser.integration.test.ts +129 -0
  102. package/src/__tests__/tools/reconciliation/real-world.integration.test.ts +53 -0
  103. package/src/server/errorHandler.ts +52 -5
  104. package/src/tools/reconcileAdapter.ts +10 -5
  105. package/src/tools/reconciliation/__tests__/adapter.test.ts +28 -22
  106. package/src/tools/reconciliation/__tests__/analyzer.test.ts +114 -180
  107. package/src/tools/reconciliation/__tests__/csvParser.test.ts +87 -0
  108. package/src/tools/reconciliation/__tests__/executor.integration.test.ts +1 -1
  109. package/src/tools/reconciliation/__tests__/executor.test.ts +88 -61
  110. package/src/tools/reconciliation/__tests__/matcher.test.ts +68 -54
  111. package/src/tools/reconciliation/__tests__/recommendationEngine.test.ts +37 -30
  112. package/src/tools/reconciliation/__tests__/reportFormatter.test.ts +6 -5
  113. package/src/tools/reconciliation/__tests__/scenarios/extremes.scenario.test.ts +30 -11
  114. package/src/tools/reconciliation/__tests__/scenarios/repeatAmount.scenario.test.ts +50 -15
  115. package/src/tools/reconciliation/__tests__/signDetector.test.ts +211 -0
  116. package/src/tools/reconciliation/__tests__/ynabAdapter.test.ts +61 -0
  117. package/src/tools/reconciliation/analyzer.ts +191 -550
  118. package/src/tools/reconciliation/csvParser.ts +617 -0
  119. package/src/tools/reconciliation/executor.ts +249 -66
  120. package/src/tools/reconciliation/index.ts +148 -54
  121. package/src/tools/reconciliation/matcher.ts +234 -214
  122. package/src/tools/reconciliation/recommendationEngine.ts +23 -19
  123. package/src/tools/reconciliation/reportFormatter.ts +16 -11
  124. package/src/tools/reconciliation/signDetector.ts +117 -0
  125. package/src/tools/reconciliation/types.ts +39 -61
  126. package/src/tools/reconciliation/ynabAdapter.ts +33 -0
  127. package/src/types/reconciliation.ts +49 -0
  128. package/test-exports/ynab_since_2025-10-16_account_53298e13_238items_2025-11-28_13-46-20.json +3662 -0
  129. package/.code/agents/0427d95e-edca-431f-a214-5e53264e29c4/error.txt +0 -8
  130. package/.code/agents/0d675174-d1e1-41c3-9975-4c2e275819a9/error.txt +0 -3
  131. package/.code/agents/0d8c5afd-4787-422b-abf8-2e5943fc7e67/error.txt +0 -3
  132. package/.code/agents/0ec34a70-ed5d-4b9e-bee4-bb0e4cccbc4b/error.txt +0 -1
  133. package/.code/agents/0ef51a21-1ab1-49d7-9561-0eaa43875ebc/error.txt +0 -12
  134. package/.code/agents/15db95d7-abad-4b4d-9c3b-8446089cb61d/error.txt +0 -1
  135. package/.code/agents/19ab9acb-f675-4ff0-902a-09a5476f8149/error.txt +0 -1
  136. package/.code/agents/1ef7e12d-f6ff-4897-8a9b-152d523d898e/error.txt +0 -5
  137. package/.code/agents/2465/exec-call_lroN9KKzJVWC7t5423DK1nT9.txt +0 -1453
  138. package/.code/agents/28edb6fe-95a9-41a0-ae69-aa0100d26c0c/error.txt +0 -8
  139. package/.code/agents/2ae40cf5-b4bf-42e2-92bf-7ea350a7755e/error.txt +0 -9
  140. package/.code/agents/2bfc4e1f-ac4b-45a5-b6df-bf89d4dbb54c/error.txt +0 -1
  141. package/.code/agents/2e2e1134-eff0-49be-ba25-8e2c3468a564/error.txt +0 -5
  142. package/.code/agents/3/exec-call_203OC4TNVkLxW7z2HCVEQ1cM.txt +0 -81
  143. package/.code/agents/3/exec-call_SS5T0XSiXB4LSNzUKTl75wkh.txt +0 -610
  144. package/.code/agents/3322c003-ce5e-48e3-a342-f5049c5bf9a2/error.txt +0 -1
  145. package/.code/agents/391e9b08-1ebc-468c-9bcd-6d0cc3193b37/error.txt +0 -1
  146. package/.code/agents/3ab0aa84-b7bb-4054-afa3-40b8fd7d3be0/error.txt +0 -1
  147. package/.code/agents/3bed368d-50fe-477e-aee3-a6707eaa1ab9/error.txt +0 -3
  148. package/.code/agents/3e40b925-db12-442f-8d7a-a25fc69a6672/error.txt +0 -8
  149. package/.code/agents/414d5776-cf58-41f3-9328-a6daed503a50/error.txt +0 -5
  150. package/.code/agents/42687751-4565-4610-b240-67835b17d861/error.txt +0 -1
  151. package/.code/agents/46b98876-1a39-43c9-9e2f-507ca6d47335/error.txt +0 -9
  152. package/.code/agents/4a7d9491-b26f-43dd-850d-2ecdc49b5d1b/error.txt +0 -1
  153. package/.code/agents/4e60f00a-1b3e-447f-87f3-7faf9deddec3/error.txt +0 -13
  154. package/.code/agents/5138fc1c-4d49-4b74-a7da-ccdb3a8e44e7/error.txt +0 -14
  155. package/.code/agents/521cff39-a7a3-42e5-a557-134f0f7daaa0/error.txt +0 -5
  156. package/.code/agents/53302dc5-3857-4413-9a47-9e0f64a51dc4/error.txt +0 -5
  157. package/.code/agents/567c7c2e-6a6f-4761-a08d-d36deeb2e0ac/error.txt +0 -5
  158. package/.code/agents/57b00845-80dc-47c9-953c-3028d16275d6/error.txt +0 -3
  159. package/.code/agents/593d9005-c2a5-48fd-8813-ece0d3f2de96/error.txt +0 -1
  160. package/.code/agents/5a112e66-0e1a-42f9-877c-53af56ea3551/error.txt +0 -1
  161. package/.code/agents/5b05e8ed-7788-4738-b7ee-9faa8180f992/error.txt +0 -5
  162. package/.code/agents/5f888d6f-d7ca-4ac8-be23-9ea1bf753951/error.txt +0 -5
  163. package/.code/agents/607db3ab-e4b0-435b-b497-93e9aa525549/error.txt +0 -8
  164. package/.code/agents/67dcb2a2-900f-4c78-b3fc-80b5213e0ddf/error.txt +0 -8
  165. package/.code/agents/69ad848c-4e98-49b3-b16c-0094ac2d1759/error.txt +0 -5
  166. package/.code/agents/6c9cfc5f-0d0b-445c-b121-9f60082c4f70/error.txt +0 -1
  167. package/.code/agents/6f6f8f77-4ab0-4f6e-9f30-40e8be0bd8f5/error.txt +0 -1
  168. package/.code/agents/72a7cde4-fa8a-4024-9038-27faa550539b/error.txt +0 -1
  169. package/.code/agents/7b48335c-8247-43aa-9949-5f820ba8e199/error.txt +0 -1
  170. package/.code/agents/80944249-bea9-4ac5-87de-a666c4df306e/error.txt +0 -1
  171. package/.code/agents/826099df-1b66-4186-a915-7eb59f9db19d/error.txt +0 -5
  172. package/.code/agents/8291d158-18a8-4a92-b799-4e9a4d9cce88/error.txt +0 -1
  173. package/.code/agents/82fb71a3-20fb-4341-804a-a2fc900f95bc/error.txt +0 -1
  174. package/.code/agents/855790ea-54ee-43e4-8209-a66994e37590/error.txt +0 -1
  175. package/.code/agents/88ce3a2e-04f2-42be-9062-bf97aa798da0/error.txt +0 -3
  176. package/.code/agents/9a17e398-b6ed-4218-bb55-bc64a8d38ce8/error.txt +0 -8
  177. package/.code/agents/9a4f4bfc-a2a6-4f40-a896-9335b41a7ed1/error.txt +0 -1
  178. package/.code/agents/9b633e55-ef84-47d6-94bb-fd3dd172ad97/error.txt +0 -1
  179. package/.code/agents/9b81f3ab-c72b-4a81-9a8f-28a49ddba84a/error.txt +0 -8
  180. package/.code/agents/a35daf29-b2d1-4aef-9b42-dad63a76bd47/error.txt +0 -3
  181. package/.code/agents/a81990cc-69ee-44d2-b907-17403c9bc5d7/error.txt +0 -5
  182. package/.code/agents/ab56260a-4a83-4ad4-9410-f88a23d6520a/error.txt +0 -1
  183. package/.code/agents/ad722c31-2d1d-45f7-bae2-3f02ca455b60/error.txt +0 -1
  184. package/.code/agents/b62e8690-3324-4b97-9309-731bee79416b/error.txt +0 -5
  185. package/.code/agents/baf60a3a-752b-4ad8-99d6-df32423ed2eb/error.txt +0 -1
  186. package/.code/agents/be049042-7dcb-4ac8-9beb-c8f1aea67742/error.txt +0 -14
  187. package/.code/agents/bed1dcb4-bfce-4a9f-8594-0f994962aafd/error.txt +0 -1
  188. package/.code/agents/c324a6cf-e935-4ede-9529-b3ebc18e8d6b/error.txt +0 -5
  189. package/.code/agents/c37c06ff-dfe3-43f2-9bbc-3ec73ec8f41d/error.txt +0 -5
  190. package/.code/agents/c8cd6671-433a-456b-9f88-e51cb2df6bfc/error.txt +0 -11
  191. package/.code/agents/ca2ccb67-2f24-428e-b27d-9365beadd140/error.txt +0 -1
  192. package/.code/agents/cf08c0c8-e7f0-423e-93ba-547e8e818340/error.txt +0 -8
  193. package/.code/agents/d579c74f-874b-40a4-9d56-ced1eb6a701d/error.txt +0 -1
  194. package/.code/agents/df412c98-7378-4deb-8e1e-76c416931181/error.txt +0 -3
  195. package/.code/agents/e5134eb3-2af4-45b0-8998-051cb4afdb45/error.txt +0 -3
  196. package/.code/agents/e6308471-aa45-4e9e-9496-2e9404164d97/error.txt +0 -8
  197. package/.code/agents/e7bd8bc7-23fb-4f46-98dc-b0dcf11b75a1/error.txt +0 -1
  198. package/.code/agents/e92bec35-378d-4fe1-8ac0-6e1bb3c86911/error.txt +0 -5
  199. package/.code/agents/ed918fbf-2dc4-4aa2-bfc5-04b65d9471ea/error.txt +0 -1
  200. package/.code/agents/ef1d756f-b272-48fc-8729-f05c494674f7/error.txt +0 -1
  201. package/.code/agents/ef359853-0249-4e41-a804-c0fc459fe456/error.txt +0 -1
  202. package/.code/agents/effc7b4a-4b90-40a0-8c86-a7a99d2d5fd2/error.txt +0 -1
  203. package/.code/agents/fa15f8d5-8359-4a8b-83a3-2f2056b3ff40/error.txt +0 -3
  204. package/.code/agents/fbef4193-eadf-4c8a-83ff-4878a6310f25/error.txt +0 -8
  205. package/.code/agents/fd0a4b4a-fda4-4964-a6d6-2b8a2da387c6/error.txt +0 -1
  206. package/.gemini/settings.json +0 -8
  207. package/WARP.md +0 -245
@@ -0,0 +1,231 @@
1
+ Based on my analysis of the ynab-mcpb repository, here's a concise, actionable implementation plan for the next iteration:
2
+
3
+ ---
4
+
5
+ # YNAB MCP Server - Next Iteration Implementation Plan
6
+
7
+ ## Context Analysis
8
+
9
+ **Current State:**
10
+ - Version: 0.13.4 (pre-1.0 API)
11
+ - TypeScript: ✅ No type errors
12
+ - Unit Tests: ✅ 1334 passed (59 files)
13
+ - Recent Focus: CI/CD reliability, caching fixes, reconciliation improvements
14
+ - Planning Documents: 3 detailed plans ready for execution
15
+
16
+ **Untracked File:** `temp-recon.ts` - Integration test script for reconciliation executor
17
+
18
+ ---
19
+
20
+ ## High-Impact Plan (Bite-Sized Tasks)
21
+
22
+ ### Phase 1: Clean Up Workspace (5 min)
23
+
24
+ **Goal:** Remove temporary files from working directory
25
+
26
+ **Task 1.1: Remove temporary reconciliation test file**
27
+ - Files: `temp-recon.ts` (root directory)
28
+ - Command: `git rm temp-recon.ts` or move to `src/__tests__/scratch/`
29
+ - Verify: `git status` shows clean working directory
30
+ - Rationale: File appears to be development scratch work, duplicates existing integration tests
31
+
32
+ ---
33
+
34
+ ### Phase 2: Implement Pending Plans (60-90 min total)
35
+
36
+ #### Option A: Reloadable Config & Token Validation (30-45 min)
37
+ **Priority:** High - Improves testability and error messages
38
+ **Plan:** `docs/plans/2025-11-20-reloadable-config-token-validation.md`
39
+ **Impact:** Better CI reliability, clearer auth failures
40
+
41
+ **Tasks:**
42
+ 1. Reloadable config loader (10 min)
43
+ - Edit: `src/server/config.ts`
44
+ - Test: `src/server/__tests__/config.test.ts`
45
+ - Verify: `npm run test:unit -- src/server/__tests__/config.test.ts`
46
+
47
+ 2. Inject config into YNABMCPServer (10 min)
48
+ - Edit: `src/server/YNABMCPServer.ts`
49
+ - Test: `src/server/__tests__/YNABMCPServer.test.ts`
50
+ - Verify: `npm run test:unit -- src/server/__tests__/YNABMCPServer.test.ts`
51
+
52
+ 3. Token validation resilience (10 min)
53
+ - Edit: `src/server/YNABMCPServer.ts`
54
+ - Test: `src/server/__tests__/server-startup.integration.test.ts`
55
+ - Verify: `npm run test:integration:core`
56
+
57
+ 4. Test alignment & portability (5 min)
58
+ - Edit: `scripts/run-throttled-integration-tests.js`
59
+ - Verify: `node scripts/run-throttled-integration-tests.js --help`
60
+
61
+ 5. Full verification (10 min)
62
+ - Run: `npm test && npm run type-check`
63
+ - Format: `npm run format`
64
+ - Build: `npm run build`
65
+
66
+ #### Option B: Reconciliation Error Handling (20-30 min)
67
+ **Priority:** High - Fixes silent failures in reconciliation
68
+ **Plan:** `docs/plans/2025-11-21-reconciliation-error-handling.md`
69
+ **Impact:** Proper error propagation, better debugging
70
+
71
+ **Tasks:**
72
+ 1. Normalize YNAB API errors (10 min)
73
+ - Edit: `src/tools/reconciliation/executor.ts`
74
+ - Add error parsing utilities
75
+ - Verify: `npm run type-check`
76
+
77
+ 2. Propagate fatal errors (5 min)
78
+ - Edit: `src/tools/reconciliation/executor.ts`
79
+ - Update catch blocks for bulk/sequential creation
80
+ - Verify: Code review for logic correctness
81
+
82
+ 3. Add test coverage (10 min)
83
+ - Edit: `src/tools/reconciliation/__tests__/executor.test.ts`
84
+ - Add 429/404 error propagation tests
85
+ - Verify: `npm run test:unit -- src/tools/reconciliation/__tests__/executor.test.ts`
86
+
87
+ 4. Integration verification (5 min)
88
+ - Run: `npm run test:integration:reconciliation` (if token available)
89
+ - Verify: Error messages are actionable
90
+
91
+ #### Option C: Transaction Cached Property Fix (Already Complete?)
92
+ **Plan:** `docs/plans/2025-11-21-fix-transaction-cached-property.md`
93
+ **Status:** CHANGELOG shows this was fixed in 0.13.1
94
+ **Action:** Verify plan is obsolete, archive or delete planning document
95
+
96
+ ---
97
+
98
+ ### Phase 3: Documentation & Code Quality (15-20 min)
99
+
100
+ **Task 3.1: Update CHANGELOG for unreleased changes**
101
+ - Edit: `CHANGELOG.md`
102
+ - Add entries under `## [Unreleased]` section
103
+ - Format: Keep a Changelog format
104
+ - Verify: `npm run format:check`
105
+
106
+ **Task 3.2: Archive completed planning documents**
107
+ - Move: `docs/plans/2025-11-21-fix-transaction-cached-property.md` → `docs/plans/archive/` (if complete)
108
+ - Update: Add completion notes or delete if obsolete
109
+ - Verify: `ls docs/plans` shows only active plans
110
+
111
+ **Task 3.3: Update CLAUDE.md if needed**
112
+ - Review: Recent architectural changes
113
+ - Edit: `CLAUDE.md` if new patterns emerged
114
+ - Verify: Accuracy of build commands, test commands
115
+
116
+ **Task 3.4: Clean up temp-recon.ts usage**
117
+ - Decision: Move to tests or delete
118
+ - Option A: Move to `src/__tests__/manual/temp-recon.ts`
119
+ - Option B: Delete if duplicates existing tests
120
+ - Verify: `git status` clean
121
+
122
+ ---
123
+
124
+ ### Phase 4: Proactive Improvements (20-30 min)
125
+
126
+ **Task 4.1: Add schema validation tests for new YNAB API fields**
127
+ - Files: `src/tools/schemas/outputs/__tests__/*.test.ts`
128
+ - Goal: Ensure schemas handle all YNAB API response variations
129
+ - Add: Edge case tests for nullable/optional fields
130
+ - Verify: `npm run test:unit -- src/tools/schemas/outputs/__tests__/`
131
+
132
+ **Task 4.2: Improve tool annotation coverage**
133
+ - Files: Check all 30 tools in `src/tools/`
134
+ - Review: Tool registration in `src/server/YNABMCPServer.ts`
135
+ - Verify: All tools have proper `ToolAnnotationPresets` applied
136
+ - Test: `npm run test:unit`
137
+
138
+ **Task 4.3: Add missing JSDoc comments**
139
+ - Files: `src/tools/*.ts`, `src/server/*.ts`
140
+ - Focus: Public API functions lacking documentation
141
+ - Format: TypeScript JSDoc with `@param`, `@returns`, `@throws`
142
+ - Verify: `npm run type-check`
143
+
144
+ ---
145
+
146
+ ### Phase 5: Testing & Verification (10-15 min)
147
+
148
+ **Task 5.1: Run full test suite**
149
+ ```bash
150
+ npm test # Unit tests (fast)
151
+ npm run type-check # TypeScript validation
152
+ npm run lint # ESLint + Prettier check
153
+ ```
154
+
155
+ **Task 5.2: Build verification**
156
+ ```bash
157
+ npm run build # Production build with verification
158
+ npm run verify-build # Post-build checks
159
+ ```
160
+
161
+ **Task 5.3: Integration tests (optional, requires YNAB_ACCESS_TOKEN)**
162
+ ```bash
163
+ npm run test:integration:core # Core integration suite
164
+ ```
165
+
166
+ ---
167
+
168
+ ## Recommended Execution Order
169
+
170
+ ### Quick Wins (30 min):
171
+ 1. Clean up workspace (remove `temp-recon.ts`)
172
+ 2. Implement reconciliation error handling (Option B)
173
+ 3. Update CHANGELOG
174
+ 4. Run verification suite
175
+
176
+ ### Comprehensive (90 min):
177
+ 1. Clean up workspace
178
+ 2. Implement reloadable config (Option A)
179
+ 3. Implement reconciliation error handling (Option B)
180
+ 4. Update documentation
181
+ 5. Add proactive improvements
182
+ 6. Full test & build verification
183
+
184
+ ---
185
+
186
+ ## File Paths Quick Reference
187
+
188
+ ### Source Files
189
+ - **Server Core:** `src/server/YNABMCPServer.ts`, `src/server/config.ts`
190
+ - **Tool Handlers:** `src/tools/*.ts` (accountTools, transactionTools, reconciliation/, etc.)
191
+ - **Reconciliation:** `src/tools/reconciliation/executor.ts`, `analyzer.ts`, `matcher.ts`
192
+ - **Utilities:** `src/utils/money.ts`, `src/utils/dateUtils.ts`, `src/utils/amountUtils.ts`
193
+ - **Types:** `src/types/index.ts`
194
+ - **Entry Point:** `src/index.ts`
195
+
196
+ ### Test Files
197
+ - **Unit Tests:** `src/**/__tests__/*.test.ts`
198
+ - **Integration Tests:** `src/**/__tests__/*.integration.test.ts`
199
+ - **E2E Tests:** `src/**/__tests__/*.e2e.test.ts`
200
+
201
+ ### Documentation
202
+ - **User Docs:** `docs/getting-started/`, `docs/guides/`, `docs/reference/`
203
+ - **Planning:** `docs/plans/*.md`
204
+ - **Root:** `README.md`, `CLAUDE.md`, `CHANGELOG.md`
205
+
206
+ ### Scripts
207
+ - **Build:** `scripts/verify-build.js`, `scripts/run-generate-mcpb.js`
208
+ - **Testing:** `scripts/run-throttled-integration-tests.js`
209
+ - **CI:** `.github/workflows/*.yml`
210
+
211
+ ---
212
+
213
+ ## Success Criteria
214
+
215
+ - ✅ No TypeScript errors (`npm run type-check`)
216
+ - ✅ All unit tests pass (`npm test`)
217
+ - ✅ Code formatted (`npm run format:check`)
218
+ - ✅ Clean working directory (`git status`)
219
+ - ✅ Production build succeeds (`npm run build`)
220
+ - ✅ CHANGELOG updated with changes
221
+ - ✅ Documentation reflects current state
222
+
223
+ ---
224
+
225
+ ## Notes
226
+
227
+ - **No breaking changes** - Maintain API compatibility for 0.x series
228
+ - **Test-driven** - Write tests before implementation where possible
229
+ - **Incremental commits** - Commit after each task completion
230
+ - **Convention:** Use conventional commit format (feat:, fix:, chore:, docs:)
231
+ - **Environment:** Requires Node 18+, npm, YNAB_ACCESS_TOKEN for integration tests