Commit 2c70750
fix(data): address medium-severity audit findings
Three fixes from the code audit:
1. parseCents now rejects negative values -- all money fields represent
costs, fees, or budgets where negatives don't make sense. Inputs like
"-$5.00", "$-100", and "--$5" are all rejected with ErrInvalidMoney.
2. requireParentAlive now distinguishes soft-deleted parents from
truly missing parents. Callers show "X is deleted -- restore it
first" vs "X no longer exists" as appropriate. Introduced
ErrParentDeleted / ErrParentNotFound sentinel errors.
3. SQLite Open() now sets journal_mode=WAL, synchronous=NORMAL, and
busy_timeout=5000 for better durability and concurrency behavior.
closes #186
Co-authored-by: Cursor <cursoragent@cursor.com>
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>1 parent 33ebe6e commit 2c70750
File tree
4 files changed
+96
-20
lines changed- internal
- app
- data
4 files changed
+96
-20
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
4 | 4 | | |
5 | 5 | | |
6 | 6 | | |
| 7 | + | |
7 | 8 | | |
8 | 9 | | |
9 | 10 | | |
| |||
1512 | 1513 | | |
1513 | 1514 | | |
1514 | 1515 | | |
| 1516 | + | |
| 1517 | + | |
| 1518 | + | |
| 1519 | + | |
| 1520 | + | |
| 1521 | + | |
| 1522 | + | |
1515 | 1523 | | |
1516 | 1524 | | |
1517 | 1525 | | |
1518 | | - | |
| 1526 | + | |
1519 | 1527 | | |
1520 | 1528 | | |
1521 | 1529 | | |
| |||
1524 | 1532 | | |
1525 | 1533 | | |
1526 | 1534 | | |
1527 | | - | |
| 1535 | + | |
1528 | 1536 | | |
1529 | 1537 | | |
1530 | 1538 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
33 | 33 | | |
34 | 34 | | |
35 | 35 | | |
36 | | - | |
37 | | - | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
38 | 49 | | |
39 | 50 | | |
40 | 51 | | |
| |||
710 | 721 | | |
711 | 722 | | |
712 | 723 | | |
713 | | - | |
| 724 | + | |
714 | 725 | | |
715 | 726 | | |
716 | 727 | | |
717 | | - | |
| 728 | + | |
718 | 729 | | |
719 | 730 | | |
720 | 731 | | |
| |||
784 | 795 | | |
785 | 796 | | |
786 | 797 | | |
787 | | - | |
| 798 | + | |
788 | 799 | | |
789 | 800 | | |
790 | 801 | | |
| |||
796 | 807 | | |
797 | 808 | | |
798 | 809 | | |
799 | | - | |
| 810 | + | |
800 | 811 | | |
801 | 812 | | |
802 | | - | |
| 813 | + | |
803 | 814 | | |
804 | 815 | | |
805 | 816 | | |
| |||
811 | 822 | | |
812 | 823 | | |
813 | 824 | | |
814 | | - | |
| 825 | + | |
815 | 826 | | |
816 | 827 | | |
817 | 828 | | |
| |||
821 | 832 | | |
822 | 833 | | |
823 | 834 | | |
824 | | - | |
825 | | - | |
826 | | - | |
| 835 | + | |
| 836 | + | |
| 837 | + | |
| 838 | + | |
| 839 | + | |
| 840 | + | |
| 841 | + | |
| 842 | + | |
| 843 | + | |
| 844 | + | |
827 | 845 | | |
828 | | - | |
| 846 | + | |
| 847 | + | |
| 848 | + | |
| 849 | + | |
| 850 | + | |
| 851 | + | |
| 852 | + | |
| 853 | + | |
| 854 | + | |
| 855 | + | |
| 856 | + | |
| 857 | + | |
| 858 | + | |
| 859 | + | |
| 860 | + | |
| 861 | + | |
| 862 | + | |
| 863 | + | |
| 864 | + | |
| 865 | + | |
| 866 | + | |
| 867 | + | |
829 | 868 | | |
830 | 869 | | |
831 | 870 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
17 | 17 | | |
18 | 18 | | |
19 | 19 | | |
20 | | - | |
21 | | - | |
22 | | - | |
23 | | - | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
24 | 25 | | |
25 | 26 | | |
26 | 27 | | |
27 | 28 | | |
28 | 29 | | |
29 | | - | |
| 30 | + | |
30 | 31 | | |
31 | 32 | | |
32 | 33 | | |
| |||
38 | 39 | | |
39 | 40 | | |
40 | 41 | | |
41 | | - | |
| 42 | + | |
42 | 43 | | |
43 | 44 | | |
44 | 45 | | |
| |||
182 | 183 | | |
183 | 184 | | |
184 | 185 | | |
| 186 | + | |
| 187 | + | |
| 188 | + | |
| 189 | + | |
185 | 190 | | |
186 | 191 | | |
187 | 192 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
91 | 91 | | |
92 | 92 | | |
93 | 93 | | |
| 94 | + | |
| 95 | + | |
| 96 | + | |
| 97 | + | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
| 103 | + | |
| 104 | + | |
| 105 | + | |
| 106 | + | |
| 107 | + | |
| 108 | + | |
| 109 | + | |
| 110 | + | |
| 111 | + | |
| 112 | + | |
| 113 | + | |
| 114 | + | |
| 115 | + | |
| 116 | + | |
| 117 | + | |
94 | 118 | | |
95 | 119 | | |
96 | 120 | | |
| |||
0 commit comments