facult 2.17.1 → 2.17.3

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.
@@ -40,7 +40,20 @@ Use the narrow setup command for normal installs:
40
40
  fclt setup codex-plugin
41
41
  ```
42
42
 
43
- That updates only the local `fclt` plugin payload under `~/plugins/fclt`, merges the `hack-local` marketplace entry at `~/.agents/plugins/marketplace.json`, and runs `codex plugin add fclt@hack-local --json` when the `codex` command is available. It does not enter managed mode, adopt Codex state, render `~/.codex/AGENTS.md`, or touch existing Codex skills/rules/config.
43
+ That updates only the local `fclt` plugin payload under `~/plugins/fclt`
44
+ and merges an entry into `~/.agents/plugins/marketplace.json`. The default
45
+ marketplace name is `hack-local`; if the marketplace file already has a
46
+ non-empty `name`, fclt preserves it and installs from that name. The generated
47
+ entry uses Codex schema-valid policy values, including
48
+ `installation: "AVAILABLE"` and `authentication: "ON_INSTALL"`.
49
+
50
+ When the `codex` command is available, setup runs
51
+ `codex plugin add fclt@<marketplace> --json`. Codex installs the plugin cache
52
+ under `~/.codex/plugins/cache/<marketplace>/fclt/` using its own version
53
+ directory.
54
+
55
+ It does not enter managed mode, adopt Codex state, render
56
+ `~/.codex/AGENTS.md`, or touch existing Codex skills/rules/config.
44
57
 
45
58
  Useful flags:
46
59
 
package/docs/reference.md CHANGED
@@ -74,7 +74,11 @@ fclt managed
74
74
  fclt unmanage <tool>
75
75
  ```
76
76
 
77
- `setup codex-plugin` is the narrow path for exposing the bundled fclt Codex plugin without entering managed mode. Managed mode writes rendered output into tool homes. Read [Managed mode](./managed-mode.md) before using it on an existing setup.
77
+ `setup codex-plugin` is the narrow path for exposing the bundled fclt Codex
78
+ plugin without entering managed mode. It writes only `~/plugins/fclt`, the
79
+ local marketplace entry, and the Codex plugin install/cache when Codex is
80
+ available. Managed mode writes rendered output into tool homes. Read
81
+ [Managed mode](./managed-mode.md) before using it on an existing setup.
78
82
 
79
83
  ## Writeback and evolution
80
84
 
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "facult",
3
- "version": "2.17.1",
3
+ "version": "2.17.3",
4
4
  "description": "Manage canonical AI capabilities, sync surfaces, and evolution state.",
5
5
  "type": "module",
6
6
  "license": "MIT",
package/src/ai.ts CHANGED
@@ -599,6 +599,7 @@ async function resolveAssetSelection(args: {
599
599
  homeDir: string;
600
600
  rootDir: string;
601
601
  asset: string;
602
+ repairGraph?: boolean;
602
603
  }): Promise<{
603
604
  assetRef?: string;
604
605
  assetId?: string;
@@ -607,7 +608,7 @@ async function resolveAssetSelection(args: {
607
608
  await ensureAiGraphPath({
608
609
  homeDir: args.homeDir,
609
610
  rootDir: args.rootDir,
610
- repair: true,
611
+ repair: args.repairGraph,
611
612
  });
612
613
  const graph = await loadGraph({
613
614
  homeDir: args.homeDir,
@@ -1123,11 +1124,13 @@ export async function assessEvolution(args: {
1123
1124
  homeDir,
1124
1125
  rootDir: args.rootDir,
1125
1126
  asset: args.asset,
1127
+ repairGraph: false,
1126
1128
  })
1127
1129
  : null;
1128
1130
  const target = filterAsset?.assetRef ?? args.asset;
1129
1131
  const writebacks = (await listWritebacks({ homeDir, rootDir: args.rootDir }))
1130
1132
  .filter((entry) => entry.status !== "dismissed")
1133
+ .filter((entry) => entry.status !== "resolved")
1131
1134
  .filter((entry) => entry.status !== "superseded")
1132
1135
  .filter((entry) => entry.evidence.length > 0)
1133
1136
  .filter((entry) => {
package/src/manage.ts CHANGED
@@ -368,7 +368,7 @@ function fcltCodexMarketplaceEntry(): Record<string, unknown> {
368
368
  },
369
369
  policy: {
370
370
  installation: "AVAILABLE",
371
- authentication: "NONE",
371
+ authentication: "ON_INSTALL",
372
372
  },
373
373
  category: "Productivity",
374
374
  };