git-daemon 0.1.11 → 0.1.12

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/README.md CHANGED
@@ -199,6 +199,14 @@ curl -H "Origin: https://app.example.com" \
199
199
  http://127.0.0.1:8790/v1/healthchecks/jobs/<JOB_ID>/result
200
200
  ```
201
201
 
202
+ List healthchecks (flat):
203
+
204
+ ```bash
205
+ curl -H "Origin: https://app.example.com" \
206
+ -H "Authorization: Bearer <TOKEN>" \
207
+ "http://127.0.0.1:8790/v1/healthchecks?flat=true"
208
+ ```
209
+
202
210
  ## Configuration
203
211
 
204
212
  Config is stored in OS-specific directories:
package/design.md CHANGED
@@ -430,7 +430,7 @@ Recommendations:
430
430
 
431
431
  ### Healthcheck endpoints
432
432
 
433
- * `GET /v1/healthchecks` → list installed suites and checks.
433
+ * `GET /v1/healthchecks` → list installed suites and checks (use `?flat=true` for a flattened list).
434
434
  * `POST /v1/healthchecks/run` → job
435
435
 
436
436
  * body: `{ repoPath, repoInfo?, suiteId?, checks?: [{ suiteId?, checkId, config?, cacheMode? }] }`
@@ -155,10 +155,16 @@ const description =
155
155
 
156
156
  if (!description) {
157
157
  emit({
158
- status: "na",
158
+ status: "failed",
159
159
  summary: "Missing repo description",
160
- explanation:
161
- "REPO_INFO.description is missing, so there is nothing to compare.",
160
+ explanation: "REPO_INFO.description is required for this healthcheck.",
161
+ details: [
162
+ {
163
+ code: "ABOUT_MISSING",
164
+ severity: "high",
165
+ message: "Provide a GitHub repo description to match the README.",
166
+ },
167
+ ],
162
168
  });
163
169
  process.exit(0);
164
170
  }
@@ -166,9 +172,16 @@ if (!description) {
166
172
  const readmePath = findReadme(repoPath);
167
173
  if (!readmePath) {
168
174
  emit({
169
- status: "na",
175
+ status: "failed",
170
176
  summary: "README not found",
171
- explanation: "No README file was found in the repo root.",
177
+ explanation: "A README is required to compare against the description.",
178
+ details: [
179
+ {
180
+ code: "README_MISSING",
181
+ severity: "high",
182
+ message: "Add a README with a clear first sentence.",
183
+ },
184
+ ],
172
185
  });
173
186
  process.exit(0);
174
187
  }
@@ -195,10 +208,18 @@ try {
195
208
  const firstSentence = extractFirstSentence(readmeText);
196
209
  if (!firstSentence) {
197
210
  emit({
198
- status: "na",
199
- summary: "README has no readable paragraph",
211
+ status: "failed",
212
+ summary: "README missing a first sentence",
200
213
  explanation:
201
214
  "Could not locate non-title text to compare against the description.",
215
+ details: [
216
+ {
217
+ code: "README_SENTENCE_MISSING",
218
+ severity: "high",
219
+ message:
220
+ "Add a first paragraph with a clear first sentence after the title.",
221
+ },
222
+ ],
202
223
  });
203
224
  process.exit(0);
204
225
  }
package/openapi.yaml CHANGED
@@ -321,13 +321,16 @@ paths:
321
321
  summary: List available healthchecks
322
322
  parameters:
323
323
  - $ref: '#/components/parameters/OriginHeader'
324
+ - $ref: '#/components/parameters/HealthcheckFlat'
324
325
  responses:
325
326
  '200':
326
327
  description: Healthcheck catalog
327
328
  content:
328
329
  application/json:
329
330
  schema:
330
- $ref: '#/components/schemas/HealthcheckCatalogResponse'
331
+ oneOf:
332
+ - $ref: '#/components/schemas/HealthcheckCatalogResponse'
333
+ - $ref: '#/components/schemas/HealthcheckFlatResponse'
331
334
  '401':
332
335
  $ref: '#/components/responses/Unauthorized'
333
336
  '403':
@@ -438,6 +441,14 @@ components:
438
441
  schema:
439
442
  type: boolean
440
443
  default: true
444
+ HealthcheckFlat:
445
+ name: flat
446
+ in: query
447
+ required: false
448
+ schema:
449
+ type: boolean
450
+ default: false
451
+ description: Return a flattened list of checks instead of suites.
441
452
  schemas:
442
453
  MetaResponse:
443
454
  type: object
@@ -790,6 +801,15 @@ components:
790
801
  type: array
791
802
  items:
792
803
  $ref: '#/components/schemas/HealthcheckSuite'
804
+ HealthcheckFlatResponse:
805
+ type: object
806
+ required:
807
+ - checks
808
+ properties:
809
+ checks:
810
+ type: array
811
+ items:
812
+ $ref: '#/components/schemas/HealthcheckFlatCheck'
793
813
  HealthcheckSuite:
794
814
  type: object
795
815
  required:
@@ -843,6 +863,43 @@ components:
843
863
  additionalProperties: true
844
864
  outputSchemaVersion:
845
865
  type: integer
866
+ HealthcheckFlatCheck:
867
+ type: object
868
+ required:
869
+ - suiteId
870
+ - checkId
871
+ - name
872
+ - version
873
+ - description
874
+ - timeoutSeconds
875
+ - cacheable
876
+ properties:
877
+ suiteId:
878
+ type: string
879
+ checkId:
880
+ type: string
881
+ name:
882
+ type: string
883
+ version:
884
+ type: string
885
+ description:
886
+ type: string
887
+ timeoutSeconds:
888
+ type: integer
889
+ minimum: 1
890
+ cacheable:
891
+ type: boolean
892
+ cacheMaxAgeSeconds:
893
+ type: integer
894
+ minimum: 1
895
+ permissions:
896
+ $ref: '#/components/schemas/HealthcheckPermissions'
897
+ configSchema:
898
+ type: object
899
+ description: JSON schema for check config.
900
+ additionalProperties: true
901
+ outputSchemaVersion:
902
+ type: integer
846
903
  HealthcheckPermissions:
847
904
  type: object
848
905
  properties:
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "git-daemon",
3
- "version": "0.1.11",
3
+ "version": "0.1.12",
4
4
  "private": false,
5
5
  "type": "commonjs",
6
6
  "main": "dist/daemon.js",
package/src/app.ts CHANGED
@@ -54,6 +54,7 @@ import { installDeps } from "./deps";
54
54
  import { openTarget } from "./os";
55
55
  import {
56
56
  HealthcheckResultStore,
57
+ flattenHealthchecks,
57
58
  listHealthcheckSuites,
58
59
  loadHealthcheckSuites,
59
60
  resolveSelections,
@@ -530,6 +531,11 @@ export const createApp = (ctx: DaemonContext) => {
530
531
  ctx.configDir,
531
532
  ctx.config.healthchecks?.suites ?? [],
532
533
  );
534
+ const flat = _req.query.flat === "true";
535
+ if (flat) {
536
+ res.json({ checks: flattenHealthchecks(suites) });
537
+ return;
538
+ }
533
539
  res.json({ suites: listHealthcheckSuites(suites) });
534
540
  } catch (err) {
535
541
  next(err);
@@ -279,6 +279,23 @@ export const listHealthcheckSuites = (suites: HealthcheckSuite[]) =>
279
279
  })),
280
280
  }));
281
281
 
282
+ export const flattenHealthchecks = (suites: HealthcheckSuite[]) =>
283
+ suites.flatMap((suite) =>
284
+ suite.checks.map((check) => ({
285
+ suiteId: suite.id,
286
+ checkId: check.id,
287
+ name: check.name,
288
+ version: check.version,
289
+ description: check.description,
290
+ timeoutSeconds: check.timeoutSeconds,
291
+ cacheable: check.cacheable,
292
+ cacheMaxAgeSeconds: check.cacheMaxAgeSeconds,
293
+ permissions: check.permissions,
294
+ configSchema: check.configSchema,
295
+ outputSchemaVersion: check.outputSchemaVersion,
296
+ })),
297
+ );
298
+
282
299
  export const resolveSelections = (
283
300
  suites: HealthcheckSuite[],
284
301
  request: HealthcheckRunRequest,