Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Sunset wasmer-registry, wasmer-interface and update misc dependencies #5181

Merged
merged 23 commits into from
Oct 28, 2024
Merged
Changes from 21 commits
Commits
Show all changes
23 commits
Select commit Hold shift + click to select a range
cd8ea4c
chore: Bump `time` crate
xdoardo Oct 22, 2024
ee3cc13
chore: Bump `tokio-serde`
xdoardo Oct 22, 2024
e504701
chore: Bump `chrono`
xdoardo Oct 22, 2024
d902628
chore: Bump `fuser`, `chrono` and `time` in CLI
xdoardo Oct 22, 2024
301587d
feat: Remove `wasmer-registry` and `wasmer-interface` crates
xdoardo Oct 25, 2024
d18ef70
chore: Make linter happy
xdoardo Oct 25, 2024
9710882
Merge branch 'main' into 5077-lots-of-cves
xdoardo Oct 25, 2024
938e51f
fix: Remove `wasmer-registry` from `Cargo.toml`.
xdoardo Oct 25, 2024
cecdd76
feat(config): Enable telemetry and notifications by default
xdoardo Oct 25, 2024
ee8b33b
fix(cli): Remove leftover `wasmer_registry`
xdoardo Oct 25, 2024
e3654b6
fix(cli/tests): `false` -> `true` in default wasmer config
xdoardo Oct 25, 2024
d15b6f2
chore: Make linter happy
xdoardo Oct 25, 2024
69ba1ac
chore: Use `proc-macro-error2` in `wasmer-derive`
xdoardo Oct 28, 2024
83c1ff1
fix(compiler/cranelift): Add `enable-serde` feature
xdoardo Oct 28, 2024
a060581
fix(compiler/singlepass): Add `enable-serde` feature
xdoardo Oct 28, 2024
5887ae8
fix(cli): Use `CliCommand` instead of `AsyncCliCommand`
xdoardo Oct 28, 2024
c25ec69
chore(cli): Add comment on why `tun-tap` was commented out
xdoardo Oct 28, 2024
96cd3ad
fix(cli): Use `argv[0]` to get program name
xdoardo Oct 28, 2024
80742a4
chore: Make linter happy
xdoardo Oct 28, 2024
0aa183b
Merge branch 'main' into 5077-lots-of-cves
xdoardo Oct 28, 2024
6f8f2fb
chore: Update `Cargo.lock`
xdoardo Oct 28, 2024
9b2047a
reset chrono to previous version
xdoardo Oct 28, 2024
ded01a6
fix(wasix): Reset `chrono` to latest
xdoardo Oct 28, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1,711 changes: 502 additions & 1,209 deletions Cargo.lock

Large diffs are not rendered by default.

25 changes: 11 additions & 14 deletions Cargo.toml
Original file line number Diff line number Diff line change
@@ -14,7 +14,7 @@ version.workspace = true
[dependencies]
wasmer = { version = "=5.0.0-rc.1", path = "lib/api", default-features = false }
wasmer-compiler = { version = "=5.0.0-rc.1", path = "lib/compiler", features = [
"compiler",
"compiler",
], optional = true }
wasmer-compiler-cranelift = { version = "=5.0.0-rc.1", path = "lib/compiler-cranelift", optional = true }
wasmer-compiler-singlepass = { version = "=5.0.0-rc.1", path = "lib/compiler-singlepass", optional = true }
@@ -31,9 +31,9 @@ wasmer-middlewares = { version = "=5.0.0-rc.1", path = "lib/middlewares", option
cfg-if = "1.0"

tokio = { version = "1.39", features = [
"rt",
"rt-multi-thread",
"macros",
"rt",
"rt-multi-thread",
"macros",
], optional = true }
crossbeam-queue = "0.3.8"

@@ -57,7 +57,6 @@ members = [
"lib/derive",
"lib/emscripten",
"lib/object",
"lib/registry",
"lib/sys-utils",
"lib/types",
"lib/virtual-io",
@@ -67,7 +66,6 @@ members = [
"lib/wai-bindgen-wasmer",
"lib/wasi-types",
"lib/wasix",
"lib/wasm-interface",
"lib/journal",
"lib/swift",
"lib/package",
@@ -78,9 +76,7 @@ members = [
"tests/wasi-wast",
"tests/wasmer-argus",
]
exclude = [
"./lib/cli/tests/packages/axum"
]
exclude = ["./lib/cli/tests/packages/axum"]
resolver = "2"

[workspace.package]
@@ -116,16 +112,17 @@ rkyv = { version = "0.8.8", features = ["indexmap-2", "bytes-1"] }
memmap2 = { version = "0.6.2" }
toml = { version = "0.5.9", features = ["preserve_order"] }
indexmap = "2"
serde_yaml = "0.9.34"
serde_yaml = { package = "serde_yml", version = "0.0.12" }
libc = { version = "^0.2", default-features = false }
gimli = { version = "0.28.1" }
futures-util = { version = "0.3.31" }
mio = "1"
# MIO 1.0 starts at tokio version 1.39, hence the minimum requirement.
tokio = { version = "1.39.0", default-features = false}
tokio = { version = "1.39.0", default-features = false }
socket2 = "0.5.7"
pretty_assertions = "1.4.0"
base64 = "0.22.0"
time = "0.3.36"

[build-dependencies]
test-generator = { path = "tests/lib/test-generator" }
@@ -136,9 +133,9 @@ rustc_version = "0.4"

[dev-dependencies]
wasmer = { version = "=5.0.0-rc.1", path = "lib/api", features = [
"compiler",
"singlepass",
"sys",
"compiler",
"singlepass",
"sys",
] }
anyhow = "1.0"
criterion = { version = "0.5", default-features = false }
17 changes: 15 additions & 2 deletions lib/backend-api/Cargo.toml
Original file line number Diff line number Diff line change
@@ -19,13 +19,12 @@ wasmer-config = { version = "0.9.0", path = "../config" }
wasmer-package.workspace = true
webc.workspace = true


# crates.io dependencies.
reqwest = { workspace = true, default-features = false, features = ["json"] }

anyhow = "1"
serde = { version = "1", features = ["derive"] }
time = { version = "0.3", features = ["formatting", "parsing"] }
time = { workspace = true, features = ["formatting", "parsing"] }
tokio = { workspace = true }
serde_json = "1"
url = { version = "2", features = ["serde"] }
@@ -37,6 +36,20 @@ serde_path_to_error = "0.1.14"
harsh = "0.2.2"
merge-streams = "0.1.2"


# Subscriptions.
graphql-ws-client = { version = "0.11.0", features = [
"tungstenite",
"client-cynic",
] }
tokio-tungstenite = { version = "0.24.0", features = [
"rustls-tls-native-roots",
] }
async-tungstenite = { version = "0.28.0", features = [
"tokio-runtime",
"tokio-rustls-native-certs",
] }

[target.'cfg(target_family = "wasm")'.dependencies.getrandom]
version = "0.2.14"
features = ["js"]
1 change: 1 addition & 0 deletions lib/backend-api/src/lib.rs
Original file line number Diff line number Diff line change
@@ -7,6 +7,7 @@ mod error;
pub mod global_id;
pub mod query;
pub mod stream;
pub mod subscription;
pub mod types;

use url::Url;
36 changes: 36 additions & 0 deletions lib/backend-api/src/query.rs
Original file line number Diff line number Diff line change
@@ -57,6 +57,42 @@ pub async fn redeploy_app_by_id(
.map(|v| v.redeploy_active_version.map(|v| v.app))
}

/// List all bindings associated with a particular package.
///
/// If a version number isn't provided, this will default to the most recently
/// published version.
pub async fn list_bindings(
client: &WasmerClient,
name: &str,
version: Option<&str>,
) -> Result<Vec<Bindings>, anyhow::Error> {
client
.run_graphql_strict(types::GetBindingsQuery::build(GetBindingsQueryVariables {
name,
version,
}))
.await
.and_then(|b| {
b.package_version
.ok_or(anyhow::anyhow!("No bindings found!"))
})
.map(|v| {
let mut bindings_packages = Vec::new();

for b in v.bindings.into_iter().flatten() {
let pkg = Bindings {
id: b.id.into_inner(),
url: b.url,
language: b.language,
generator: b.generator,
};
bindings_packages.push(pkg);
}

bindings_packages
})
}

/// Revoke an existing token
pub async fn revoke_token(
client: &WasmerClient,
64 changes: 64 additions & 0 deletions lib/backend-api/src/subscription.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,64 @@
use crate::{
types::{PackageVersionReadySubscription, PackageVersionReadySubscriptionVariables},
WasmerClient,
};
use anyhow::Context;
use async_tungstenite::tungstenite::client::IntoClientRequest;
use cynic::SubscriptionBuilder;
use graphql_ws_client::Subscription;
use reqwest::header::HeaderValue;
use std::future::IntoFuture;

pub async fn package_version_ready(
client: &WasmerClient,
package_version_id: &str,
) -> anyhow::Result<
Subscription<
cynic::StreamingOperation<
PackageVersionReadySubscription,
PackageVersionReadySubscriptionVariables,
>,
>,
> {
let mut url = client.graphql_endpoint().clone();
if url.scheme() == "http" {
url.set_scheme("ws").unwrap();
} else if url.scheme() == "https" {
url.set_scheme("wss").unwrap();
}

let url = url.to_string();
let mut req = url.into_client_request()?;

req.headers_mut().insert(
"Sec-WebSocket-Protocol",
HeaderValue::from_str("graphql-transport-ws").unwrap(),
);

if let Some(token) = client.auth_token() {
req.headers_mut().insert(
reqwest::header::AUTHORIZATION,
HeaderValue::from_str(&format!("Bearer {}", token))?,
);
}

req.headers_mut()
.insert(reqwest::header::USER_AGENT, client.user_agent.clone());

let (connection, _resp) = async_tungstenite::tokio::connect_async(req)
.await
.context("could not connect")?;

let (client, actor) = graphql_ws_client::Client::build(connection).await?;
tokio::spawn(actor.into_future());

let stream = client
.subscribe(PackageVersionReadySubscription::build(
PackageVersionReadySubscriptionVariables {
package_version_id: cynic::Id::new(package_version_id),
},
))
.await?;

Ok(stream)
}
83 changes: 83 additions & 0 deletions lib/backend-api/src/types.rs
Original file line number Diff line number Diff line change
@@ -2171,6 +2171,89 @@ mod queries {
#[derive(cynic::Scalar, Debug, Clone)]
pub struct BigInt(pub i64);

#[derive(cynic::Enum, Clone, Copy, Debug, PartialEq, Eq)]
pub enum ProgrammingLanguage {
Python,
Javascript,
}

/// A library that exposes bindings to a Wasmer package.
#[derive(Debug, Clone)]
pub struct Bindings {
/// A unique ID specifying this set of bindings.
pub id: String,
/// The URL which can be used to download the files that were generated
/// (typically as a `*.tar.gz` file).
pub url: String,
/// The programming language these bindings are written in.
pub language: ProgrammingLanguage,
/// The generator used to generate these bindings.
pub generator: BindingsGenerator,
}

#[derive(cynic::QueryVariables, Debug, Clone)]
pub struct GetBindingsQueryVariables<'a> {
pub name: &'a str,
pub version: Option<&'a str>,
}

#[derive(cynic::QueryFragment, Debug, Clone)]
#[cynic(graphql_type = "Query", variables = "GetBindingsQueryVariables")]
pub struct GetBindingsQuery {
#[arguments(name: $name, version: $version)]
#[cynic(rename = "getPackageVersion")]
pub package_version: Option<PackageBindingsVersion>,
}

#[derive(cynic::QueryFragment, Debug, Clone)]
#[cynic(graphql_type = "PackageVersion")]
pub struct PackageBindingsVersion {
pub bindings: Vec<Option<PackageVersionLanguageBinding>>,
}

#[derive(cynic::QueryFragment, Debug, Clone)]
pub struct BindingsGenerator {
pub package_version: PackageVersion,
pub command_name: String,
}

#[derive(cynic::QueryFragment, Debug, Clone)]
pub struct PackageVersionLanguageBinding {
pub id: cynic::Id,
pub language: ProgrammingLanguage,
pub url: String,
pub generator: BindingsGenerator,
pub __typename: String,
}

#[derive(cynic::QueryVariables, Debug)]
pub struct PackageVersionReadySubscriptionVariables {
pub package_version_id: cynic::Id,
}

#[derive(cynic::QueryFragment, Debug)]
#[cynic(
graphql_type = "Subscription",
variables = "PackageVersionReadySubscriptionVariables"
)]
pub struct PackageVersionReadySubscription {
#[arguments(packageVersionId: $package_version_id)]
pub package_version_ready: PackageVersionReadyResponse,
}

#[derive(cynic::QueryFragment, Debug)]
pub struct PackageVersionReadyResponse {
pub state: PackageVersionState,
pub success: bool,
}

#[derive(cynic::Enum, Clone, Copy, Debug)]
pub enum PackageVersionState {
WebcGenerated,
BindingsGenerated,
NativeExesGenerated,
}

#[derive(cynic::InlineFragments, Debug, Clone)]
#[cynic(graphql_type = "Node", variables = "GetDeployAppVersionsByIdVars")]
pub enum NodeDeployAppVersions {
Loading