mirror of
https://github.com/ModernRelay/omnigraph.git
synced 2026-06-09 01:35:18 +02:00
Polish OpenAPI spec for SDK generation
Add operation descriptions and examples to utoipa annotations so the generated TypeScript SDK has rich JSDoc, and so future Python/Go SDKs and any /openapi.json docs UI benefit from the same effort. - Doc comments on all 18 handlers (utoipa picks up summary/description) - #[schema(example = ...)] on free-text fields (query_source, schema_source, NDJSON data) and i64 timestamps - Destructive/irreversible warnings on change, applySchema, ingest, mergeBranches, deleteBranch, publishRun, abortRun Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
This commit is contained in:
parent
628bc2e607
commit
7809bf607e
3 changed files with 220 additions and 24 deletions
|
|
@ -52,7 +52,11 @@ pub struct RunOutput {
|
|||
pub actor_id: Option<String>,
|
||||
pub status: String,
|
||||
pub published_snapshot_id: Option<String>,
|
||||
/// Run creation time as Unix epoch microseconds.
|
||||
#[schema(example = 1714000000000000i64)]
|
||||
pub created_at: i64,
|
||||
/// Last status change as Unix epoch microseconds.
|
||||
#[schema(example = 1714000000000000i64)]
|
||||
pub updated_at: i64,
|
||||
}
|
||||
|
||||
|
|
@ -63,7 +67,9 @@ pub struct RunListOutput {
|
|||
|
||||
#[derive(Debug, Clone, Serialize, Deserialize, ToSchema)]
|
||||
pub struct BranchCreateRequest {
|
||||
/// Parent branch to fork from. Defaults to `main`.
|
||||
pub from: Option<String>,
|
||||
/// Name of the new branch. Must not already exist.
|
||||
pub name: String,
|
||||
}
|
||||
|
||||
|
|
@ -89,7 +95,9 @@ pub struct BranchDeleteOutput {
|
|||
|
||||
#[derive(Debug, Clone, Serialize, Deserialize, ToSchema)]
|
||||
pub struct BranchMergeRequest {
|
||||
/// Source branch whose commits will be merged.
|
||||
pub source: String,
|
||||
/// Target branch that will receive the merge. Defaults to `main`.
|
||||
pub target: Option<String>,
|
||||
}
|
||||
|
||||
|
|
@ -239,6 +247,8 @@ pub struct CommitOutput {
|
|||
pub parent_commit_id: Option<String>,
|
||||
pub merged_parent_commit_id: Option<String>,
|
||||
pub actor_id: Option<String>,
|
||||
/// Commit creation time as Unix epoch microseconds.
|
||||
#[schema(example = 1714000000000000i64)]
|
||||
pub created_at: i64,
|
||||
}
|
||||
|
||||
|
|
@ -249,23 +259,40 @@ pub struct CommitListOutput {
|
|||
|
||||
#[derive(Debug, Clone, Serialize, Deserialize, ToSchema)]
|
||||
pub struct ReadRequest {
|
||||
/// GQ query source. May declare one or more named queries; pick one with
|
||||
/// `query_name` if there is more than one.
|
||||
#[schema(example = "query get_person($name: String) {\n match {\n $p: Person { name: $name }\n }\n return { $p.name, $p.age }\n}")]
|
||||
pub query_source: String,
|
||||
/// Name of the query to run when `query_source` declares multiple. Optional
|
||||
/// when only one query is declared.
|
||||
pub query_name: Option<String>,
|
||||
/// JSON object whose keys match the query's declared parameters.
|
||||
pub params: Option<Value>,
|
||||
/// Branch to read from. Mutually exclusive with `snapshot`. Defaults to `main`.
|
||||
pub branch: Option<String>,
|
||||
/// Snapshot id to read from. Mutually exclusive with `branch`.
|
||||
pub snapshot: Option<String>,
|
||||
}
|
||||
|
||||
#[derive(Debug, Clone, Serialize, Deserialize, ToSchema)]
|
||||
pub struct ChangeRequest {
|
||||
/// GQ mutation source containing `insert`, `update`, or `delete` statements.
|
||||
/// May declare multiple named mutations; pick one with `query_name`.
|
||||
#[schema(example = "query insert_person($name: String, $age: I32) {\n insert Person { name: $name, age: $age }\n}")]
|
||||
pub query_source: String,
|
||||
/// Name of the mutation to run when `query_source` declares multiple.
|
||||
pub query_name: Option<String>,
|
||||
/// JSON object whose keys match the mutation's declared parameters.
|
||||
pub params: Option<Value>,
|
||||
/// Target branch. Defaults to `main`.
|
||||
pub branch: Option<String>,
|
||||
}
|
||||
|
||||
#[derive(Debug, Clone, Serialize, Deserialize, ToSchema)]
|
||||
pub struct SchemaApplyRequest {
|
||||
/// Project schema in `.pg` source form. The diff against the current
|
||||
/// schema produces the migration steps that will be applied.
|
||||
#[schema(example = "node Person {\n name: String @key\n age: I32?\n}\n\nedge Knows: Person -> Person")]
|
||||
pub schema_source: String,
|
||||
}
|
||||
|
||||
|
|
@ -287,18 +314,27 @@ pub struct SchemaOutput {
|
|||
|
||||
#[derive(Debug, Clone, Serialize, Deserialize, ToSchema)]
|
||||
pub struct IngestRequest {
|
||||
/// Target branch. Created from `from` if it does not yet exist. Defaults to `main`.
|
||||
pub branch: Option<String>,
|
||||
/// Parent branch used to create `branch` if it does not exist. Defaults to `main`.
|
||||
pub from: Option<String>,
|
||||
/// How existing rows are handled. Defaults to `merge`.
|
||||
#[schema(value_type = Option<LoadModeSchema>)]
|
||||
pub mode: Option<LoadMode>,
|
||||
/// NDJSON payload: one record per line, each shaped
|
||||
/// `{"type": "<TypeName>", "data": {...}}`.
|
||||
#[schema(example = "{\"type\": \"Person\", \"data\": {\"name\": \"Alice\", \"age\": 30}}\n{\"type\": \"Person\", \"data\": {\"name\": \"Bob\", \"age\": 25}}")]
|
||||
pub data: String,
|
||||
}
|
||||
|
||||
#[derive(Debug, Clone, Serialize, Deserialize, ToSchema)]
|
||||
pub struct ExportRequest {
|
||||
/// Branch to export. Defaults to `main`.
|
||||
pub branch: Option<String>,
|
||||
/// Restrict the export to these node/edge type names. Empty exports all types.
|
||||
#[serde(default)]
|
||||
pub type_names: Vec<String>,
|
||||
/// Restrict the export to these table keys. Empty exports all tables.
|
||||
#[serde(default)]
|
||||
pub table_keys: Vec<String>,
|
||||
}
|
||||
|
|
|
|||
|
|
@ -497,6 +497,11 @@ async fn shutdown_signal() {
|
|||
(status = 200, description = "Server is healthy", body = HealthOutput),
|
||||
),
|
||||
)]
|
||||
/// Liveness probe.
|
||||
///
|
||||
/// Returns server status and version. Unauthenticated; safe to call from any
|
||||
/// caller. Use this to confirm the server is reachable before invoking other
|
||||
/// endpoints.
|
||||
async fn server_health() -> Json<HealthOutput> {
|
||||
Json(HealthOutput {
|
||||
status: "ok".to_string(),
|
||||
|
|
@ -616,6 +621,11 @@ fn authorize_request(
|
|||
),
|
||||
security(("bearer_token" = [])),
|
||||
)]
|
||||
/// Read the current snapshot of a branch.
|
||||
///
|
||||
/// Returns the manifest version plus per-table metadata (path, version, row
|
||||
/// count) for every table on the branch. Defaults to `main` when `branch` is
|
||||
/// omitted. Read-only.
|
||||
async fn server_snapshot(
|
||||
State(state): State<AppState>,
|
||||
actor: Option<Extension<AuthenticatedActor>>,
|
||||
|
|
@ -658,6 +668,13 @@ async fn server_snapshot(
|
|||
),
|
||||
security(("bearer_token" = [])),
|
||||
)]
|
||||
/// Execute a GQ read query.
|
||||
///
|
||||
/// Runs the query in `query_source` against either a branch or a frozen
|
||||
/// snapshot (mutually exclusive). When `query_source` defines multiple named
|
||||
/// queries, pick one with `query_name`. `params` is a JSON object whose keys
|
||||
/// match the parameters declared by the query. Returns rows as a JSON array
|
||||
/// plus a `columns` list. Read-only.
|
||||
async fn server_read(
|
||||
State(state): State<AppState>,
|
||||
actor: Option<Extension<AuthenticatedActor>>,
|
||||
|
|
@ -728,6 +745,12 @@ async fn server_read(
|
|||
),
|
||||
security(("bearer_token" = [])),
|
||||
)]
|
||||
/// Stream the contents of a branch as NDJSON.
|
||||
///
|
||||
/// Emits one JSON object per line (`application/x-ndjson`). Filter with
|
||||
/// `type_names` (node/edge type names) and/or `table_keys`; both empty
|
||||
/// streams the entire branch. Suitable for large exports — the response is
|
||||
/// streamed, not buffered. Read-only.
|
||||
async fn server_export(
|
||||
State(state): State<AppState>,
|
||||
actor: Option<Extension<AuthenticatedActor>>,
|
||||
|
|
@ -788,6 +811,12 @@ async fn server_export(
|
|||
),
|
||||
security(("bearer_token" = [])),
|
||||
)]
|
||||
/// Apply a GQ mutation to a branch.
|
||||
///
|
||||
/// Writes to the named `branch` (defaults to `main`). Mutations are atomic
|
||||
/// per call and produce a new commit. Returns counts of nodes and edges
|
||||
/// affected. **Destructive**: on success the branch is updated; rejected
|
||||
/// mutations may still acquire locks briefly. Returns 409 on merge conflict.
|
||||
async fn server_change(
|
||||
State(state): State<AppState>,
|
||||
actor: Option<Extension<AuthenticatedActor>>,
|
||||
|
|
@ -844,6 +873,11 @@ async fn server_change(
|
|||
),
|
||||
security(("bearer_token" = [])),
|
||||
)]
|
||||
/// Read the current schema source.
|
||||
///
|
||||
/// Returns the project's schema as a single string in `.pg` source form.
|
||||
/// Useful for clients that want to introspect available types and tables
|
||||
/// before constructing GQ queries. Read-only.
|
||||
async fn server_schema_get(
|
||||
State(state): State<AppState>,
|
||||
actor: Option<Extension<AuthenticatedActor>>,
|
||||
|
|
@ -882,6 +916,12 @@ async fn server_schema_get(
|
|||
),
|
||||
security(("bearer_token" = [])),
|
||||
)]
|
||||
/// Apply a schema migration.
|
||||
///
|
||||
/// Diffs `schema_source` against the current schema and applies the resulting
|
||||
/// migration steps (add/drop type, add/drop column, etc.). **Destructive**:
|
||||
/// some steps drop data. Returns the list of steps applied; if `applied` is
|
||||
/// false the diff was unsupported and no changes were made.
|
||||
async fn server_schema_apply(
|
||||
State(state): State<AppState>,
|
||||
actor: Option<Extension<AuthenticatedActor>>,
|
||||
|
|
@ -921,6 +961,13 @@ async fn server_schema_apply(
|
|||
),
|
||||
security(("bearer_token" = [])),
|
||||
)]
|
||||
/// Bulk-ingest NDJSON data into a branch.
|
||||
///
|
||||
/// `data` is NDJSON with one record per line. `mode` controls behavior on
|
||||
/// existing rows: `merge` upserts by id (default), `append` blindly inserts,
|
||||
/// `overwrite` replaces table contents. If `branch` does not exist it is
|
||||
/// created from `from` (defaults to `main`). **Destructive** when `mode` is
|
||||
/// `overwrite` or when ingest produces conflicting writes.
|
||||
async fn server_ingest(
|
||||
State(state): State<AppState>,
|
||||
actor: Option<Extension<AuthenticatedActor>>,
|
||||
|
|
@ -989,6 +1036,9 @@ async fn server_ingest(
|
|||
),
|
||||
security(("bearer_token" = [])),
|
||||
)]
|
||||
/// List all branches.
|
||||
///
|
||||
/// Returns branch names sorted alphabetically. Read-only.
|
||||
async fn server_branch_list(
|
||||
State(state): State<AppState>,
|
||||
actor: Option<Extension<AuthenticatedActor>>,
|
||||
|
|
@ -1029,6 +1079,11 @@ async fn server_branch_list(
|
|||
),
|
||||
security(("bearer_token" = [])),
|
||||
)]
|
||||
/// Create a new branch.
|
||||
///
|
||||
/// Forks `name` off of `from` (defaults to `main`). The new branch shares
|
||||
/// table data with its parent until it is mutated. Returns 409 if `name`
|
||||
/// already exists.
|
||||
async fn server_branch_create(
|
||||
State(state): State<AppState>,
|
||||
actor: Option<Extension<AuthenticatedActor>>,
|
||||
|
|
@ -1078,6 +1133,11 @@ async fn server_branch_create(
|
|||
),
|
||||
security(("bearer_token" = [])),
|
||||
)]
|
||||
/// Delete a branch.
|
||||
///
|
||||
/// **Irreversible.** Removes the branch pointer; commits remain reachable
|
||||
/// only if referenced by another branch. Returns 404 if the branch does not
|
||||
/// exist.
|
||||
async fn server_branch_delete(
|
||||
State(state): State<AppState>,
|
||||
actor: Option<Extension<AuthenticatedActor>>,
|
||||
|
|
@ -1122,6 +1182,12 @@ async fn server_branch_delete(
|
|||
),
|
||||
security(("bearer_token" = [])),
|
||||
)]
|
||||
/// Merge one branch into another.
|
||||
///
|
||||
/// Merges `source` into `target` (defaults to `main`). Outcome is one of
|
||||
/// `already_up_to_date`, `fast_forward`, or `merged`. Returns 409 with the
|
||||
/// list of conflicts if the merge cannot be completed; the target is left
|
||||
/// unchanged in that case. **Destructive** to `target` on success.
|
||||
async fn server_branch_merge(
|
||||
State(state): State<AppState>,
|
||||
actor: Option<Extension<AuthenticatedActor>>,
|
||||
|
|
@ -1165,6 +1231,11 @@ async fn server_branch_merge(
|
|||
),
|
||||
security(("bearer_token" = [])),
|
||||
)]
|
||||
/// List all runs.
|
||||
///
|
||||
/// A run is an ephemeral branch produced by an agent or background job. The
|
||||
/// list includes pending, in-progress, published, and aborted runs across
|
||||
/// all target branches. Read-only.
|
||||
async fn server_run_list(
|
||||
State(state): State<AppState>,
|
||||
actor: Option<Extension<AuthenticatedActor>>,
|
||||
|
|
@ -1207,6 +1278,10 @@ async fn server_run_list(
|
|||
),
|
||||
security(("bearer_token" = [])),
|
||||
)]
|
||||
/// Get a single run.
|
||||
///
|
||||
/// Returns the run's status, target/run branches, base snapshot, and (if
|
||||
/// published) the resulting snapshot id. Read-only.
|
||||
async fn server_run_show(
|
||||
State(state): State<AppState>,
|
||||
actor: Option<Extension<AuthenticatedActor>>,
|
||||
|
|
@ -1250,6 +1325,10 @@ async fn server_run_show(
|
|||
),
|
||||
security(("bearer_token" = [])),
|
||||
)]
|
||||
/// Publish a run to its target branch.
|
||||
///
|
||||
/// Promotes the run's snapshot onto its `target_branch` as a new commit. The
|
||||
/// run must be in a publishable state. **Destructive** to the target branch.
|
||||
async fn server_run_publish(
|
||||
State(state): State<AppState>,
|
||||
actor: Option<Extension<AuthenticatedActor>>,
|
||||
|
|
@ -1300,6 +1379,10 @@ async fn server_run_publish(
|
|||
),
|
||||
security(("bearer_token" = [])),
|
||||
)]
|
||||
/// Abort a run.
|
||||
///
|
||||
/// Marks the run as aborted and releases its working branch. **Irreversible**:
|
||||
/// the run cannot be resumed once aborted.
|
||||
async fn server_run_abort(
|
||||
State(state): State<AppState>,
|
||||
actor: Option<Extension<AuthenticatedActor>>,
|
||||
|
|
@ -1346,6 +1429,10 @@ async fn server_run_abort(
|
|||
),
|
||||
security(("bearer_token" = [])),
|
||||
)]
|
||||
/// List commits.
|
||||
///
|
||||
/// Filter by `branch` to get the commits on a single branch (most recent
|
||||
/// first); omit to list across all branches. Read-only.
|
||||
async fn server_commit_list(
|
||||
State(state): State<AppState>,
|
||||
actor: Option<Extension<AuthenticatedActor>>,
|
||||
|
|
@ -1391,6 +1478,10 @@ async fn server_commit_list(
|
|||
),
|
||||
security(("bearer_token" = [])),
|
||||
)]
|
||||
/// Get a single commit.
|
||||
///
|
||||
/// Returns the commit's manifest version, parent commit(s), and creation
|
||||
/// metadata. Read-only.
|
||||
async fn server_commit_show(
|
||||
State(state): State<AppState>,
|
||||
actor: Option<Extension<AuthenticatedActor>>,
|
||||
|
|
|
|||
117
openapi.json
117
openapi.json
|
|
@ -15,6 +15,8 @@
|
|||
"tags": [
|
||||
"branches"
|
||||
],
|
||||
"summary": "List all branches.",
|
||||
"description": "Returns branch names sorted alphabetically. Read-only.",
|
||||
"operationId": "listBranches",
|
||||
"responses": {
|
||||
"200": {
|
||||
|
|
@ -58,6 +60,8 @@
|
|||
"tags": [
|
||||
"branches"
|
||||
],
|
||||
"summary": "Create a new branch.",
|
||||
"description": "Forks `name` off of `from` (defaults to `main`). The new branch shares\ntable data with its parent until it is mutated. Returns 409 if `name`\nalready exists.",
|
||||
"operationId": "createBranch",
|
||||
"requestBody": {
|
||||
"content": {
|
||||
|
|
@ -133,6 +137,8 @@
|
|||
"tags": [
|
||||
"branches"
|
||||
],
|
||||
"summary": "Merge one branch into another.",
|
||||
"description": "Merges `source` into `target` (defaults to `main`). Outcome is one of\n`already_up_to_date`, `fast_forward`, or `merged`. Returns 409 with the\nlist of conflicts if the merge cannot be completed; the target is left\nunchanged in that case. **Destructive** to `target` on success.",
|
||||
"operationId": "mergeBranches",
|
||||
"requestBody": {
|
||||
"content": {
|
||||
|
|
@ -208,6 +214,8 @@
|
|||
"tags": [
|
||||
"branches"
|
||||
],
|
||||
"summary": "Delete a branch.",
|
||||
"description": "**Irreversible.** Removes the branch pointer; commits remain reachable\nonly if referenced by another branch. Returns 404 if the branch does not\nexist.",
|
||||
"operationId": "deleteBranch",
|
||||
"parameters": [
|
||||
{
|
||||
|
|
@ -274,6 +282,8 @@
|
|||
"tags": [
|
||||
"mutations"
|
||||
],
|
||||
"summary": "Apply a GQ mutation to a branch.",
|
||||
"description": "Writes to the named `branch` (defaults to `main`). Mutations are atomic\nper call and produce a new commit. Returns counts of nodes and edges\naffected. **Destructive**: on success the branch is updated; rejected\nmutations may still acquire locks briefly. Returns 409 on merge conflict.",
|
||||
"operationId": "change",
|
||||
"requestBody": {
|
||||
"content": {
|
||||
|
|
@ -349,6 +359,8 @@
|
|||
"tags": [
|
||||
"commits"
|
||||
],
|
||||
"summary": "List commits.",
|
||||
"description": "Filter by `branch` to get the commits on a single branch (most recent\nfirst); omit to list across all branches. Read-only.",
|
||||
"operationId": "listCommits",
|
||||
"parameters": [
|
||||
{
|
||||
|
|
@ -407,6 +419,8 @@
|
|||
"tags": [
|
||||
"commits"
|
||||
],
|
||||
"summary": "Get a single commit.",
|
||||
"description": "Returns the commit's manifest version, parent commit(s), and creation\nmetadata. Read-only.",
|
||||
"operationId": "getCommit",
|
||||
"parameters": [
|
||||
{
|
||||
|
|
@ -473,6 +487,8 @@
|
|||
"tags": [
|
||||
"queries"
|
||||
],
|
||||
"summary": "Stream the contents of a branch as NDJSON.",
|
||||
"description": "Emits one JSON object per line (`application/x-ndjson`). Filter with\n`type_names` (node/edge type names) and/or `table_keys`; both empty\nstreams the entire branch. Suitable for large exports — the response is\nstreamed, not buffered. Read-only.",
|
||||
"operationId": "export",
|
||||
"requestBody": {
|
||||
"content": {
|
||||
|
|
@ -534,6 +550,8 @@
|
|||
"tags": [
|
||||
"health"
|
||||
],
|
||||
"summary": "Liveness probe.",
|
||||
"description": "Returns server status and version. Unauthenticated; safe to call from any\ncaller. Use this to confirm the server is reachable before invoking other\nendpoints.",
|
||||
"operationId": "health",
|
||||
"responses": {
|
||||
"200": {
|
||||
|
|
@ -554,6 +572,8 @@
|
|||
"tags": [
|
||||
"mutations"
|
||||
],
|
||||
"summary": "Bulk-ingest NDJSON data into a branch.",
|
||||
"description": "`data` is NDJSON with one record per line. `mode` controls behavior on\nexisting rows: `merge` upserts by id (default), `append` blindly inserts,\n`overwrite` replaces table contents. If `branch` does not exist it is\ncreated from `from` (defaults to `main`). **Destructive** when `mode` is\n`overwrite` or when ingest produces conflicting writes.",
|
||||
"operationId": "ingest",
|
||||
"requestBody": {
|
||||
"content": {
|
||||
|
|
@ -619,6 +639,8 @@
|
|||
"tags": [
|
||||
"queries"
|
||||
],
|
||||
"summary": "Execute a GQ read query.",
|
||||
"description": "Runs the query in `query_source` against either a branch or a frozen\nsnapshot (mutually exclusive). When `query_source` defines multiple named\nqueries, pick one with `query_name`. `params` is a JSON object whose keys\nmatch the parameters declared by the query. Returns rows as a JSON array\nplus a `columns` list. Read-only.",
|
||||
"operationId": "read",
|
||||
"requestBody": {
|
||||
"content": {
|
||||
|
|
@ -684,6 +706,8 @@
|
|||
"tags": [
|
||||
"runs"
|
||||
],
|
||||
"summary": "List all runs.",
|
||||
"description": "A run is an ephemeral branch produced by an agent or background job. The\nlist includes pending, in-progress, published, and aborted runs across\nall target branches. Read-only.",
|
||||
"operationId": "listRuns",
|
||||
"responses": {
|
||||
"200": {
|
||||
|
|
@ -729,6 +753,8 @@
|
|||
"tags": [
|
||||
"runs"
|
||||
],
|
||||
"summary": "Get a single run.",
|
||||
"description": "Returns the run's status, target/run branches, base snapshot, and (if\npublished) the resulting snapshot id. Read-only.",
|
||||
"operationId": "getRun",
|
||||
"parameters": [
|
||||
{
|
||||
|
|
@ -795,6 +821,8 @@
|
|||
"tags": [
|
||||
"runs"
|
||||
],
|
||||
"summary": "Abort a run.",
|
||||
"description": "Marks the run as aborted and releases its working branch. **Irreversible**:\nthe run cannot be resumed once aborted.",
|
||||
"operationId": "abortRun",
|
||||
"parameters": [
|
||||
{
|
||||
|
|
@ -861,6 +889,8 @@
|
|||
"tags": [
|
||||
"runs"
|
||||
],
|
||||
"summary": "Publish a run to its target branch.",
|
||||
"description": "Promotes the run's snapshot onto its `target_branch` as a new commit. The\nrun must be in a publishable state. **Destructive** to the target branch.",
|
||||
"operationId": "publishRun",
|
||||
"parameters": [
|
||||
{
|
||||
|
|
@ -927,6 +957,8 @@
|
|||
"tags": [
|
||||
"schema"
|
||||
],
|
||||
"summary": "Read the current schema source.",
|
||||
"description": "Returns the project's schema as a single string in `.pg` source form.\nUseful for clients that want to introspect available types and tables\nbefore constructing GQ queries. Read-only.",
|
||||
"operationId": "getSchema",
|
||||
"responses": {
|
||||
"200": {
|
||||
|
|
@ -972,6 +1004,8 @@
|
|||
"tags": [
|
||||
"mutations"
|
||||
],
|
||||
"summary": "Apply a schema migration.",
|
||||
"description": "Diffs `schema_source` against the current schema and applies the resulting\nmigration steps (add/drop type, add/drop column, etc.). **Destructive**:\nsome steps drop data. Returns the list of steps applied; if `applied` is\nfalse the diff was unsupported and no changes were made.",
|
||||
"operationId": "applySchema",
|
||||
"requestBody": {
|
||||
"content": {
|
||||
|
|
@ -1037,6 +1071,8 @@
|
|||
"tags": [
|
||||
"snapshots"
|
||||
],
|
||||
"summary": "Read the current snapshot of a branch.",
|
||||
"description": "Returns the manifest version plus per-table metadata (path, version, row\ncount) for every table on the branch. Defaults to `main` when `branch` is\nomitted. Read-only.",
|
||||
"operationId": "getSnapshot",
|
||||
"parameters": [
|
||||
{
|
||||
|
|
@ -1128,10 +1164,12 @@
|
|||
"type": [
|
||||
"string",
|
||||
"null"
|
||||
]
|
||||
],
|
||||
"description": "Parent branch to fork from. Defaults to `main`."
|
||||
},
|
||||
"name": {
|
||||
"type": "string"
|
||||
"type": "string",
|
||||
"description": "Name of the new branch. Must not already exist."
|
||||
}
|
||||
}
|
||||
},
|
||||
|
|
@ -1210,13 +1248,15 @@
|
|||
],
|
||||
"properties": {
|
||||
"source": {
|
||||
"type": "string"
|
||||
"type": "string",
|
||||
"description": "Source branch whose commits will be merged."
|
||||
},
|
||||
"target": {
|
||||
"type": [
|
||||
"string",
|
||||
"null"
|
||||
]
|
||||
],
|
||||
"description": "Target branch that will receive the merge. Defaults to `main`."
|
||||
}
|
||||
}
|
||||
},
|
||||
|
|
@ -1261,17 +1301,23 @@
|
|||
"type": [
|
||||
"string",
|
||||
"null"
|
||||
]
|
||||
],
|
||||
"description": "Target branch. Defaults to `main`."
|
||||
},
|
||||
"params": {
|
||||
"description": "JSON object whose keys match the mutation's declared parameters."
|
||||
},
|
||||
"params": {},
|
||||
"query_name": {
|
||||
"type": [
|
||||
"string",
|
||||
"null"
|
||||
]
|
||||
],
|
||||
"description": "Name of the mutation to run when `query_source` declares multiple."
|
||||
},
|
||||
"query_source": {
|
||||
"type": "string"
|
||||
"type": "string",
|
||||
"description": "GQ mutation source containing `insert`, `update`, or `delete` statements.\nMay declare multiple named mutations; pick one with `query_name`.",
|
||||
"example": "query insert_person($name: String, $age: I32) {\n insert Person { name: $name, age: $age }\n}"
|
||||
}
|
||||
}
|
||||
},
|
||||
|
|
@ -1305,7 +1351,9 @@
|
|||
},
|
||||
"created_at": {
|
||||
"type": "integer",
|
||||
"format": "int64"
|
||||
"format": "int64",
|
||||
"description": "Commit creation time as Unix epoch microseconds.",
|
||||
"example": 1714000000000000
|
||||
},
|
||||
"graph_commit_id": {
|
||||
"type": "string"
|
||||
|
|
@ -1380,19 +1428,22 @@
|
|||
"type": [
|
||||
"string",
|
||||
"null"
|
||||
]
|
||||
],
|
||||
"description": "Branch to export. Defaults to `main`."
|
||||
},
|
||||
"table_keys": {
|
||||
"type": "array",
|
||||
"items": {
|
||||
"type": "string"
|
||||
}
|
||||
},
|
||||
"description": "Restrict the export to these table keys. Empty exports all tables."
|
||||
},
|
||||
"type_names": {
|
||||
"type": "array",
|
||||
"items": {
|
||||
"type": "string"
|
||||
}
|
||||
},
|
||||
"description": "Restrict the export to these node/edge type names. Empty exports all types."
|
||||
}
|
||||
}
|
||||
},
|
||||
|
|
@ -1467,16 +1518,20 @@
|
|||
"type": [
|
||||
"string",
|
||||
"null"
|
||||
]
|
||||
],
|
||||
"description": "Target branch. Created from `from` if it does not yet exist. Defaults to `main`."
|
||||
},
|
||||
"data": {
|
||||
"type": "string"
|
||||
"type": "string",
|
||||
"description": "NDJSON payload: one record per line, each shaped\n`{\"type\": \"<TypeName>\", \"data\": {...}}`.",
|
||||
"example": "{\"type\": \"Person\", \"data\": {\"name\": \"Alice\", \"age\": 30}}\n{\"type\": \"Person\", \"data\": {\"name\": \"Bob\", \"age\": 25}}"
|
||||
},
|
||||
"from": {
|
||||
"type": [
|
||||
"string",
|
||||
"null"
|
||||
]
|
||||
],
|
||||
"description": "Parent branch used to create `branch` if it does not exist. Defaults to `main`."
|
||||
},
|
||||
"mode": {
|
||||
"oneOf": [
|
||||
|
|
@ -1484,7 +1539,8 @@
|
|||
"type": "null"
|
||||
},
|
||||
{
|
||||
"$ref": "#/components/schemas/LoadMode"
|
||||
"$ref": "#/components/schemas/LoadMode",
|
||||
"description": "How existing rows are handled. Defaults to `merge`."
|
||||
}
|
||||
]
|
||||
}
|
||||
|
|
@ -1590,23 +1646,30 @@
|
|||
"type": [
|
||||
"string",
|
||||
"null"
|
||||
]
|
||||
],
|
||||
"description": "Branch to read from. Mutually exclusive with `snapshot`. Defaults to `main`."
|
||||
},
|
||||
"params": {
|
||||
"description": "JSON object whose keys match the query's declared parameters."
|
||||
},
|
||||
"params": {},
|
||||
"query_name": {
|
||||
"type": [
|
||||
"string",
|
||||
"null"
|
||||
]
|
||||
],
|
||||
"description": "Name of the query to run when `query_source` declares multiple. Optional\nwhen only one query is declared."
|
||||
},
|
||||
"query_source": {
|
||||
"type": "string"
|
||||
"type": "string",
|
||||
"description": "GQ query source. May declare one or more named queries; pick one with\n`query_name` if there is more than one.",
|
||||
"example": "query get_person($name: String) {\n match {\n $p: Person { name: $name }\n }\n return { $p.name, $p.age }\n}"
|
||||
},
|
||||
"snapshot": {
|
||||
"type": [
|
||||
"string",
|
||||
"null"
|
||||
]
|
||||
],
|
||||
"description": "Snapshot id to read from. Mutually exclusive with `branch`."
|
||||
}
|
||||
}
|
||||
},
|
||||
|
|
@ -1670,7 +1733,9 @@
|
|||
},
|
||||
"created_at": {
|
||||
"type": "integer",
|
||||
"format": "int64"
|
||||
"format": "int64",
|
||||
"description": "Run creation time as Unix epoch microseconds.",
|
||||
"example": 1714000000000000
|
||||
},
|
||||
"operation_hash": {
|
||||
"type": [
|
||||
|
|
@ -1698,7 +1763,9 @@
|
|||
},
|
||||
"updated_at": {
|
||||
"type": "integer",
|
||||
"format": "int64"
|
||||
"format": "int64",
|
||||
"description": "Last status change as Unix epoch microseconds.",
|
||||
"example": 1714000000000000
|
||||
}
|
||||
}
|
||||
},
|
||||
|
|
@ -1744,7 +1811,9 @@
|
|||
],
|
||||
"properties": {
|
||||
"schema_source": {
|
||||
"type": "string"
|
||||
"type": "string",
|
||||
"description": "Project schema in `.pg` source form. The diff against the current\nschema produces the migration steps that will be applied.",
|
||||
"example": "node Person {\n name: String @key\n age: I32?\n}\n\nedge Knows: Person -> Person"
|
||||
}
|
||||
}
|
||||
},
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue