forked from andrusha/snowflake-rs
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathjson_api.rs
86 lines (72 loc) · 2.2 KB
/
json_api.rs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
use anyhow::{Context, Result};
use clap::Parser;
use std::fs;
extern crate snowflake_jwt;
#[derive(Parser, Debug)]
#[command(author, version, about, long_about = None)]
struct Args {
/// Path to RSA PEM private key
#[arg(long)]
private_key: String,
/// <account_identifier> in Snowflake format, uppercase
#[arg(short, long)]
account_identifier: String,
/// Database name
#[arg(short, long)]
database: String,
/// Schema name
#[arg(long)]
schema: String,
/// Warehouse
#[arg(short, long)]
warehouse: String,
/// username to whom the private key belongs to
#[arg(short, long)]
username: String,
/// role which user will assume
#[arg(short, long)]
role: String,
/// sql statement to execute and print result from
#[arg(long)]
sql: String,
}
fn main() -> Result<()> {
let args = Args::parse();
let pem = fs::read_to_string(&args.private_key)?;
let full_identifier = format!("{}.{}", &args.account_identifier, &args.username);
let jwt = snowflake_jwt::generate_jwt_token(&pem, &full_identifier)?;
println!("{}", &args.sql);
let url = format!(
"https://{}.snowflakecomputing.com/api/v2/statements",
&args.account_identifier
);
let auth = format!("Bearer {}", &jwt);
let resp = ureq::post(&url)
.set("X-Snowflake-Authorization-Token-Type", "KEYPAIR_JWT")
.set("Authorization", &auth)
.set("User-Agent", "myApplicationName/1.0")
.send_json(ureq::json!({
"statement": &args.sql,
"timeout": 60,
"database": &args.database,
"schema": &args.schema,
"warehouse": &args.warehouse,
"role": &args.role
}));
match resp {
Ok(r) => {
println!("{}", r.into_string()?);
}
Err(ureq::Error::Status(code, r)) => {
let rstr = r.into_string().context("consuming response")?;
println!(
"failed to execute statement, server replied with {}, {}",
code, rstr
);
}
Err(ureq::Error::Transport(tr)) => {
println!("transport error: {:?}", tr);
}
}
Ok(())
}