@telorun/assert 0.7.17 → 0.7.19

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
@@ -44,146 +44,7 @@ $ telo ./examples/hello-api
44
44
 
45
45
  ## Example manifest
46
46
 
47
- Here is an example Telo application that defines a simple HTTP API:
48
-
49
- ```yaml
50
- kind: Telo.Application
51
- metadata:
52
- name: feedback
53
- version: 1.0.0
54
- description: |
55
- A complete feedback collection REST API — no code, pure YAML.
56
- Persists entries to SQLite and serves them over HTTP.
57
- imports:
58
- Http: std/http-server@0.12.0
59
- Sql: std/sql@0.9.2
60
- targets:
61
- - !ref Migrations
62
- - !ref Server
63
- ---
64
- # SQLite database — swap driver/host/database for PostgreSQL with zero YAML changes
65
- kind: Sql.Connection
66
- metadata:
67
- name: Db
68
- driver: sqlite
69
- file: ./tmp/feedback.db
70
- ---
71
- # Migrations: applied automatically before the server starts
72
- kind: Sql.Migrations
73
- metadata:
74
- name: Migrations
75
- connection: !ref Db
76
- ---
77
- kind: Sql.Migration
78
- metadata:
79
- name: Migration_20260413_182154_CreateFeedback
80
- version: 20260413_182154_CreateFeedback
81
- sql: |
82
- CREATE TABLE IF NOT EXISTS feedback (
83
- id INTEGER PRIMARY KEY AUTOINCREMENT,
84
- text TEXT NOT NULL,
85
- source TEXT,
86
- score INTEGER NOT NULL DEFAULT 0,
87
- created_at DATETIME DEFAULT CURRENT_TIMESTAMP
88
- )
89
- ---
90
- kind: Http.Server
91
- metadata:
92
- name: Server
93
- baseUrl: http://localhost:8844
94
- port: 8844
95
- logger: true
96
- openapi:
97
- info:
98
- title: Feedback API
99
- version: 1.0.0
100
- mounts:
101
- - path: /v1
102
- mount: !ref FeedbackRoutes
103
- ---
104
- kind: Http.Api
105
- metadata:
106
- name: FeedbackRoutes
107
- routes:
108
- # POST /v1/feedback — insert a new entry, score derived from body length heuristic
109
- - request:
110
- path: /feedback
111
- method: POST
112
- schema:
113
- body:
114
- type: object
115
- properties:
116
- text:
117
- type: string
118
- minLength: 1
119
- source:
120
- type: string
121
- required: [ text ]
122
- handler:
123
- kind: Sql.Exec
124
- connection: !ref Db
125
- inputs:
126
- sql: "INSERT INTO feedback (text, source, score) VALUES (?, ?, ?)"
127
- bindings:
128
- - "${{ request.body.text }}"
129
- - "${{ request.body.source }}"
130
- - "${{ size(request.body.text) }}"
131
- response:
132
- - status: 201
133
- headers:
134
- Content-Type: application/json
135
- body:
136
- ok: true
137
- message: Feedback received
138
-
139
- # GET /v1/feedback — list all entries, newest first
140
- - request:
141
- path: /feedback
142
- method: GET
143
- handler:
144
- kind: Sql.Select
145
- connection: !ref Db
146
- from: feedback
147
- columns: [ id, text, source, score, created_at ]
148
- orderBy:
149
- - { column: created_at, direction: desc }
150
- response:
151
- - status: 200
152
- headers:
153
- Content-Type: application/json
154
- body: "${{ result.rows }}"
155
-
156
- # GET /v1/feedback/{id} — fetch a single entry
157
- - request:
158
- path: /feedback/{id}
159
- method: GET
160
- schema:
161
- params:
162
- type: object
163
- properties:
164
- id:
165
- type: integer
166
- required: [ id ]
167
- handler:
168
- kind: Sql.Select
169
- connection: !ref Db
170
- from: feedback
171
- columns: [ id, text, source, score, created_at ]
172
- where:
173
- - { column: id, op: "=", value: "${{ request.params.id }}" }
174
- response:
175
- - status: 200
176
- when: "size(result.rows) > 0"
177
- headers:
178
- Content-Type: application/json
179
- body: "${{ result.rows[0] }}"
180
- - status: 404
181
- headers:
182
- Content-Type: application/json
183
- body:
184
- ok: false
185
- message: Not found
186
- ```
47
+ See [examples/](./examples/) for a list of working applications.
187
48
 
188
49
  ## Status
189
50
 
package/dist/manifest.js CHANGED
@@ -1,4 +1,4 @@
1
- import { DEFAULT_MANIFEST_FILENAME, Loader, StaticAnalyzer, flattenForAnalyzer } from "@telorun/analyzer";
1
+ import { DEFAULT_MANIFEST_FILENAME, Loader, StaticAnalyzer, defaultSources, flattenForAnalyzer } from "@telorun/analyzer";
2
2
  import * as fs from "fs/promises";
3
3
  import * as path from "path";
4
4
  class LocalFileSource {
@@ -52,7 +52,7 @@ export async function create(manifest, ctx) {
52
52
  const green = (t) => c("32", t);
53
53
  const dim = (t) => c("2", t);
54
54
  const name = manifest.metadata.name;
55
- const loader = new Loader([new LocalFileSource()]);
55
+ const loader = new Loader([new LocalFileSource(), ...defaultSources()]);
56
56
  const analyzer = new StaticAnalyzer();
57
57
  const resolvedUrl = new URL(manifest.source, ctx.moduleContext.source).toString();
58
58
  let manifests;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@telorun/assert",
3
- "version": "0.7.17",
3
+ "version": "0.7.19",
4
4
  "description": "Telo Assert module - Assertion resource kinds for Telo manifests.",
5
5
  "keywords": [
6
6
  "telo",
@@ -62,12 +62,12 @@
62
62
  ],
63
63
  "dependencies": {
64
64
  "@sinclair/typebox": "^0.34.48",
65
- "@telorun/analyzer": "0.27.0"
65
+ "@telorun/analyzer": "0.28.1"
66
66
  },
67
67
  "devDependencies": {
68
68
  "@types/node": "^20.0.0",
69
69
  "typescript": "^5.0.0",
70
- "@telorun/sdk": "0.36.0"
70
+ "@telorun/sdk": "0.38.0"
71
71
  },
72
72
  "peerDependencies": {
73
73
  "@telorun/sdk": "*"
package/src/manifest.ts CHANGED
@@ -1,4 +1,4 @@
1
- import { DEFAULT_MANIFEST_FILENAME, Loader, StaticAnalyzer, flattenForAnalyzer, type AnalysisDiagnostic, type ManifestSource } from "@telorun/analyzer";
1
+ import { DEFAULT_MANIFEST_FILENAME, Loader, StaticAnalyzer, defaultSources, flattenForAnalyzer, type AnalysisDiagnostic, type ManifestSource } from "@telorun/analyzer";
2
2
  import type { ResourceContext, Runnable } from "@telorun/sdk";
3
3
  import * as fs from "fs/promises";
4
4
  import * as path from "path";
@@ -78,7 +78,7 @@ export async function create(
78
78
  const dim = (t: string) => c("2", t);
79
79
 
80
80
  const name = manifest.metadata.name;
81
- const loader = new Loader([new LocalFileSource()]);
81
+ const loader = new Loader([new LocalFileSource(), ...defaultSources()]);
82
82
  const analyzer = new StaticAnalyzer();
83
83
 
84
84
  const resolvedUrl = new URL(manifest.source, ctx.moduleContext.source).toString();