Commit c0b5eb7
committed
Harden security, performance, and DoS resilience across workspace - Fix TOCTOU race in vault permission check (fstat on fd, not path)
- Add constant-time token comparison via subtle::ConstantTimeEq
- Use Docker file-based secrets instead of env vars for passphrase
- Validate config paths (absolute only, reject ..) via garde
- Add JSON depth check (max 64) on webhook payloads
DoS hardening closes 5 resource exhaustion vectors:
- Cap actions per rule (100) and condition siblings per node (100)
- Enforce minimum cron interval (60s) to prevent per-second abuse
- Limit WriteFile action content to 10 MiB
- Cap rule count at 10,000 per instance
- Non-blocking webhook dispatch (try_send, 503 on full channel) Performance fixes eliminate hot-path waste: - Cache compiled regexes at add_rule() time (HashMap lookup vs recompile) - Arc-wrap RuleMatch payload and actions (ref-count bump vs deep clone) - Arc-wrap NativeConnectorHost in registry, derive Clone on CapabilityChecker — drop registry lock before connector network calls - Drop engine lock before cron/watcher unschedule in rule update/delete API input validation: - Clamp event query limit to 10,000 - Reject path parameters longer than 256 chars - Bound event query limit on all endpoints Shared module extraction (code deduplication): -deserialize_secret/deserialize_secret_option in springtale-connector
- base64url_encode/urlencoded encoding helpers - handle_json_response for typed API clients - derive_api_token_hash in springtale-crypto - Per-connector client::test_helpers mock modules1 parent 910e5c4 commit c0b5eb7
61 files changed
Lines changed: 1333 additions & 826 deletions
File tree
- apps
- springtale-cli/src
- commands
- springtaled
- src
- api
- runtime
- tests
- connectors
- connector-bluesky/src
- actions
- client
- connector-github/src
- client
- connector-http/src
- actions
- client
- connector-kick/src
- actions
- auth
- client
- connector-presearch/src
- actions
- client
- crates
- springtale-connector
- src
- capability
- registry
- springtale-core/src
- router
- rule
- springtale-crypto
- src
- token
- vault
- springtale-scheduler/src/cron
- springtale-store/src
- docs/logo
Some content is hidden
Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
68 | 68 | | |
69 | 69 | | |
70 | 70 | | |
| 71 | + | |
71 | 72 | | |
72 | 73 | | |
73 | 74 | | |
| |||
Large diffs are not rendered by default.
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
8 | 8 | | |
9 | 9 | | |
10 | 10 | | |
11 | | - | |
| 11 | + | |
12 | 12 | | |
13 | 13 | | |
14 | 14 | | |
| |||
96 | 96 | | |
97 | 97 | | |
98 | 98 | | |
99 | | - | |
100 | | - | |
101 | | - | |
102 | | - | |
103 | | - | |
104 | | - | |
105 | | - | |
106 | | - | |
107 | | - | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
87 | 87 | | |
88 | 88 | | |
89 | 89 | | |
90 | | - | |
| 90 | + | |
91 | 91 | | |
92 | 92 | | |
93 | 93 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
62 | 62 | | |
63 | 63 | | |
64 | 64 | | |
65 | | - | |
| 65 | + | |
66 | 66 | | |
67 | 67 | | |
68 | 68 | | |
69 | 69 | | |
70 | 70 | | |
71 | 71 | | |
72 | | - | |
| 72 | + | |
73 | 73 | | |
74 | 74 | | |
75 | 75 | | |
76 | 76 | | |
77 | 77 | | |
78 | | - | |
79 | | - | |
80 | | - | |
81 | | - | |
82 | | - | |
83 | | - | |
84 | | - | |
85 | | - | |
86 | | - | |
87 | | - | |
88 | | - | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
13 | 13 | | |
14 | 14 | | |
15 | 15 | | |
| 16 | + | |
16 | 17 | | |
17 | 18 | | |
18 | 19 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
2 | 2 | | |
3 | 3 | | |
4 | 4 | | |
| 5 | + | |
5 | 6 | | |
6 | 7 | | |
7 | 8 | | |
| |||
12 | 13 | | |
13 | 14 | | |
14 | 15 | | |
15 | | - | |
| 16 | + | |
| 17 | + | |
16 | 18 | | |
17 | 19 | | |
18 | 20 | | |
| |||
30 | 32 | | |
31 | 33 | | |
32 | 34 | | |
33 | | - | |
34 | | - | |
35 | | - | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
36 | 39 | | |
37 | 40 | | |
38 | 41 | | |
39 | 42 | | |
40 | 43 | | |
41 | | - | |
42 | | - | |
43 | | - | |
44 | | - | |
45 | | - | |
46 | | - | |
47 | | - | |
48 | | - | |
49 | | - | |
50 | | - | |
51 | | - | |
52 | | - | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
29 | 29 | | |
30 | 30 | | |
31 | 31 | | |
| 32 | + | |
32 | 33 | | |
33 | 34 | | |
34 | 35 | | |
| |||
42 | 43 | | |
43 | 44 | | |
44 | 45 | | |
| 46 | + | |
45 | 47 | | |
46 | 48 | | |
47 | 49 | | |
| |||
55 | 57 | | |
56 | 58 | | |
57 | 59 | | |
| 60 | + | |
58 | 61 | | |
59 | 62 | | |
60 | 63 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
22 | 22 | | |
23 | 23 | | |
24 | 24 | | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
25 | 28 | | |
26 | 29 | | |
27 | 30 | | |
| |||
30 | 33 | | |
31 | 34 | | |
32 | 35 | | |
| 36 | + | |
| 37 | + | |
33 | 38 | | |
34 | 39 | | |
35 | | - | |
| 40 | + | |
36 | 41 | | |
37 | 42 | | |
38 | 43 | | |
| |||
42 | 47 | | |
43 | 48 | | |
44 | 49 | | |
45 | | - | |
| 50 | + | |
46 | 51 | | |
47 | 52 | | |
48 | 53 | | |
| |||
0 commit comments