securityclaw 0.0.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 (62) hide show
  1. package/CHANGELOG.md +49 -0
  2. package/LICENSE +21 -0
  3. package/README.md +135 -0
  4. package/README.zh-CN.md +135 -0
  5. package/admin/public/app.js +148 -0
  6. package/admin/public/favicon.svg +21 -0
  7. package/admin/public/index.html +31 -0
  8. package/admin/public/styles.css +2715 -0
  9. package/admin/server.ts +1053 -0
  10. package/bin/install-lib.mjs +88 -0
  11. package/bin/securityclaw.mjs +66 -0
  12. package/config/policy.default.yaml +520 -0
  13. package/index.ts +2662 -0
  14. package/install.sh +22 -0
  15. package/openclaw.plugin.json +60 -0
  16. package/package.json +69 -0
  17. package/src/admin/build.ts +113 -0
  18. package/src/admin/console_notice.ts +195 -0
  19. package/src/admin/dashboard_url_state.ts +80 -0
  20. package/src/admin/openclaw_session_catalog.ts +137 -0
  21. package/src/admin/runtime_guard.ts +51 -0
  22. package/src/admin/skill_interception_store.ts +1606 -0
  23. package/src/application/commands/approval_commands.ts +189 -0
  24. package/src/approvals/chat_approval_store.ts +433 -0
  25. package/src/config/live_config.ts +144 -0
  26. package/src/config/loader.ts +168 -0
  27. package/src/config/runtime_override.ts +66 -0
  28. package/src/config/strategy_store.ts +121 -0
  29. package/src/config/validator.ts +222 -0
  30. package/src/domain/models/resource_context.ts +31 -0
  31. package/src/domain/ports/approval_repository.ts +40 -0
  32. package/src/domain/ports/notification_port.ts +29 -0
  33. package/src/domain/ports/openclaw_adapter.ts +22 -0
  34. package/src/domain/services/account_policy_engine.ts +163 -0
  35. package/src/domain/services/approval_service.ts +336 -0
  36. package/src/domain/services/approval_subject_resolver.ts +37 -0
  37. package/src/domain/services/context_inference_service.ts +502 -0
  38. package/src/domain/services/file_rule_registry.ts +171 -0
  39. package/src/domain/services/formatting_service.ts +101 -0
  40. package/src/domain/services/path_candidate_inference.ts +111 -0
  41. package/src/domain/services/sensitive_path_registry.ts +288 -0
  42. package/src/domain/services/sensitivity_label_inference.ts +161 -0
  43. package/src/domain/services/shell_filesystem_inference.ts +360 -0
  44. package/src/engine/approval_fsm.ts +104 -0
  45. package/src/engine/decision_engine.ts +39 -0
  46. package/src/engine/dlp_engine.ts +91 -0
  47. package/src/engine/rule_engine.ts +208 -0
  48. package/src/events/emitter.ts +86 -0
  49. package/src/events/schema.ts +27 -0
  50. package/src/hooks/context_guard.ts +36 -0
  51. package/src/hooks/output_guard.ts +66 -0
  52. package/src/hooks/persist_guard.ts +69 -0
  53. package/src/hooks/policy_guard.ts +222 -0
  54. package/src/hooks/result_guard.ts +88 -0
  55. package/src/i18n/locale.ts +36 -0
  56. package/src/index.ts +255 -0
  57. package/src/infrastructure/adapters/notification_adapter.ts +173 -0
  58. package/src/infrastructure/adapters/openclaw_adapter_impl.ts +59 -0
  59. package/src/infrastructure/config/plugin_config_parser.ts +105 -0
  60. package/src/monitoring/status_store.ts +612 -0
  61. package/src/types.ts +409 -0
  62. package/src/utils.ts +97 -0
@@ -0,0 +1,51 @@
1
+ const TRUTHY_VALUES = new Set(["1", "true", "yes", "on"]);
2
+ const SUPERVISOR_HINT_KEYS = [
3
+ "OPENCLAW_LAUNCHD_LABEL",
4
+ "LAUNCH_JOB_LABEL",
5
+ "LAUNCH_JOB_NAME",
6
+ "XPC_SERVICE_NAME",
7
+ "OPENCLAW_SYSTEMD_UNIT",
8
+ "INVOCATION_ID",
9
+ "SYSTEMD_EXEC_PID",
10
+ "JOURNAL_STREAM",
11
+ "OPENCLAW_WINDOWS_TASK_NAME"
12
+ ] as const;
13
+
14
+ type AutoStartDecision = {
15
+ enabled: boolean;
16
+ reason:
17
+ | "forced"
18
+ | "gateway-service"
19
+ | "gateway-supervisor"
20
+ | "non-persistent-runtime";
21
+ };
22
+
23
+ function hasText(value: string | undefined): boolean {
24
+ return typeof value === "string" && value.trim().length > 0;
25
+ }
26
+
27
+ function isTruthy(value: string | undefined): boolean {
28
+ return hasText(value) && TRUTHY_VALUES.has(value!.trim().toLowerCase());
29
+ }
30
+
31
+ function hasSupervisorHints(env: NodeJS.ProcessEnv): boolean {
32
+ return SUPERVISOR_HINT_KEYS.some((key) => hasText(env[key]));
33
+ }
34
+
35
+ export function shouldAutoStartAdminServer(env: NodeJS.ProcessEnv = process.env): AutoStartDecision {
36
+ if (isTruthy(env.SECURITYCLAW_ADMIN_AUTOSTART_FORCE)) {
37
+ return { enabled: true, reason: "forced" };
38
+ }
39
+
40
+ const serviceKind = env.OPENCLAW_SERVICE_KIND?.trim().toLowerCase();
41
+ const serviceMarker = env.OPENCLAW_SERVICE_MARKER?.trim();
42
+ if (serviceMarker && serviceKind === "gateway") {
43
+ return { enabled: true, reason: "gateway-service" };
44
+ }
45
+
46
+ if (serviceKind === "gateway" && hasSupervisorHints(env)) {
47
+ return { enabled: true, reason: "gateway-supervisor" };
48
+ }
49
+
50
+ return { enabled: false, reason: "non-persistent-runtime" };
51
+ }