mirror of
https://github.com/NexVeridian/ark-invest-api-rust.git
synced 2025-09-02 01:49:11 +00:00
normalize arkvx
This commit is contained in:
parent
9426313f73
commit
6343159387
5 changed files with 17 additions and 29 deletions
4
.github/workflows/nextest.yml
vendored
4
.github/workflows/nextest.yml
vendored
|
@ -16,7 +16,7 @@ env:
|
|||
|
||||
jobs:
|
||||
run-tests:
|
||||
name: Run tests
|
||||
name: run tests
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- uses: actions/checkout@v3
|
||||
|
@ -31,7 +31,7 @@ jobs:
|
|||
run: cargo nextest run -E "all() - test(get_api) - kind(bin)"
|
||||
|
||||
clippy:
|
||||
name: Clippy
|
||||
name: clippy
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- uses: actions/checkout@v3
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
version: "3"
|
||||
services:
|
||||
ark-invest-api-rust:
|
||||
image: ghcr.io/NexVeridian/ark-invest-api-rust:latest
|
||||
image: ghcr.io/nexveridian/ark-invest-api-rust:latest
|
||||
container_name: ark-invest-api-rust
|
||||
restart: unless-stopped
|
||||
volumes:
|
||||
|
|
22
src/main.rs
22
src/main.rs
|
@ -86,28 +86,20 @@ async fn main() {
|
|||
.layer(CompressionLayer::new().zstd(true))
|
||||
.route("/api.json", get(serve_api))
|
||||
.layer(CompressionLayer::new().zstd(true))
|
||||
.api_route(
|
||||
"/arkvc_holdings",
|
||||
get_with(routes::arkvc_holdings, |mut o| {
|
||||
o = o.id("ARKVC Holdings");
|
||||
description_date(o)
|
||||
}),
|
||||
)
|
||||
.layer(
|
||||
rate_limit_global(500)
|
||||
.layer(rate_limit_ip())
|
||||
.layer(cors())
|
||||
.layer(CompressionLayer::new().zstd(true)),
|
||||
)
|
||||
.api_route(
|
||||
"/ark_holdings",
|
||||
get_with(routes::ark_holdings, |mut o| {
|
||||
o = o.id("ARK* ETF Holdings");
|
||||
// test description
|
||||
o = o.id("ARK* ETF Holdings").description(r"
|
||||
| date ┆ ticker ┆ cusip ┆ company ┆ market_value ┆ shares ┆ share_price ┆ weight │
|
||||
│ --- ┆ --- ┆ --- ┆ --- ┆ --- ┆ --- ┆ --- ┆ --- │
|
||||
│ date ┆ str ┆ str ┆ str ┆ i64 ┆ f64 ┆ f64 ┆ f64 │
|
||||
");
|
||||
description_date(o)
|
||||
}),
|
||||
)
|
||||
.layer(
|
||||
rate_limit_global(200)
|
||||
rate_limit_global(1000)
|
||||
.layer(rate_limit_ip())
|
||||
.layer(cors())
|
||||
.layer(CompressionLayer::new().zstd(true)),
|
||||
|
|
|
@ -3,16 +3,6 @@ use axum::extract::Query;
|
|||
|
||||
mod polars_utils;
|
||||
|
||||
pub async fn arkvc_holdings(date_range: Query<polars_utils::DateRange>) -> impl IntoApiResponse {
|
||||
let df = polars_utils::get_parquet("ARKVC".to_owned()).await.unwrap();
|
||||
|
||||
let filter_df = polars_utils::filter_date_range(df, date_range)
|
||||
.await
|
||||
.unwrap();
|
||||
|
||||
axum::Json(polars_utils::to_json(filter_df).await.unwrap())
|
||||
}
|
||||
|
||||
pub async fn ark_holdings(
|
||||
ticker: Query<polars_utils::Ticker>,
|
||||
date_range: Query<polars_utils::DateRange>,
|
||||
|
|
|
@ -56,13 +56,19 @@ pub async fn filter_date_range(
|
|||
}
|
||||
|
||||
#[derive(Serialize, Deserialize, JsonSchema, strum_macros::Display)]
|
||||
pub enum TypeTicker {
|
||||
pub enum Ticker {
|
||||
ARKVX,
|
||||
ARKF,
|
||||
ARKG,
|
||||
ARKK,
|
||||
ARKQ,
|
||||
ARKW,
|
||||
ARKX,
|
||||
// ARKA,
|
||||
// ARKZ,
|
||||
ARKC,
|
||||
ARKD,
|
||||
ARKY,
|
||||
}
|
||||
|
||||
#[derive(Serialize, Deserialize, JsonSchema)]
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue