@pensar/apex 0.0.92-canary.1e2cfc8f → 0.0.92

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 (2) hide show
  1. package/build/index.js +23 -13
  2. package/package.json +1 -1
package/build/index.js CHANGED
@@ -31880,6 +31880,12 @@ var init_openrouter = __esm(() => {
31880
31880
  var PENSAR_MODELS;
31881
31881
  var init_pensar = __esm(() => {
31882
31882
  PENSAR_MODELS = [
31883
+ {
31884
+ id: "pensar:anthropic.claude-opus-4-6-v1",
31885
+ name: "Claude Opus 4.6 (Pensar)",
31886
+ provider: "pensar",
31887
+ contextLength: 200000
31888
+ },
31883
31889
  {
31884
31890
  id: "pensar:anthropic.claude-sonnet-4-5-20250929-v1:0",
31885
31891
  name: "Claude Sonnet 4.5 (Pensar)",
@@ -31971,7 +31977,7 @@ var package_default2;
31971
31977
  var init_package = __esm(() => {
31972
31978
  package_default2 = {
31973
31979
  name: "@pensar/apex",
31974
- version: "0.0.92-canary.1e2cfc8f",
31980
+ version: "0.0.92",
31975
31981
  description: "AI-powered penetration testing CLI tool with terminal UI",
31976
31982
  module: "src/tui/index.tsx",
31977
31983
  main: "build/index.js",
@@ -32165,6 +32171,7 @@ async function get() {
32165
32171
  inceptionAPIKey: process.env.INCEPTION_API_KEY ?? parsedConfig.inceptionAPIKey,
32166
32172
  bedrockAPIKey: process.env.BEDROCK_API_KEY ?? parsedConfig.bedrockAPIKey,
32167
32173
  pensarAPIKey: process.env.PENSAR_API_KEY ?? parsedConfig.pensarAPIKey,
32174
+ pensarApiUrl: process.env.PENSAR_API_URL ?? parsedConfig.pensarApiUrl,
32168
32175
  daytonaAPIKey: process.env.DAYTONA_API_KEY ?? parsedConfig.daytonaAPIKey,
32169
32176
  daytonaOrgId: process.env.DAYTONA_ORG_ID ?? parsedConfig.daytonaOrgId,
32170
32177
  runloopAPIKey: process.env.RUNLOOP_API_KEY ?? parsedConfig.runloopAPIKey
@@ -88129,13 +88136,13 @@ __export(exports_constants, {
88129
88136
  PENSAR_CONSOLE_BASE_URL: () => PENSAR_CONSOLE_BASE_URL,
88130
88137
  PENSAR_API_BASE_URL: () => PENSAR_API_BASE_URL
88131
88138
  });
88132
- function getPensarApiUrl() {
88133
- return PENSAR_API_BASE_URL;
88139
+ function getPensarApiUrl(config2) {
88140
+ return config2?.pensarApiUrl || process.env.PENSAR_API_URL || PENSAR_API_BASE_URL;
88134
88141
  }
88135
88142
  function getPensarConsoleUrl() {
88136
88143
  return process.env.PENSAR_CONSOLE_URL || PENSAR_CONSOLE_BASE_URL;
88137
88144
  }
88138
- var PENSAR_API_BASE_URL = "https://api.pensar.dev", PENSAR_CONSOLE_BASE_URL = "https://console.pensar.dev";
88145
+ var PENSAR_API_BASE_URL = "https://api.console.pensar.dev", PENSAR_CONSOLE_BASE_URL = "https://console.pensar.dev";
88139
88146
 
88140
88147
  // src/core/config/index.ts
88141
88148
  var config2;
@@ -88199,7 +88206,7 @@ async function ensureValidToken(cfg) {
88199
88206
  return { token: cfg.accessToken, type: "workos" };
88200
88207
  }
88201
88208
  if (cfg.refreshToken) {
88202
- const clientId = await fetchWorkOSClientId();
88209
+ const clientId = await fetchWorkOSClientId(cfg);
88203
88210
  if (clientId) {
88204
88211
  const newToken = await refreshAccessToken(clientId, cfg.refreshToken);
88205
88212
  if (newToken) {
@@ -88213,12 +88220,12 @@ async function ensureValidToken(cfg) {
88213
88220
  }
88214
88221
  return null;
88215
88222
  }
88216
- async function fetchWorkOSClientId() {
88223
+ async function fetchWorkOSClientId(cfg) {
88217
88224
  if (cachedClientId)
88218
88225
  return cachedClientId;
88219
88226
  try {
88220
88227
  const { getPensarApiUrl: getPensarApiUrl2 } = await Promise.resolve().then(() => exports_constants);
88221
- const apiUrl = getPensarApiUrl2();
88228
+ const apiUrl = getPensarApiUrl2(cfg);
88222
88229
  const response = await fetch(`${apiUrl}/api/cli/config`);
88223
88230
  if (!response.ok)
88224
88231
  return null;
@@ -88243,6 +88250,7 @@ function buildAuthConfig(cfg) {
88243
88250
  openRouterAPIKey: cfg.openRouterAPIKey ?? undefined,
88244
88251
  inceptionAPIKey: cfg.inceptionAPIKey ?? undefined,
88245
88252
  pensarAPIKey: cfg.pensarAPIKey ?? undefined,
88253
+ pensarApiUrl: cfg.pensarApiUrl ?? undefined,
88246
88254
  accessToken: cfg.accessToken ?? undefined,
88247
88255
  refreshToken: cfg.refreshToken ?? undefined,
88248
88256
  workspaceId: cfg.workspaceId ?? undefined,
@@ -88318,7 +88326,7 @@ function getProviderModel(model, authConfig) {
88318
88326
  if (!pensarApiKey && !hasWorkOSAuth) {
88319
88327
  throw new Error("Pensar not configured. Run /auth to connect to Pensar Console.");
88320
88328
  }
88321
- const pensarApiUrl = getPensarApiUrl();
88329
+ const pensarApiUrl = authConfig?.pensarApiUrl || getPensarApiUrl();
88322
88330
  const bedrockModelId = model.startsWith("pensar:") ? model.slice(7) : model;
88323
88331
  if (process.env.PENSAR_DEBUG === "1" || process.env.PENSAR_DEBUG === "true") {
88324
88332
  console.log(`[pensar] getProviderModel: ${model} → bedrock:${bedrockModelId} via ${pensarApiUrl}`);
@@ -88334,7 +88342,8 @@ function getProviderModel(model, authConfig) {
88334
88342
  return ensureValidToken({
88335
88343
  accessToken: freshConfig.accessToken,
88336
88344
  refreshToken: freshConfig.refreshToken,
88337
- pensarAPIKey: freshConfig.pensarAPIKey
88345
+ pensarAPIKey: freshConfig.pensarAPIKey,
88346
+ pensarApiUrl: freshConfig.pensarApiUrl
88338
88347
  });
88339
88348
  };
88340
88349
  }
@@ -279098,7 +279107,7 @@ function AuthFlow({ onClose }) {
279098
279107
  setStep("requesting");
279099
279108
  setError(null);
279100
279109
  cancelledRef.current = false;
279101
- const apiUrl = getPensarApiUrl();
279110
+ const apiUrl = getPensarApiUrl(appConfig.data);
279102
279111
  console.error(`[auth] apiUrl=${apiUrl}`);
279103
279112
  try {
279104
279113
  console.error(`[auth] fetching ${apiUrl}/api/cli/config`);
@@ -279368,7 +279377,7 @@ function AuthFlow({ onClose }) {
279368
279377
  }
279369
279378
  if (key.name === "return" && workspaces[selectedIndex]) {
279370
279379
  const currentConfig = appConfig.data;
279371
- const apiUrl = getPensarApiUrl();
279380
+ const apiUrl = getPensarApiUrl(currentConfig);
279372
279381
  const accessToken = currentConfig.accessToken;
279373
279382
  selectWorkspace(apiUrl, accessToken, workspaces[selectedIndex]);
279374
279383
  }
@@ -279742,7 +279751,8 @@ function CreditsFlow({ onOpenAuthDialog }) {
279742
279751
  const tokenResult = await ensureValidToken({
279743
279752
  accessToken: appConfig.data.accessToken,
279744
279753
  refreshToken: appConfig.data.refreshToken,
279745
- pensarAPIKey: appConfig.data.pensarAPIKey
279754
+ pensarAPIKey: appConfig.data.pensarAPIKey,
279755
+ pensarApiUrl: appConfig.data.pensarApiUrl
279746
279756
  });
279747
279757
  if (!tokenResult) {
279748
279758
  setStep("no-auth");
@@ -279751,7 +279761,7 @@ function CreditsFlow({ onOpenAuthDialog }) {
279751
279761
  setStep("loading");
279752
279762
  setError(null);
279753
279763
  try {
279754
- const apiUrl = getPensarApiUrl();
279764
+ const apiUrl = getPensarApiUrl(appConfig.data);
279755
279765
  const headers = {
279756
279766
  Authorization: `Bearer ${tokenResult.token}`
279757
279767
  };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@pensar/apex",
3
- "version": "0.0.92-canary.1e2cfc8f",
3
+ "version": "0.0.92",
4
4
  "description": "AI-powered penetration testing CLI tool with terminal UI",
5
5
  "module": "src/tui/index.tsx",
6
6
  "main": "build/index.js",