pullfrog 0.1.22 → 0.1.23

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.
package/dist/cli.mjs CHANGED
@@ -101018,6 +101018,18 @@ var providers = {
101018
101018
  }
101019
101019
  }
101020
101020
  }),
101021
+ "opencode-go": provider({
101022
+ displayName: "OpenCode Go",
101023
+ envVars: ["OPENCODE_API_KEY"],
101024
+ models: {
101025
+ "glm-5.1": {
101026
+ displayName: "GLM 5.1",
101027
+ resolve: "opencode-go/glm-5.1",
101028
+ openRouterResolve: "openrouter/z-ai/glm-5.1",
101029
+ preferred: true
101030
+ }
101031
+ }
101032
+ }),
101021
101033
  bedrock: provider({
101022
101034
  displayName: "Amazon Bedrock",
101023
101035
  envVars: ["AWS_BEARER_TOKEN_BEDROCK", "AWS_REGION", "BEDROCK_MODEL_ID"],
@@ -101855,7 +101867,7 @@ var import_semver = __toESM(require_semver2(), 1);
101855
101867
  // package.json
101856
101868
  var package_default = {
101857
101869
  name: "pullfrog",
101858
- version: "0.1.22",
101870
+ version: "0.1.23",
101859
101871
  type: "module",
101860
101872
  bin: {
101861
101873
  pullfrog: "dist/cli.mjs",
@@ -117134,6 +117146,9 @@ function formatModelLabel(params) {
117134
117146
  // still render a friendly display name.
117135
117147
  modelAliases.find((a) => a.resolve === params.model || a.openRouterResolve === params.model);
117136
117148
  const displayName = alias?.displayName ?? params.model;
117149
+ if (params.oss) {
117150
+ return `\`${displayName}\` (free via [Pullfrog for OSS](https://pullfrog.com/for-oss))`;
117151
+ }
117137
117152
  const base = alias?.isFree ? `\`${displayName}\` (free)` : `\`${displayName}\``;
117138
117153
  if (!params.fallbackFrom) return base;
117139
117154
  return `${base} (credentials for ${providerDisplayName(params.fallbackFrom)} not configured)`;
@@ -117155,7 +117170,7 @@ function buildPullfrogFooter(params) {
117155
117170
  }
117156
117171
  if (params.model) {
117157
117172
  parts.push(
117158
- `Using ${formatModelLabel({ model: params.model, fallbackFrom: params.fallbackFrom })}`
117173
+ `Using ${formatModelLabel({ model: params.model, fallbackFrom: params.fallbackFrom, oss: params.oss })}`
117159
117174
  );
117160
117175
  }
117161
117176
  const allParts = [...parts, "[\u{1D54F}](https://x.com/pullfrogai)"];
@@ -117950,7 +117965,8 @@ function buildCommentFooter(ctx, customParts) {
117950
117965
  } : void 0,
117951
117966
  customParts,
117952
117967
  model: ctx.toolState.model,
117953
- fallbackFrom: ctx.toolState.modelFallback?.from
117968
+ fallbackFrom: ctx.toolState.modelFallback?.from,
117969
+ oss: ctx.oss
117954
117970
  });
117955
117971
  }
117956
117972
  function buildImplementPlanLink(ctx, issueNumber, commentId) {
@@ -152818,7 +152834,8 @@ async function createAndSubmitWithFooter(ctx, params, opts) {
152818
152834
  workflowRun: ctx.runId ? { owner: ctx.repo.owner, repo: ctx.repo.name, runId: ctx.runId, jobId: ctx.jobId } : void 0,
152819
152835
  customParts,
152820
152836
  model: ctx.toolState.model,
152821
- fallbackFrom: ctx.toolState.modelFallback?.from
152837
+ fallbackFrom: ctx.toolState.modelFallback?.from,
152838
+ oss: ctx.oss
152822
152839
  });
152823
152840
  return await ctx.octokit.rest.pulls.submitReview({
152824
152841
  owner: params.owner,
@@ -154242,7 +154259,8 @@ function buildPrBodyWithFooter(ctx, body) {
154242
154259
  triggeredBy: true,
154243
154260
  workflowRun: ctx.runId ? { owner: ctx.repo.owner, repo: ctx.repo.name, runId: ctx.runId, jobId: ctx.jobId } : void 0,
154244
154261
  model: ctx.toolState.model,
154245
- fallbackFrom: ctx.toolState.modelFallback?.from
154262
+ fallbackFrom: ctx.toolState.modelFallback?.from,
154263
+ oss: ctx.oss
154246
154264
  });
154247
154265
  const bodyWithoutFooter = stripExistingFooter(fixDoubleEscapedString(body));
154248
154266
  return `${bodyWithoutFooter}${footer}`;
@@ -160768,7 +160786,8 @@ ${ctx.error}` : ctx.error;
160768
160786
  workflowRun: runId ? { owner: repoContext.owner, repo: repoContext.name, runId } : void 0,
160769
160787
  customParts,
160770
160788
  model: ctx.toolState.model,
160771
- fallbackFrom: ctx.toolState.modelFallback?.from
160789
+ fallbackFrom: ctx.toolState.modelFallback?.from,
160790
+ oss: ctx.toolState.oss
160772
160791
  });
160773
160792
  const body = `${formattedError}${footer}`;
160774
160793
  const comment = ctx.toolState.progressComment;
@@ -161740,6 +161759,7 @@ async function main() {
161740
161759
  }
161741
161760
  const payload = resolvePayload(resolvedPromptInput, runContext.repoSettings);
161742
161761
  toolState.model = payload.model;
161762
+ toolState.oss = runContext.oss;
161743
161763
  if (payload.event.trigger === "pull_request_synchronize") {
161744
161764
  toolState.beforeSha = payload.event.before_sha;
161745
161765
  }
@@ -162984,7 +163004,7 @@ async function run2() {
162984
163004
  }
162985
163005
 
162986
163006
  // cli.ts
162987
- var VERSION10 = "0.1.22";
163007
+ var VERSION10 = "0.1.23";
162988
163008
  var bin = basename2(process.argv[1] || "");
162989
163009
  var PROG = bin === "pf" || bin === "pullfrog" ? bin : "pullfrog";
162990
163010
  var rawArgs = process.argv.slice(2);
package/dist/index.js CHANGED
@@ -99218,6 +99218,18 @@ var providers = {
99218
99218
  }
99219
99219
  }
99220
99220
  }),
99221
+ "opencode-go": provider({
99222
+ displayName: "OpenCode Go",
99223
+ envVars: ["OPENCODE_API_KEY"],
99224
+ models: {
99225
+ "glm-5.1": {
99226
+ displayName: "GLM 5.1",
99227
+ resolve: "opencode-go/glm-5.1",
99228
+ openRouterResolve: "openrouter/z-ai/glm-5.1",
99229
+ preferred: true
99230
+ }
99231
+ }
99232
+ }),
99221
99233
  bedrock: provider({
99222
99234
  displayName: "Amazon Bedrock",
99223
99235
  envVars: ["AWS_BEARER_TOKEN_BEDROCK", "AWS_REGION", "BEDROCK_MODEL_ID"],
@@ -100055,7 +100067,7 @@ var import_semver = __toESM(require_semver2(), 1);
100055
100067
  // package.json
100056
100068
  var package_default = {
100057
100069
  name: "pullfrog",
100058
- version: "0.1.22",
100070
+ version: "0.1.23",
100059
100071
  type: "module",
100060
100072
  bin: {
100061
100073
  pullfrog: "dist/cli.mjs",
@@ -115376,6 +115388,9 @@ function formatModelLabel(params) {
115376
115388
  // still render a friendly display name.
115377
115389
  modelAliases.find((a) => a.resolve === params.model || a.openRouterResolve === params.model);
115378
115390
  const displayName = alias?.displayName ?? params.model;
115391
+ if (params.oss) {
115392
+ return `\`${displayName}\` (free via [Pullfrog for OSS](https://pullfrog.com/for-oss))`;
115393
+ }
115379
115394
  const base = alias?.isFree ? `\`${displayName}\` (free)` : `\`${displayName}\``;
115380
115395
  if (!params.fallbackFrom) return base;
115381
115396
  return `${base} (credentials for ${providerDisplayName(params.fallbackFrom)} not configured)`;
@@ -115397,7 +115412,7 @@ function buildPullfrogFooter(params) {
115397
115412
  }
115398
115413
  if (params.model) {
115399
115414
  parts.push(
115400
- `Using ${formatModelLabel({ model: params.model, fallbackFrom: params.fallbackFrom })}`
115415
+ `Using ${formatModelLabel({ model: params.model, fallbackFrom: params.fallbackFrom, oss: params.oss })}`
115401
115416
  );
115402
115417
  }
115403
115418
  const allParts = [...parts, "[\u{1D54F}](https://x.com/pullfrogai)"];
@@ -116192,7 +116207,8 @@ function buildCommentFooter(ctx, customParts) {
116192
116207
  } : void 0,
116193
116208
  customParts,
116194
116209
  model: ctx.toolState.model,
116195
- fallbackFrom: ctx.toolState.modelFallback?.from
116210
+ fallbackFrom: ctx.toolState.modelFallback?.from,
116211
+ oss: ctx.oss
116196
116212
  });
116197
116213
  }
116198
116214
  function buildImplementPlanLink(ctx, issueNumber, commentId) {
@@ -151060,7 +151076,8 @@ async function createAndSubmitWithFooter(ctx, params, opts) {
151060
151076
  workflowRun: ctx.runId ? { owner: ctx.repo.owner, repo: ctx.repo.name, runId: ctx.runId, jobId: ctx.jobId } : void 0,
151061
151077
  customParts,
151062
151078
  model: ctx.toolState.model,
151063
- fallbackFrom: ctx.toolState.modelFallback?.from
151079
+ fallbackFrom: ctx.toolState.modelFallback?.from,
151080
+ oss: ctx.oss
151064
151081
  });
151065
151082
  return await ctx.octokit.rest.pulls.submitReview({
151066
151083
  owner: params.owner,
@@ -152484,7 +152501,8 @@ function buildPrBodyWithFooter(ctx, body) {
152484
152501
  triggeredBy: true,
152485
152502
  workflowRun: ctx.runId ? { owner: ctx.repo.owner, repo: ctx.repo.name, runId: ctx.runId, jobId: ctx.jobId } : void 0,
152486
152503
  model: ctx.toolState.model,
152487
- fallbackFrom: ctx.toolState.modelFallback?.from
152504
+ fallbackFrom: ctx.toolState.modelFallback?.from,
152505
+ oss: ctx.oss
152488
152506
  });
152489
152507
  const bodyWithoutFooter = stripExistingFooter(fixDoubleEscapedString(body));
152490
152508
  return `${bodyWithoutFooter}${footer}`;
@@ -159010,7 +159028,8 @@ ${ctx.error}` : ctx.error;
159010
159028
  workflowRun: runId ? { owner: repoContext.owner, repo: repoContext.name, runId } : void 0,
159011
159029
  customParts,
159012
159030
  model: ctx.toolState.model,
159013
- fallbackFrom: ctx.toolState.modelFallback?.from
159031
+ fallbackFrom: ctx.toolState.modelFallback?.from,
159032
+ oss: ctx.toolState.oss
159014
159033
  });
159015
159034
  const body = `${formattedError}${footer}`;
159016
159035
  const comment = ctx.toolState.progressComment;
@@ -159982,6 +160001,7 @@ async function main() {
159982
160001
  }
159983
160002
  const payload = resolvePayload(resolvedPromptInput, runContext.repoSettings);
159984
160003
  toolState.model = payload.model;
160004
+ toolState.oss = runContext.oss;
159985
160005
  if (payload.event.trigger === "pull_request_synchronize") {
159986
160006
  toolState.beforeSha = payload.event.before_sha;
159987
160007
  }
package/dist/internal.js CHANGED
@@ -284,6 +284,18 @@ var providers = {
284
284
  }
285
285
  }
286
286
  }),
287
+ "opencode-go": provider({
288
+ displayName: "OpenCode Go",
289
+ envVars: ["OPENCODE_API_KEY"],
290
+ models: {
291
+ "glm-5.1": {
292
+ displayName: "GLM 5.1",
293
+ resolve: "opencode-go/glm-5.1",
294
+ openRouterResolve: "openrouter/z-ai/glm-5.1",
295
+ preferred: true
296
+ }
297
+ }
298
+ }),
287
299
  bedrock: provider({
288
300
  displayName: "Amazon Bedrock",
289
301
  envVars: ["AWS_BEARER_TOKEN_BEDROCK", "AWS_REGION", "BEDROCK_MODEL_ID"],
@@ -1127,6 +1139,9 @@ function formatModelLabel(params) {
1127
1139
  // still render a friendly display name.
1128
1140
  modelAliases.find((a) => a.resolve === params.model || a.openRouterResolve === params.model);
1129
1141
  const displayName = alias?.displayName ?? params.model;
1142
+ if (params.oss) {
1143
+ return `\`${displayName}\` (free via [Pullfrog for OSS](https://pullfrog.com/for-oss))`;
1144
+ }
1130
1145
  const base = alias?.isFree ? `\`${displayName}\` (free)` : `\`${displayName}\``;
1131
1146
  if (!params.fallbackFrom) return base;
1132
1147
  return `${base} (credentials for ${providerDisplayName(params.fallbackFrom)} not configured)`;
@@ -1148,7 +1163,7 @@ function buildPullfrogFooter(params) {
1148
1163
  }
1149
1164
  if (params.model) {
1150
1165
  parts.push(
1151
- `Using ${formatModelLabel({ model: params.model, fallbackFrom: params.fallbackFrom })}`
1166
+ `Using ${formatModelLabel({ model: params.model, fallbackFrom: params.fallbackFrom, oss: params.oss })}`
1152
1167
  );
1153
1168
  }
1154
1169
  const allParts = [...parts, "[\u{1D54F}](https://x.com/pullfrogai)"];
package/dist/models.d.ts CHANGED
@@ -85,6 +85,7 @@ export declare const providers: {
85
85
  deepseek: ProviderConfig;
86
86
  moonshotai: ProviderConfig;
87
87
  opencode: ProviderConfig;
88
+ "opencode-go": ProviderConfig;
88
89
  bedrock: ProviderConfig;
89
90
  vertex: ProviderConfig;
90
91
  openrouter: ProviderConfig;
@@ -108,6 +108,7 @@ export interface ToolState {
108
108
  modelFallback?: {
109
109
  from: string;
110
110
  } | undefined;
111
+ oss?: boolean | undefined;
111
112
  todoTracker?: TodoTracker | undefined;
112
113
  diffCoverage?: DiffCoverageState | undefined;
113
114
  agentDiagnostic?: AgentDiagnostic | undefined;
@@ -24,6 +24,12 @@ export interface BuildPullfrogFooterParams {
24
24
  * so the substitution is visible in PR comments + reviews.
25
25
  */
26
26
  fallbackFrom?: string | undefined;
27
+ /**
28
+ * true when the run's model costs are covered by the Pullfrog for OSS
29
+ * program — the footer renders `Using <model> (free via Pullfrog for OSS)`
30
+ * with the phrase linking to the OSS application page.
31
+ */
32
+ oss?: boolean | undefined;
27
33
  }
28
34
  /**
29
35
  * build a pullfrog footer with configurable parts
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "pullfrog",
3
- "version": "0.1.22",
3
+ "version": "0.1.23",
4
4
  "type": "module",
5
5
  "bin": {
6
6
  "pullfrog": "dist/cli.mjs",