Skip to content

Commit

Permalink
feat(ci): add stainless generation to ci
Browse files Browse the repository at this point in the history
  • Loading branch information
zcabter committed Nov 14, 2024
1 parent 94b3709 commit 430ce5a
Show file tree
Hide file tree
Showing 5 changed files with 190 additions and 14 deletions.
19 changes: 19 additions & 0 deletions .github/workflows/generate-node-client.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
name: Upload OpenAPI spec to Stainless

on:
pull_request: # testing only
push:
branches: [main]

jobs:
stainless:
concurrency: upload-openapi-spec-action
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: stainless-api/upload-openapi-spec-action@main
with:
stainless_api_key: ${{ secrets.STAINLESS_API_KEY }}
input_path: "crates/jstz_node/openapi.json"
config_path: "crates/jstz_node/stainless.yml"
project_name: "jstz-client"
23 changes: 15 additions & 8 deletions crates/jstz_node/openapi.json
Original file line number Diff line number Diff line change
Expand Up @@ -440,7 +440,8 @@
}
}
}
]
],
"title": "DeployFunction"
},
{
"allOf": [
Expand All @@ -461,7 +462,8 @@
}
}
}
]
],
"title": "RunFunction"
}
]
},
Expand Down Expand Up @@ -679,7 +681,8 @@
}
}
}
]
],
"title": "DeployFunctionReceipt"
},
{
"allOf": [
Expand All @@ -700,10 +703,12 @@
}
}
}
]
],
"title": "RunFunctionReceipt"
},
{
"type": "object",
"title": "DepositReceipt",
"required": [
"#type"
],
Expand Down Expand Up @@ -735,7 +740,8 @@
}
}
}
]
],
"title": "FaDepositReceipt"
},
{
"allOf": [
Expand All @@ -756,7 +762,8 @@
}
}
}
]
],
"title": "FaWithdrawReceipt"
}
]
},
Expand Down Expand Up @@ -821,7 +828,7 @@
},
"headers": {
"type": "object",
"description": "Any valid HTTP headers"
"additionalProperties": true
},
"method": {
"type": "string",
Expand Down Expand Up @@ -865,7 +872,7 @@
},
"headers": {
"type": "object",
"description": "Any valid HTTP headers"
"additionalProperties": true
},
"status_code": {
"type": "integer",
Expand Down
133 changes: 133 additions & 0 deletions crates/jstz_node/stainless.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,133 @@
# yaml-language-server: $schema=https://app.stainlessapi.com/config.schema.json

organization:
# Name of your organization or company, used to determine the name of the client
# and headings.
name: jstz client # Strangely, the organisation name is used as the name of the root class
docs: https://jstz-dev.github.io/jstz/
contact: [email protected]

# `targets` define the output targets and their customization options, such as
# whether to emit the Node SDK and what it's package name should be.
targets:
node:
readme_title: Jstz Client
package_name: "@jstz-dev/client"
production_repo: null
publish:
npm: false

# `client_settings` define settings for the API client, such as extra constructor
# arguments (used for authentication), retry behavior, idempotency, etc.
client_settings:
opts: {}

# `environments` are a map of the name of the environment (e.g. "sandbox",
# "production") to the corresponding url to use.
environments:
production: https://localhost:8933

# `pagination` defines [pagination schemes] which provides a template to match
# endpoints and generate next-page and auto-pagination helpers in the SDKs.
pagination: []

# `resources` define the structure and organziation for your API, such as how
# methods and models are grouped together and accessed. See the [configuration
# guide] for more information.
#
# [configuration guide]:
# https://app.stainlessapi.com/docs/guides/configure#resources
resources:
accounts:
# Subresources define resources that are nested within another for more powerful
# logical groupings, e.g. `cards.payments`.
subresources:
balance:
# Configure the methods defined in this resource. Each key in the object is the
# name of the method and the value is either an endpoint (for example, `get /foo`)
# or an object with more detail.
#
# [reference]: https://app.stainlessapi.com/docs/reference/config#method
methods:
retrieve: get /accounts/{address}/balance
code:
# Configure the models--named types--defined in the resource. Each key in the
# object is the name of the model and the value is either the name of a schema in
# `#/components/schemas` or an object with more detail.
#
# [reference]: https://app.stainlessapi.com/docs/reference/config#model
models:
parsedCode: ParsedCode
methods:
retrieve: get /accounts/{address}/code
kv:
models:
kvValue: KvValue
methods:
retrieve: get /accounts/{address}/kv
subresources:
subkeys:
methods:
list:
type: http
endpoint: get /accounts/{address}/kv/subkeys
paginated: false
nonce:
models:
nonce: Nonce
methods:
retrieve: get /accounts/{address}/nonce

logs:
models:
logRecord: LogRecord
methods:
stream: get /logs/{address}/stream
subresources:
persistent_requests:
methods:
list:
type: http
endpoint: get /logs/{address}/persistent/requests
paginated: false
retrieve: get /logs/{address}/persistent/requests/{request_id}

operations:
methods:
inject: post /operations
subresources:
receipt:
models:
receipt: Receipt
methods:
retrieve: get /operations/{operation_hash}/receipt

crypto:
models:
publicKey: PublicKey
publicKeyHash: PublicKeyHash
signature: Signature

settings:
license: Apache-2.0

# `readme` is used to configure the code snippets that will be rendered in the
# README.md of various SDKs. In particular, you can change the `headline`
# snippet's endpoint and the arguments to call it with.
readme:
example_requests:
default:
type: request
endpoint: get /accounts/{address}/code
params: &ref_0
address: REPLACE_ME
headline:
type: request
endpoint: get /accounts/{address}/code
params: *ref_0
pagination:
type: request
endpoint: get /accounts/{address}/kv/subkeys
params:
address: REPLACE_ME
include_stainless_attribution: false
18 changes: 13 additions & 5 deletions crates/jstz_proto/src/operation.rs
Original file line number Diff line number Diff line change
Expand Up @@ -109,10 +109,7 @@ pub struct RunFunction {
pub method: Method,
/// Any valid HTTP headers
#[serde(with = "http_serde::header_map")]
#[schema(
value_type = Object,
additional_properties,
)]
#[schema(schema_with= openapi::http_headers)]
pub headers: HeaderMap,
#[schema(schema_with = openapi::http_body_schema)]
pub body: HttpBody,
Expand All @@ -123,7 +120,9 @@ pub struct RunFunction {
#[derive(Debug, Serialize, Deserialize, PartialEq, Eq, Clone, ToSchema)]
#[serde(tag = "#type")]
pub enum Content {
#[schema(title = "DeployFunction")]
DeployFunction(DeployFunction),
#[schema(title = "RunFunction")]
RunFunction(RunFunction),
}

Expand Down Expand Up @@ -215,9 +214,18 @@ pub enum ExternalOperation {
}

pub mod openapi {
use utoipa::{openapi::Array, schema};
use utoipa::{
openapi::{schema::AdditionalProperties, Array, Object, ObjectBuilder},
schema,
};

pub fn http_body_schema() -> Array {
schema!(Option<Vec<u8>>).build()
}

pub fn http_headers() -> Object {
ObjectBuilder::new()
.additional_properties(Some(AdditionalProperties::FreeForm(true)))
.build()
}
}
11 changes: 10 additions & 1 deletion crates/jstz_proto/src/receipt.rs
Original file line number Diff line number Diff line change
Expand Up @@ -46,17 +46,26 @@ pub struct RunFunctionReceipt {
pub status_code: StatusCode,
/// Any valid HTTP headers
#[serde(with = "http_serde::header_map")]
#[schema(value_type = Object, additional_properties)]
#[schema(schema_with = crate::operation::openapi::http_headers)]
pub headers: HeaderMap,
}

#[derive(Debug, Clone, Serialize, Deserialize, ToSchema)]
#[serde(tag = "#type")]
pub enum ReceiptContent {
#[schema(title = "DeployFunctionReceipt")]
DeployFunction(DeployFunctionReceipt),

#[schema(title = "RunFunctionReceipt")]
RunFunction(RunFunctionReceipt),

#[schema(title = "DepositReceipt")]
Deposit,

#[schema(title = "FaDepositReceipt")]
FaDeposit(FaDepositReceipt),

#[schema(title = "FaWithdrawReceipt")]
FaWithdraw(FaWithdrawReceipt),
}

Expand Down

0 comments on commit 430ce5a

Please sign in to comment.