@wlfi-agent/cli 1.4.13 → 1.4.14

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 (289) hide show
  1. package/Cargo.lock +3968 -0
  2. package/Cargo.toml +50 -0
  3. package/README.md +426 -6
  4. package/crates/vault-cli-admin/Cargo.toml +26 -0
  5. package/crates/vault-cli-admin/src/io_utils.rs +500 -0
  6. package/crates/vault-cli-admin/src/main.rs +3990 -0
  7. package/crates/vault-cli-admin/src/shared_config.rs +624 -0
  8. package/crates/vault-cli-admin/src/tui/amounts.rs +180 -0
  9. package/crates/vault-cli-admin/src/tui/token_rpc.rs +250 -0
  10. package/crates/vault-cli-admin/src/tui/utils.rs +82 -0
  11. package/crates/vault-cli-admin/src/tui.rs +3410 -0
  12. package/crates/vault-cli-agent/Cargo.toml +24 -0
  13. package/crates/vault-cli-agent/src/io_utils.rs +576 -0
  14. package/crates/vault-cli-agent/src/main.rs +833 -0
  15. package/crates/vault-cli-daemon/Cargo.toml +28 -0
  16. package/crates/vault-cli-daemon/src/bin/wlfi-agent-system-keychain.rs +216 -0
  17. package/crates/vault-cli-daemon/src/main.rs +644 -0
  18. package/crates/vault-cli-daemon/src/relay_sync.rs +894 -0
  19. package/crates/vault-cli-daemon/tests/system_keychain_helper_acl.rs +167 -0
  20. package/crates/vault-daemon/Cargo.toml +32 -0
  21. package/crates/vault-daemon/src/daemon_parts/api_impl_and_utils.rs +1041 -0
  22. package/crates/vault-daemon/src/daemon_parts/core_helpers.rs +1256 -0
  23. package/crates/vault-daemon/src/daemon_parts/types_api_rpc.rs +622 -0
  24. package/crates/vault-daemon/src/lib.rs +54 -0
  25. package/crates/vault-daemon/src/persistence.rs +441 -0
  26. package/crates/vault-daemon/src/tests.rs +237 -0
  27. package/crates/vault-daemon/src/tests_parts/part1.rs +1224 -0
  28. package/crates/vault-daemon/src/tests_parts/part2.rs +1021 -0
  29. package/crates/vault-daemon/src/tests_parts/part3.rs +835 -0
  30. package/crates/vault-daemon/src/tests_parts/part4.rs +604 -0
  31. package/crates/vault-domain/Cargo.toml +20 -0
  32. package/crates/vault-domain/src/action.rs +849 -0
  33. package/crates/vault-domain/src/address.rs +51 -0
  34. package/crates/vault-domain/src/approval.rs +90 -0
  35. package/crates/vault-domain/src/constants.rs +4 -0
  36. package/crates/vault-domain/src/error.rs +54 -0
  37. package/crates/vault-domain/src/keys.rs +71 -0
  38. package/crates/vault-domain/src/lib.rs +42 -0
  39. package/crates/vault-domain/src/nonce.rs +102 -0
  40. package/crates/vault-domain/src/policy.rs +172 -0
  41. package/crates/vault-domain/src/request.rs +53 -0
  42. package/crates/vault-domain/src/scope.rs +24 -0
  43. package/crates/vault-domain/src/session.rs +50 -0
  44. package/crates/vault-domain/src/signature.rs +34 -0
  45. package/crates/vault-domain/src/tests.rs +651 -0
  46. package/crates/vault-domain/src/u128_as_decimal_string.rs +44 -0
  47. package/crates/vault-policy/Cargo.toml +17 -0
  48. package/crates/vault-policy/src/engine.rs +301 -0
  49. package/crates/vault-policy/src/error.rs +81 -0
  50. package/crates/vault-policy/src/lib.rs +17 -0
  51. package/crates/vault-policy/src/report.rs +34 -0
  52. package/crates/vault-policy/src/tests.rs +891 -0
  53. package/crates/vault-policy/src/tests_explain.rs +78 -0
  54. package/crates/vault-sdk-agent/Cargo.toml +21 -0
  55. package/crates/vault-sdk-agent/src/lib.rs +711 -0
  56. package/crates/vault-signer/Cargo.toml +25 -0
  57. package/crates/vault-signer/src/lib.rs +731 -0
  58. package/crates/vault-signer/tests/secure_enclave_acl.rs +54 -0
  59. package/crates/vault-transport-unix/Cargo.toml +24 -0
  60. package/crates/vault-transport-unix/src/lib.rs +1640 -0
  61. package/crates/vault-transport-xpc/Cargo.toml +25 -0
  62. package/crates/vault-transport-xpc/src/client_codec_api.rs +635 -0
  63. package/crates/vault-transport-xpc/src/lib.rs +680 -0
  64. package/crates/vault-transport-xpc/src/tests.rs +818 -0
  65. package/crates/vault-transport-xpc/tests/e2e_flow.rs +773 -0
  66. package/dist/cli.cjs +35088 -0
  67. package/dist/cli.cjs.map +1 -0
  68. package/package.json +49 -43
  69. package/packages/cache/.turbo/turbo-build.log +52 -0
  70. package/packages/cache/dist/chunk-2QFWMUXT.cjs +43 -0
  71. package/packages/cache/dist/chunk-2QFWMUXT.cjs.map +1 -0
  72. package/packages/cache/dist/chunk-4U63TZTQ.js +43 -0
  73. package/packages/cache/dist/chunk-4U63TZTQ.js.map +1 -0
  74. package/packages/cache/dist/chunk-ALQ6H7KG.cjs +404 -0
  75. package/packages/cache/dist/chunk-ALQ6H7KG.cjs.map +1 -0
  76. package/packages/cache/dist/chunk-FGJEEF5N.js +404 -0
  77. package/packages/cache/dist/chunk-FGJEEF5N.js.map +1 -0
  78. package/packages/cache/dist/chunk-UYNEHZHB.cjs +45 -0
  79. package/packages/cache/dist/chunk-UYNEHZHB.cjs.map +1 -0
  80. package/packages/cache/dist/chunk-VXVMPG3W.js +45 -0
  81. package/packages/cache/dist/chunk-VXVMPG3W.js.map +1 -0
  82. package/packages/cache/dist/client/index.cjs +11 -0
  83. package/packages/cache/dist/client/index.cjs.map +1 -0
  84. package/packages/cache/dist/client/index.d.cts +15 -0
  85. package/packages/cache/dist/client/index.d.ts +15 -0
  86. package/packages/cache/dist/client/index.js +11 -0
  87. package/packages/cache/dist/client/index.js.map +1 -0
  88. package/packages/cache/dist/errors/index.cjs +11 -0
  89. package/packages/cache/dist/errors/index.cjs.map +1 -0
  90. package/packages/cache/dist/errors/index.d.cts +26 -0
  91. package/packages/cache/dist/errors/index.d.ts +26 -0
  92. package/packages/cache/dist/errors/index.js +11 -0
  93. package/packages/cache/dist/errors/index.js.map +1 -0
  94. package/packages/cache/dist/index.cjs +29 -0
  95. package/packages/cache/dist/index.cjs.map +1 -0
  96. package/packages/cache/dist/index.d.cts +4 -0
  97. package/packages/cache/dist/index.d.ts +4 -0
  98. package/packages/cache/dist/index.js +29 -0
  99. package/packages/cache/dist/index.js.map +1 -0
  100. package/packages/cache/dist/service/index.cjs +15 -0
  101. package/packages/cache/dist/service/index.cjs.map +1 -0
  102. package/packages/cache/dist/service/index.d.cts +184 -0
  103. package/packages/cache/dist/service/index.d.ts +184 -0
  104. package/packages/cache/dist/service/index.js +15 -0
  105. package/packages/cache/dist/service/index.js.map +1 -0
  106. package/packages/cache/node_modules/.bin/jiti +17 -0
  107. package/packages/cache/node_modules/.bin/tsc +17 -0
  108. package/packages/cache/node_modules/.bin/tsserver +17 -0
  109. package/packages/cache/node_modules/.bin/tsup +17 -0
  110. package/packages/cache/node_modules/.bin/tsup-node +17 -0
  111. package/packages/cache/node_modules/.bin/tsx +17 -0
  112. package/packages/cache/node_modules/.bin/vitest +17 -0
  113. package/packages/cache/package.json +48 -0
  114. package/packages/cache/src/client/index.ts +56 -0
  115. package/packages/cache/src/errors/index.ts +53 -0
  116. package/packages/cache/src/index.ts +3 -0
  117. package/packages/cache/src/service/index.test.ts +263 -0
  118. package/packages/cache/src/service/index.ts +678 -0
  119. package/packages/cache/tsconfig.json +13 -0
  120. package/packages/cache/tsup.config.ts +13 -0
  121. package/packages/cache/vitest.config.ts +16 -0
  122. package/packages/config/.turbo/turbo-build.log +18 -0
  123. package/packages/config/dist/index.cjs +1037 -0
  124. package/packages/config/dist/index.cjs.map +1 -0
  125. package/packages/config/dist/index.d.ts +131 -0
  126. package/packages/config/node_modules/.bin/jiti +17 -0
  127. package/packages/config/node_modules/.bin/tsc +17 -0
  128. package/packages/config/node_modules/.bin/tsserver +17 -0
  129. package/packages/config/node_modules/.bin/tsup +17 -0
  130. package/packages/config/node_modules/.bin/tsup-node +17 -0
  131. package/packages/config/node_modules/.bin/tsx +17 -0
  132. package/packages/config/package.json +21 -0
  133. package/packages/config/src/index.js +1 -0
  134. package/packages/config/src/index.ts +1282 -0
  135. package/packages/config/tsconfig.json +4 -0
  136. package/packages/rpc/.turbo/turbo-build.log +32 -0
  137. package/packages/rpc/dist/_esm-BCLXDO2R.cjs +3660 -0
  138. package/packages/rpc/dist/_esm-BCLXDO2R.cjs.map +1 -0
  139. package/packages/rpc/dist/ccip-OWJLAW55.cjs +16 -0
  140. package/packages/rpc/dist/ccip-OWJLAW55.cjs.map +1 -0
  141. package/packages/rpc/dist/chunk-APQIFZ3B.cjs +6247 -0
  142. package/packages/rpc/dist/chunk-APQIFZ3B.cjs.map +1 -0
  143. package/packages/rpc/dist/chunk-CDO2GWRD.cjs +410 -0
  144. package/packages/rpc/dist/chunk-CDO2GWRD.cjs.map +1 -0
  145. package/packages/rpc/dist/chunk-QGTNTFJ7.cjs +2249 -0
  146. package/packages/rpc/dist/chunk-QGTNTFJ7.cjs.map +1 -0
  147. package/packages/rpc/dist/chunk-TZDTAHWR.cjs +44 -0
  148. package/packages/rpc/dist/chunk-TZDTAHWR.cjs.map +1 -0
  149. package/packages/rpc/dist/index.cjs +7342 -0
  150. package/packages/rpc/dist/index.cjs.map +1 -0
  151. package/packages/rpc/dist/index.d.ts +3857 -0
  152. package/packages/rpc/dist/secp256k1-WCNM675D.cjs +18 -0
  153. package/packages/rpc/dist/secp256k1-WCNM675D.cjs.map +1 -0
  154. package/packages/rpc/node_modules/.bin/jiti +17 -0
  155. package/packages/rpc/node_modules/.bin/tsc +17 -0
  156. package/packages/rpc/node_modules/.bin/tsserver +17 -0
  157. package/packages/rpc/node_modules/.bin/tsup +17 -0
  158. package/packages/rpc/node_modules/.bin/tsup-node +17 -0
  159. package/packages/rpc/node_modules/.bin/tsx +17 -0
  160. package/packages/rpc/package.json +25 -0
  161. package/packages/rpc/src/index.ts +206 -0
  162. package/packages/rpc/tsconfig.json +4 -0
  163. package/packages/typescript/base.json +36 -0
  164. package/packages/typescript/nextjs.json +17 -0
  165. package/packages/typescript/package.json +10 -0
  166. package/packages/ui/.turbo/turbo-build.log +44 -0
  167. package/packages/ui/dist/chunk-MOAFBKSA.js +11 -0
  168. package/packages/ui/dist/chunk-MOAFBKSA.js.map +1 -0
  169. package/packages/ui/dist/components/badge.d.ts +12 -0
  170. package/packages/ui/dist/components/badge.js +31 -0
  171. package/packages/ui/dist/components/badge.js.map +1 -0
  172. package/packages/ui/dist/components/button.d.ts +13 -0
  173. package/packages/ui/dist/components/button.js +40 -0
  174. package/packages/ui/dist/components/button.js.map +1 -0
  175. package/packages/ui/dist/components/card.d.ts +10 -0
  176. package/packages/ui/dist/components/card.js +39 -0
  177. package/packages/ui/dist/components/card.js.map +1 -0
  178. package/packages/ui/dist/components/input.d.ts +5 -0
  179. package/packages/ui/dist/components/input.js +28 -0
  180. package/packages/ui/dist/components/input.js.map +1 -0
  181. package/packages/ui/dist/components/label.d.ts +5 -0
  182. package/packages/ui/dist/components/label.js +13 -0
  183. package/packages/ui/dist/components/label.js.map +1 -0
  184. package/packages/ui/dist/components/separator.d.ts +5 -0
  185. package/packages/ui/dist/components/separator.js +13 -0
  186. package/packages/ui/dist/components/separator.js.map +1 -0
  187. package/packages/ui/dist/components/textarea.d.ts +5 -0
  188. package/packages/ui/dist/components/textarea.js +27 -0
  189. package/packages/ui/dist/components/textarea.js.map +1 -0
  190. package/packages/ui/dist/tailwind.d.ts +56 -0
  191. package/packages/ui/dist/tailwind.js +60 -0
  192. package/packages/ui/dist/tailwind.js.map +1 -0
  193. package/packages/ui/dist/utils/cn.d.ts +5 -0
  194. package/packages/ui/dist/utils/cn.js +7 -0
  195. package/packages/ui/dist/utils/cn.js.map +1 -0
  196. package/packages/ui/node_modules/.bin/jiti +17 -0
  197. package/packages/ui/node_modules/.bin/tsc +17 -0
  198. package/packages/ui/node_modules/.bin/tsserver +17 -0
  199. package/packages/ui/node_modules/.bin/tsup +17 -0
  200. package/packages/ui/node_modules/.bin/tsup-node +17 -0
  201. package/packages/ui/node_modules/.bin/tsx +17 -0
  202. package/packages/ui/package.json +69 -0
  203. package/packages/ui/src/components/badge.tsx +27 -0
  204. package/packages/ui/src/components/button.tsx +40 -0
  205. package/packages/ui/src/components/card.tsx +31 -0
  206. package/packages/ui/src/components/input.tsx +21 -0
  207. package/packages/ui/src/components/label.tsx +6 -0
  208. package/packages/ui/src/components/separator.tsx +6 -0
  209. package/packages/ui/src/components/textarea.tsx +20 -0
  210. package/packages/ui/src/globals.css +70 -0
  211. package/packages/ui/src/tailwind.ts +56 -0
  212. package/packages/ui/src/utils/cn.ts +6 -0
  213. package/packages/ui/tsconfig.json +20 -0
  214. package/packages/ui/tsup.config.ts +20 -0
  215. package/pnpm-workspace.yaml +4 -0
  216. package/scripts/install-rust-binaries.mjs +84 -0
  217. package/scripts/launchd/install-user-daemon.sh +358 -0
  218. package/scripts/launchd/run-vault-daemon.sh +5 -0
  219. package/scripts/launchd/run-wlfi-agent-daemon.sh +73 -0
  220. package/scripts/launchd/uninstall-user-daemon.sh +103 -0
  221. package/src/cli.ts +2121 -0
  222. package/src/lib/admin-guard.js +1 -0
  223. package/src/lib/admin-guard.ts +185 -0
  224. package/src/lib/admin-passthrough.ts +33 -0
  225. package/src/lib/admin-reset.ts +751 -0
  226. package/src/lib/admin-setup.ts +1612 -0
  227. package/src/lib/agent-auth-clear.js +1 -0
  228. package/src/lib/agent-auth-clear.ts +58 -0
  229. package/src/lib/agent-auth-forwarding.js +1 -0
  230. package/src/lib/agent-auth-forwarding.ts +149 -0
  231. package/src/lib/agent-auth-migrate.js +1 -0
  232. package/src/lib/agent-auth-migrate.ts +150 -0
  233. package/src/lib/agent-auth-revoke.ts +103 -0
  234. package/src/lib/agent-auth-rotate.ts +107 -0
  235. package/src/lib/agent-auth-token.js +1 -0
  236. package/src/lib/agent-auth-token.ts +25 -0
  237. package/src/lib/agent-auth.ts +89 -0
  238. package/src/lib/asset-broadcast.js +1 -0
  239. package/src/lib/asset-broadcast.ts +285 -0
  240. package/src/lib/bootstrap-artifacts.js +1 -0
  241. package/src/lib/bootstrap-artifacts.ts +205 -0
  242. package/src/lib/bootstrap-credentials.js +1 -0
  243. package/src/lib/bootstrap-credentials.ts +832 -0
  244. package/src/lib/config-amounts.js +1 -0
  245. package/src/lib/config-amounts.ts +189 -0
  246. package/src/lib/config-mutation.ts +27 -0
  247. package/src/lib/fs-trust.js +1 -0
  248. package/src/lib/fs-trust.ts +537 -0
  249. package/src/lib/keychain.js +1 -0
  250. package/src/lib/keychain.ts +225 -0
  251. package/src/lib/local-admin-access.ts +106 -0
  252. package/src/lib/network-selection.js +1 -0
  253. package/src/lib/network-selection.ts +71 -0
  254. package/src/lib/passthrough-security.js +1 -0
  255. package/src/lib/passthrough-security.ts +114 -0
  256. package/src/lib/rpc-guard.js +1 -0
  257. package/src/lib/rpc-guard.ts +7 -0
  258. package/src/lib/rust-spawn-options.js +1 -0
  259. package/src/lib/rust-spawn-options.ts +98 -0
  260. package/src/lib/rust.js +1 -0
  261. package/src/lib/rust.ts +143 -0
  262. package/src/lib/signed-tx.js +1 -0
  263. package/src/lib/signed-tx.ts +116 -0
  264. package/src/lib/status-repair-cli.ts +116 -0
  265. package/src/lib/sudo.js +1 -0
  266. package/src/lib/sudo.ts +172 -0
  267. package/src/lib/vault-password-forwarding.js +1 -0
  268. package/src/lib/vault-password-forwarding.ts +155 -0
  269. package/src/lib/wallet-profile.js +1 -0
  270. package/src/lib/wallet-profile.ts +332 -0
  271. package/src/lib/wallet-repair.js +1 -0
  272. package/src/lib/wallet-repair.ts +304 -0
  273. package/src/lib/wallet-setup.js +1 -0
  274. package/src/lib/wallet-setup.ts +1466 -0
  275. package/src/lib/wallet-status.js +1 -0
  276. package/src/lib/wallet-status.ts +640 -0
  277. package/tsconfig.base.json +17 -0
  278. package/tsconfig.json +10 -0
  279. package/tsup.config.ts +25 -0
  280. package/turbo.json +41 -0
  281. package/LICENSE.md +0 -1
  282. package/dist/wlfa/index.cjs +0 -250
  283. package/dist/wlfa/index.d.cts +0 -1
  284. package/dist/wlfa/index.d.ts +0 -1
  285. package/dist/wlfa/index.js +0 -250
  286. package/dist/wlfc/index.cjs +0 -1839
  287. package/dist/wlfc/index.d.cts +0 -1
  288. package/dist/wlfc/index.d.ts +0 -1
  289. package/dist/wlfc/index.js +0 -1839
@@ -0,0 +1,6 @@
1
+ import * as React from 'react';
2
+ import { cn } from '../utils/cn';
3
+
4
+ export function Label({ className, ...props }: React.LabelHTMLAttributes<HTMLLabelElement>): React.JSX.Element {
5
+ return <label className={cn('text-sm font-medium leading-none', className)} {...props} />;
6
+ }
@@ -0,0 +1,6 @@
1
+ import * as React from 'react';
2
+ import { cn } from '../utils/cn';
3
+
4
+ export function Separator({ className, ...props }: React.HTMLAttributes<HTMLDivElement>): React.JSX.Element {
5
+ return <div className={cn('h-px w-full bg-border', className)} role="separator" {...props} />;
6
+ }
@@ -0,0 +1,20 @@
1
+ import * as React from 'react';
2
+ import { cn } from '../utils/cn';
3
+
4
+ const Textarea = React.forwardRef<HTMLTextAreaElement, React.TextareaHTMLAttributes<HTMLTextAreaElement>>(
5
+ ({ className, ...props }, ref) => {
6
+ return (
7
+ <textarea
8
+ className={cn(
9
+ 'flex min-h-[96px] w-full rounded-xl border border-input bg-background px-3 py-2 text-sm ring-offset-background placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50',
10
+ className
11
+ )}
12
+ ref={ref}
13
+ {...props}
14
+ />
15
+ );
16
+ }
17
+ );
18
+ Textarea.displayName = 'Textarea';
19
+
20
+ export { Textarea };
@@ -0,0 +1,70 @@
1
+ @tailwind base;
2
+ @tailwind components;
3
+ @tailwind utilities;
4
+
5
+ :root {
6
+ --background: 0 0% 100%;
7
+ --foreground: 222 47% 11%;
8
+ --card: 0 0% 100%;
9
+ --card-foreground: 222 47% 11%;
10
+ --primary: 45 93% 47%;
11
+ --primary-foreground: 222 47% 11%;
12
+ --secondary: 222 14% 96%;
13
+ --secondary-foreground: 222 47% 11%;
14
+ --accent: 210 40% 96%;
15
+ --accent-foreground: 222 47% 11%;
16
+ --muted: 210 40% 96%;
17
+ --muted-foreground: 215 16% 47%;
18
+ --destructive: 0 84% 60%;
19
+ --destructive-foreground: 0 0% 100%;
20
+ --success: 152 77% 39%;
21
+ --success-foreground: 0 0% 100%;
22
+ --warning: 34 100% 52%;
23
+ --warning-foreground: 222 47% 11%;
24
+ --border: 214 32% 91%;
25
+ --input: 214 32% 91%;
26
+ --ring: 45 93% 47%;
27
+ }
28
+
29
+ .dark {
30
+ --background: 222 47% 7%;
31
+ --foreground: 210 40% 98%;
32
+ --card: 224 38% 11%;
33
+ --card-foreground: 210 40% 98%;
34
+ --primary: 45 93% 47%;
35
+ --primary-foreground: 222 47% 11%;
36
+ --secondary: 217 33% 17%;
37
+ --secondary-foreground: 210 40% 98%;
38
+ --accent: 217 33% 17%;
39
+ --accent-foreground: 210 40% 98%;
40
+ --muted: 217 33% 17%;
41
+ --muted-foreground: 215 20% 65%;
42
+ --destructive: 0 63% 44%;
43
+ --destructive-foreground: 210 40% 98%;
44
+ --success: 152 77% 39%;
45
+ --success-foreground: 210 40% 98%;
46
+ --warning: 34 100% 52%;
47
+ --warning-foreground: 222 47% 11%;
48
+ --border: 217 33% 20%;
49
+ --input: 217 33% 20%;
50
+ --ring: 45 93% 47%;
51
+ }
52
+
53
+ * {
54
+ @apply border-border;
55
+ }
56
+
57
+ html {
58
+ color-scheme: light dark;
59
+ }
60
+
61
+ body {
62
+ @apply min-h-screen bg-background text-foreground antialiased;
63
+ background-image:
64
+ radial-gradient(circle at top, rgba(255, 209, 70, 0.12), transparent 34%),
65
+ linear-gradient(180deg, rgba(15, 23, 42, 0.04), transparent 30%);
66
+ }
67
+
68
+ a {
69
+ @apply text-primary transition-colors hover:text-primary/80;
70
+ }
@@ -0,0 +1,56 @@
1
+ const tailwindPreset = {
2
+ darkMode: ['class'],
3
+ content: [],
4
+ theme: {
5
+ extend: {
6
+ borderRadius: {
7
+ xl: '1rem',
8
+ '2xl': '1.25rem'
9
+ },
10
+ boxShadow: {
11
+ soft: '0 16px 40px -20px rgba(0, 0, 0, 0.35)'
12
+ },
13
+ colors: {
14
+ border: 'hsl(var(--border))',
15
+ input: 'hsl(var(--input))',
16
+ ring: 'hsl(var(--ring))',
17
+ background: 'hsl(var(--background))',
18
+ foreground: 'hsl(var(--foreground))',
19
+ muted: {
20
+ DEFAULT: 'hsl(var(--muted))',
21
+ foreground: 'hsl(var(--muted-foreground))'
22
+ },
23
+ primary: {
24
+ DEFAULT: 'hsl(var(--primary))',
25
+ foreground: 'hsl(var(--primary-foreground))'
26
+ },
27
+ secondary: {
28
+ DEFAULT: 'hsl(var(--secondary))',
29
+ foreground: 'hsl(var(--secondary-foreground))'
30
+ },
31
+ accent: {
32
+ DEFAULT: 'hsl(var(--accent))',
33
+ foreground: 'hsl(var(--accent-foreground))'
34
+ },
35
+ destructive: {
36
+ DEFAULT: 'hsl(var(--destructive))',
37
+ foreground: 'hsl(var(--destructive-foreground))'
38
+ },
39
+ success: {
40
+ DEFAULT: 'hsl(var(--success))',
41
+ foreground: 'hsl(var(--success-foreground))'
42
+ },
43
+ warning: {
44
+ DEFAULT: 'hsl(var(--warning))',
45
+ foreground: 'hsl(var(--warning-foreground))'
46
+ },
47
+ card: {
48
+ DEFAULT: 'hsl(var(--card))',
49
+ foreground: 'hsl(var(--card-foreground))'
50
+ }
51
+ }
52
+ }
53
+ }
54
+ };
55
+
56
+ export default tailwindPreset;
@@ -0,0 +1,6 @@
1
+ import { clsx, type ClassValue } from 'clsx';
2
+ import { twMerge } from 'tailwind-merge';
3
+
4
+ export function cn(...inputs: ClassValue[]): string {
5
+ return twMerge(clsx(inputs));
6
+ }
@@ -0,0 +1,20 @@
1
+ {
2
+ "extends": "../typescript/base.json",
3
+ "compilerOptions": {
4
+ "rootDir": "src",
5
+ "outDir": "dist",
6
+ "jsx": "react-jsx",
7
+ "lib": [
8
+ "dom",
9
+ "dom.iterable",
10
+ "es2022"
11
+ ],
12
+ "types": [
13
+ "react",
14
+ "react-dom"
15
+ ]
16
+ },
17
+ "include": [
18
+ "src/**/*"
19
+ ]
20
+ }
@@ -0,0 +1,20 @@
1
+ import { defineConfig } from 'tsup';
2
+
3
+ export default defineConfig({
4
+ entry: [
5
+ 'src/tailwind.ts',
6
+ 'src/utils/cn.ts',
7
+ 'src/components/badge.tsx',
8
+ 'src/components/button.tsx',
9
+ 'src/components/card.tsx',
10
+ 'src/components/input.tsx',
11
+ 'src/components/label.tsx',
12
+ 'src/components/separator.tsx',
13
+ 'src/components/textarea.tsx'
14
+ ],
15
+ format: ['esm'],
16
+ dts: true,
17
+ sourcemap: true,
18
+ clean: true,
19
+ external: ['react', 'react-dom']
20
+ });
@@ -0,0 +1,4 @@
1
+ packages:
2
+ - packages/*
3
+ - apps/*
4
+ - apps/maintenance/*
@@ -0,0 +1,84 @@
1
+ import fs from 'node:fs';
2
+ import os from 'node:os';
3
+ import path from 'node:path';
4
+ import { spawnSync } from 'node:child_process';
5
+
6
+ if (process.env.WLFI_SKIP_RUST_INSTALL === '1') {
7
+ process.exit(0);
8
+ }
9
+
10
+ const repoRoot = new URL('..', import.meta.url).pathname;
11
+ const wlfiHome = process.env.WLFI_HOME?.trim() || path.join(os.homedir(), '.wlfi_agent');
12
+ const binDir = path.join(wlfiHome, 'bin');
13
+ const extension = process.platform === 'win32' ? '.exe' : '';
14
+ const rustBins = [
15
+ 'wlfi-agent-daemon',
16
+ 'wlfi-agent-admin',
17
+ 'wlfi-agent-agent',
18
+ 'wlfi-agent-system-keychain'
19
+ ];
20
+ const helperScripts = [
21
+ {
22
+ source: path.join(repoRoot, 'scripts', 'launchd', 'run-wlfi-agent-daemon.sh'),
23
+ destination: path.join(binDir, 'run-wlfi-agent-daemon.sh')
24
+ }
25
+ ];
26
+
27
+ fs.mkdirSync(binDir, { recursive: true, mode: 0o700 });
28
+ const cargo = spawnSync('cargo', ['--version'], { cwd: repoRoot, stdio: 'pipe' });
29
+ if (cargo.status !== 0) {
30
+ console.warn('[wlfi-agent] cargo was not found; skipping Rust binary installation');
31
+ console.warn('[wlfi-agent] install Rust from https://rustup.rs and rerun `npm run install:rust-binaries`.');
32
+ process.exit(0);
33
+ }
34
+
35
+ const build = spawnSync(
36
+ 'cargo',
37
+ [
38
+ 'build',
39
+ '--release',
40
+ '-p',
41
+ 'wlfi-agent-daemon',
42
+ '-p',
43
+ 'wlfi-agent-admin',
44
+ '-p',
45
+ 'wlfi-agent-agent'
46
+ ],
47
+ { cwd: repoRoot, stdio: 'inherit' }
48
+ );
49
+ if (build.status !== 0) {
50
+ process.exit(build.status ?? 1);
51
+ }
52
+
53
+ for (const binary of rustBins) {
54
+ const source = path.join(repoRoot, 'target', 'release', binary + extension);
55
+ const destination = path.join(binDir, binary + extension);
56
+ fs.copyFileSync(source, destination);
57
+ if (process.platform !== 'win32') {
58
+ fs.chmodSync(destination, 0o755);
59
+ }
60
+ }
61
+
62
+ for (const script of helperScripts) {
63
+ fs.copyFileSync(script.source, script.destination);
64
+ if (process.platform !== 'win32') {
65
+ fs.chmodSync(script.destination, 0o755);
66
+ }
67
+ }
68
+
69
+ const configPath = path.join(wlfiHome, 'config.json');
70
+ if (!fs.existsSync(configPath)) {
71
+ fs.writeFileSync(
72
+ configPath,
73
+ JSON.stringify(
74
+ {
75
+ daemonSocket: path.join(wlfiHome, 'daemon.sock'),
76
+ stateFile: path.join(wlfiHome, 'daemon-state.enc'),
77
+ rustBinDir: binDir
78
+ },
79
+ null,
80
+ 2
81
+ ) + '\n',
82
+ { mode: 0o600 }
83
+ );
84
+ }
@@ -0,0 +1,358 @@
1
+ #!/usr/bin/env bash
2
+ set -euo pipefail
3
+
4
+ usage() {
5
+ cat <<'EOF2'
6
+ Install or replace the WLFI Agent root LaunchDaemon.
7
+
8
+ Usage:
9
+ install-user-daemon.sh [options]
10
+
11
+ Options:
12
+ --label <label> LaunchDaemon label (default: com.wlfi.agent.daemon)
13
+ --runner <path> LaunchDaemon runner script path (required)
14
+ --daemon-bin <path> Rust daemon binary path (required)
15
+ --keychain-helper <path> Rust helper path for daemon System.keychain access (required)
16
+ --state-file <path> Encrypted daemon state path (required)
17
+ --daemon-socket <path> Daemon unix socket path (required)
18
+ --keychain-service <name> Keychain service (default: wlfi-agent-daemon-password)
19
+ --keychain-account <name> Keychain account (required)
20
+ --signer-backend <kind> Signer backend for daemon (default: software)
21
+ --allow-admin-euid <uid> Allowed admin client uid (required)
22
+ --allow-agent-euid <uid> Allowed agent client uid (required)
23
+ Environment:
24
+ WLFI_RELAY_DAEMON_TOKEN Optional relay auth token to store in a root-only daemon file
25
+ --vault-password-stdin Read vault password from stdin and store it in System.keychain
26
+ --help Show this help
27
+ EOF2
28
+ }
29
+
30
+ require_non_empty_value() {
31
+ local flag="$1"
32
+ local value="${2:-}"
33
+ if [[ -z "$value" ]]; then
34
+ echo "missing value for $flag" >&2
35
+ exit 1
36
+ fi
37
+ }
38
+
39
+ validate_label() {
40
+ local value="$1"
41
+ if [[ ! "$value" =~ ^[A-Za-z0-9._-]+$ ]]; then
42
+ echo "invalid --label '$value': allowed characters are [A-Za-z0-9._-]" >&2
43
+ exit 1
44
+ fi
45
+ }
46
+
47
+ read_secret_from_stdin() {
48
+ local label="$1"
49
+ local raw
50
+ raw="$(cat)"
51
+ raw="${raw%$'\n'}"
52
+ raw="${raw%$'\r'}"
53
+ if [[ -z "${raw//[[:space:]]/}" ]]; then
54
+ echo "$label must not be empty or whitespace" >&2
55
+ exit 1
56
+ fi
57
+ printf '%s' "$raw"
58
+ }
59
+
60
+ require_regular_executable() {
61
+ local label="$1"
62
+ local target="$2"
63
+
64
+ if [[ -L "$target" ]]; then
65
+ echo "$label must not be a symlink: $target" >&2
66
+ exit 1
67
+ fi
68
+ if [[ ! -f "$target" ]]; then
69
+ echo "$label must be a regular file: $target" >&2
70
+ exit 1
71
+ fi
72
+ if [[ ! -x "$target" ]]; then
73
+ echo "$label is not executable: $target" >&2
74
+ exit 1
75
+ fi
76
+ }
77
+
78
+ install_private_file() {
79
+ local label="$1"
80
+ local target="$2"
81
+ local value="$3"
82
+ local temp_target="${target}.tmp.$$"
83
+
84
+ if [[ -L "$target" ]]; then
85
+ echo "$label must not be a symlink: $target" >&2
86
+ exit 1
87
+ fi
88
+ if [[ -e "$target" && ! -f "$target" ]]; then
89
+ echo "$label must be a regular file: $target" >&2
90
+ exit 1
91
+ fi
92
+
93
+ printf '%s' "$value" > "$temp_target"
94
+ chmod 600 "$temp_target"
95
+ chown root:wheel "$temp_target"
96
+ mv -f "$temp_target" "$target"
97
+ }
98
+
99
+ if [[ "$(uname -s)" != "Darwin" ]]; then
100
+ echo "install-user-daemon.sh supports macOS launchd only" >&2
101
+ exit 1
102
+ fi
103
+
104
+ if [[ "$(id -u)" -ne 0 ]]; then
105
+ echo "install-user-daemon.sh must be run as root" >&2
106
+ exit 1
107
+ fi
108
+
109
+ label="com.wlfi.agent.daemon"
110
+ runner=""
111
+ daemon_bin=""
112
+ keychain_helper=""
113
+ state_file=""
114
+ daemon_socket=""
115
+ keychain_service="wlfi-agent-daemon-password"
116
+ keychain_account=""
117
+ signer_backend="software"
118
+ allow_admin_euid=""
119
+ allow_agent_euid=""
120
+ vault_password_stdin=false
121
+
122
+ while [[ $# -gt 0 ]]; do
123
+ case "$1" in
124
+ --label)
125
+ require_non_empty_value "$1" "${2:-}"
126
+ label="$2"
127
+ shift 2
128
+ ;;
129
+ --runner)
130
+ require_non_empty_value "$1" "${2:-}"
131
+ runner="$2"
132
+ shift 2
133
+ ;;
134
+ --daemon-bin)
135
+ require_non_empty_value "$1" "${2:-}"
136
+ daemon_bin="$2"
137
+ shift 2
138
+ ;;
139
+ --keychain-helper)
140
+ require_non_empty_value "$1" "${2:-}"
141
+ keychain_helper="$2"
142
+ shift 2
143
+ ;;
144
+ --state-file)
145
+ require_non_empty_value "$1" "${2:-}"
146
+ state_file="$2"
147
+ shift 2
148
+ ;;
149
+ --daemon-socket)
150
+ require_non_empty_value "$1" "${2:-}"
151
+ daemon_socket="$2"
152
+ shift 2
153
+ ;;
154
+ --keychain-service)
155
+ require_non_empty_value "$1" "${2:-}"
156
+ keychain_service="$2"
157
+ shift 2
158
+ ;;
159
+ --keychain-account)
160
+ require_non_empty_value "$1" "${2:-}"
161
+ keychain_account="$2"
162
+ shift 2
163
+ ;;
164
+ --signer-backend)
165
+ require_non_empty_value "$1" "${2:-}"
166
+ signer_backend="$2"
167
+ shift 2
168
+ ;;
169
+ --allow-admin-euid)
170
+ require_non_empty_value "$1" "${2:-}"
171
+ allow_admin_euid="$2"
172
+ shift 2
173
+ ;;
174
+ --allow-agent-euid)
175
+ require_non_empty_value "$1" "${2:-}"
176
+ allow_agent_euid="$2"
177
+ shift 2
178
+ ;;
179
+ --vault-password-stdin)
180
+ vault_password_stdin=true
181
+ shift
182
+ ;;
183
+ --help|-h)
184
+ usage
185
+ exit 0
186
+ ;;
187
+ *)
188
+ echo "unknown argument: $1" >&2
189
+ usage >&2
190
+ exit 1
191
+ ;;
192
+ esac
193
+ done
194
+
195
+ validate_label "$label"
196
+ require_non_empty_value "--runner" "$runner"
197
+ require_non_empty_value "--daemon-bin" "$daemon_bin"
198
+ require_non_empty_value "--keychain-helper" "$keychain_helper"
199
+ require_non_empty_value "--state-file" "$state_file"
200
+ require_non_empty_value "--daemon-socket" "$daemon_socket"
201
+ require_non_empty_value "--keychain-account" "$keychain_account"
202
+ require_non_empty_value "--allow-admin-euid" "$allow_admin_euid"
203
+ require_non_empty_value "--allow-agent-euid" "$allow_agent_euid"
204
+
205
+ if [[ ! -x "$runner" ]]; then
206
+ echo "runner is not executable: $runner" >&2
207
+ exit 1
208
+ fi
209
+ if [[ ! -x "$daemon_bin" ]]; then
210
+ echo "daemon binary is not executable: $daemon_bin" >&2
211
+ exit 1
212
+ fi
213
+ if [[ ! -x "$keychain_helper" ]]; then
214
+ echo "keychain helper is not executable: $keychain_helper" >&2
215
+ exit 1
216
+ fi
217
+
218
+ if [[ "$vault_password_stdin" != true ]]; then
219
+ echo "install-user-daemon.sh requires --vault-password-stdin" >&2
220
+ exit 1
221
+ fi
222
+
223
+ vault_password="$(read_secret_from_stdin 'vault password')"
224
+ trap 'unset vault_password' EXIT
225
+ relay_daemon_token="${WLFI_RELAY_DAEMON_TOKEN:-}"
226
+
227
+ launch_daemons_dir="/Library/LaunchDaemons"
228
+ plist_path="${launch_daemons_dir}/${label}.plist"
229
+ log_dir="/var/log/wlfi-agent"
230
+ stdout_log="${log_dir}/${label}.out.log"
231
+ stderr_log="${log_dir}/${label}.err.log"
232
+ managed_bin_dir="/Library/WLFI/bin"
233
+ managed_runner="${managed_bin_dir}/run-wlfi-agent-daemon.sh"
234
+ managed_daemon_bin="${managed_bin_dir}/$(basename "$daemon_bin")"
235
+ managed_keychain_helper="${managed_bin_dir}/$(basename "$keychain_helper")"
236
+ state_dir="$(dirname "$state_file")"
237
+ socket_dir="$(dirname "$daemon_socket")"
238
+ relay_token_file="${state_dir}/relay-daemon-token"
239
+
240
+ require_regular_executable "runner" "$runner"
241
+ require_regular_executable "daemon binary" "$daemon_bin"
242
+ require_regular_executable "keychain helper" "$keychain_helper"
243
+
244
+ mkdir -p "$launch_daemons_dir" "$log_dir" "$managed_bin_dir" "$state_dir" "$socket_dir"
245
+ chmod 755 "$launch_daemons_dir"
246
+ chmod 755 "$managed_bin_dir"
247
+ chmod 700 "$log_dir" "$state_dir"
248
+ chmod 755 "$socket_dir"
249
+ chown root:wheel "$log_dir" "$managed_bin_dir" "$state_dir" "$socket_dir"
250
+
251
+ temp_runner="${managed_runner}.tmp.$$"
252
+ temp_daemon_bin="${managed_daemon_bin}.tmp.$$"
253
+ temp_keychain_helper="${managed_keychain_helper}.tmp.$$"
254
+ temp_relay_token_file="${relay_token_file}.tmp.$$"
255
+ trap 'rm -f "$temp_runner" "$temp_daemon_bin" "$temp_keychain_helper" "$temp_relay_token_file"; unset vault_password relay_daemon_token' EXIT
256
+
257
+ install -o root -g wheel -m 755 "$runner" "$temp_runner"
258
+ install -o root -g wheel -m 755 "$daemon_bin" "$temp_daemon_bin"
259
+ install -o root -g wheel -m 700 "$keychain_helper" "$temp_keychain_helper"
260
+ mv -f "$temp_runner" "$managed_runner"
261
+ mv -f "$temp_daemon_bin" "$managed_daemon_bin"
262
+ mv -f "$temp_keychain_helper" "$managed_keychain_helper"
263
+
264
+ if [[ -n "$relay_daemon_token" ]]; then
265
+ install_private_file "relay daemon token file" "$relay_token_file" "$relay_daemon_token"
266
+ else
267
+ rm -f "$relay_token_file"
268
+ fi
269
+
270
+ "$managed_keychain_helper" replace-generic-password \
271
+ --keychain /Library/Keychains/System.keychain \
272
+ --service "$keychain_service" \
273
+ --account "$keychain_account" \
274
+ --password-stdin <<<"$vault_password"
275
+
276
+ cat > "$plist_path" <<EOF2
277
+ <?xml version="1.0" encoding="UTF-8"?>
278
+ <!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
279
+ <plist version="1.0">
280
+ <dict>
281
+ <key>Label</key>
282
+ <string>${label}</string>
283
+ <key>ProgramArguments</key>
284
+ <array>
285
+ <string>${managed_runner}</string>
286
+ </array>
287
+ <key>EnvironmentVariables</key>
288
+ <dict>
289
+ <key>WLFI_DAEMON_BIN</key>
290
+ <string>${managed_daemon_bin}</string>
291
+ <key>WLFI_STATE_FILE</key>
292
+ <string>${state_file}</string>
293
+ <key>WLFI_DAEMON_SOCKET</key>
294
+ <string>${daemon_socket}</string>
295
+ <key>WLFI_KEYCHAIN_SERVICE</key>
296
+ <string>${keychain_service}</string>
297
+ <key>WLFI_KEYCHAIN_ACCOUNT</key>
298
+ <string>${keychain_account}</string>
299
+ <key>WLFI_KEYCHAIN_HELPER</key>
300
+ <string>${managed_keychain_helper}</string>
301
+ <key>WLFI_SIGNER_BACKEND</key>
302
+ <string>${signer_backend}</string>
303
+ <key>WLFI_ALLOW_ADMIN_EUID</key>
304
+ <string>${allow_admin_euid}</string>
305
+ <key>WLFI_ALLOW_AGENT_EUID</key>
306
+ <string>${allow_agent_euid}</string>
307
+ EOF2
308
+
309
+ if [[ -n "$relay_daemon_token" ]]; then
310
+ cat >> "$plist_path" <<EOF2
311
+ <key>WLFI_RELAY_DAEMON_TOKEN_FILE</key>
312
+ <string>${relay_token_file}</string>
313
+ EOF2
314
+ fi
315
+
316
+ cat >> "$plist_path" <<EOF2
317
+ </dict>
318
+ <key>RunAtLoad</key>
319
+ <true/>
320
+ <key>KeepAlive</key>
321
+ <true/>
322
+ <key>WorkingDirectory</key>
323
+ <string>${state_dir}</string>
324
+ <key>StandardOutPath</key>
325
+ <string>${stdout_log}</string>
326
+ <key>StandardErrorPath</key>
327
+ <string>${stderr_log}</string>
328
+ </dict>
329
+ </plist>
330
+ EOF2
331
+ chmod 644 "$plist_path"
332
+ chown root:wheel "$plist_path"
333
+
334
+ launchctl bootout system/${label} >/dev/null 2>&1 || true
335
+ launchctl enable system/${label} >/dev/null 2>&1 || true
336
+ launchctl bootstrap system "$plist_path"
337
+ launchctl enable system/${label} >/dev/null 2>&1 || true
338
+ launchctl kickstart -k system/${label} >/dev/null 2>&1 || true
339
+
340
+ cat <<EOF2
341
+ installed launch daemon:
342
+ label: ${label}
343
+ plist: ${plist_path}
344
+ runner: ${managed_runner}
345
+ daemon bin: ${managed_daemon_bin}
346
+ keychain helper: ${managed_keychain_helper}
347
+ daemon socket: ${daemon_socket}
348
+ state file: ${state_file}
349
+ signer backend: ${signer_backend}
350
+ keychain service: ${keychain_service}
351
+ keychain account: ${keychain_account}
352
+ EOF2
353
+
354
+ if [[ -n "$relay_daemon_token" ]]; then
355
+ cat <<EOF2
356
+ relay daemon token file: ${relay_token_file}
357
+ EOF2
358
+ fi
@@ -0,0 +1,5 @@
1
+ #!/usr/bin/env bash
2
+ set -euo pipefail
3
+
4
+ script_dir="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
5
+ exec "${script_dir}/run-wlfi-agent-daemon.sh" "$@"