feat(wfe-containerd-protos): generate full containerd gRPC API (tonic 0.14)
New crate generating Rust gRPC stubs from the official containerd proto files (vendored as git submodule). Full client-facing API surface using tonic 0.14 / prost 0.14. No transitive dependency conflicts. Services: containers, content, diff, events, images, introspection, leases, mounts, namespaces, sandbox, snapshots, streaming, tasks, transfer, version.
This commit is contained in:
3
.gitmodules
vendored
Normal file
3
.gitmodules
vendored
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
[submodule "wfe-containerd-protos/vendor/containerd"]
|
||||||
|
path = wfe-containerd-protos/vendor/containerd
|
||||||
|
url = https://github.com/containerd/containerd.git
|
||||||
@@ -1,5 +1,5 @@
|
|||||||
[workspace]
|
[workspace]
|
||||||
members = ["wfe-core", "wfe-sqlite", "wfe-postgres", "wfe-opensearch", "wfe-valkey", "wfe", "wfe-yaml", "wfe-buildkit", "wfe-containerd"]
|
members = ["wfe-core", "wfe-sqlite", "wfe-postgres", "wfe-opensearch", "wfe-valkey", "wfe", "wfe-yaml", "wfe-buildkit", "wfe-containerd", "wfe-containerd-protos"]
|
||||||
resolver = "2"
|
resolver = "2"
|
||||||
|
|
||||||
[workspace.package]
|
[workspace.package]
|
||||||
|
|||||||
19
wfe-containerd-protos/Cargo.toml
Normal file
19
wfe-containerd-protos/Cargo.toml
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
[package]
|
||||||
|
name = "wfe-containerd-protos"
|
||||||
|
version.workspace = true
|
||||||
|
edition.workspace = true
|
||||||
|
license.workspace = true
|
||||||
|
repository.workspace = true
|
||||||
|
homepage.workspace = true
|
||||||
|
description = "Generated gRPC stubs for the full containerd API"
|
||||||
|
|
||||||
|
[dependencies]
|
||||||
|
tonic = "0.14"
|
||||||
|
tonic-prost = "0.14"
|
||||||
|
prost = "0.14"
|
||||||
|
prost-types = "0.14"
|
||||||
|
|
||||||
|
[build-dependencies]
|
||||||
|
tonic-build = "0.14"
|
||||||
|
tonic-prost-build = "0.14"
|
||||||
|
prost-build = "0.14"
|
||||||
50
wfe-containerd-protos/build.rs
Normal file
50
wfe-containerd-protos/build.rs
Normal file
@@ -0,0 +1,50 @@
|
|||||||
|
use std::path::PathBuf;
|
||||||
|
|
||||||
|
fn main() -> Result<(), Box<dyn std::error::Error>> {
|
||||||
|
let api_dir = PathBuf::from("vendor/containerd/api");
|
||||||
|
|
||||||
|
// Collect all .proto files, excluding internal runtime shim protos
|
||||||
|
let proto_files: Vec<PathBuf> = walkdir(&api_dir)?
|
||||||
|
.into_iter()
|
||||||
|
.filter(|p| {
|
||||||
|
let s = p.to_string_lossy();
|
||||||
|
!s.contains("/runtime/task/") && !s.contains("/runtime/sandbox/")
|
||||||
|
})
|
||||||
|
.collect();
|
||||||
|
|
||||||
|
println!(
|
||||||
|
"cargo:warning=Compiling {} containerd proto files",
|
||||||
|
proto_files.len()
|
||||||
|
);
|
||||||
|
|
||||||
|
let out_dir = PathBuf::from(std::env::var("OUT_DIR")?);
|
||||||
|
|
||||||
|
// Use tonic-prost-build (the tonic 0.14 way)
|
||||||
|
let mut prost_config = prost_build::Config::new();
|
||||||
|
prost_config.include_file("mod.rs");
|
||||||
|
|
||||||
|
tonic_prost_build::configure()
|
||||||
|
.build_server(false)
|
||||||
|
.compile_with_config(
|
||||||
|
prost_config,
|
||||||
|
&proto_files,
|
||||||
|
&[api_dir, PathBuf::from("proto")],
|
||||||
|
)?;
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Recursively collect all .proto files under a directory.
|
||||||
|
fn walkdir(dir: &PathBuf) -> Result<Vec<PathBuf>, Box<dyn std::error::Error>> {
|
||||||
|
let mut protos = Vec::new();
|
||||||
|
for entry in std::fs::read_dir(dir)? {
|
||||||
|
let entry = entry?;
|
||||||
|
let path = entry.path();
|
||||||
|
if path.is_dir() {
|
||||||
|
protos.extend(walkdir(&path)?);
|
||||||
|
} else if path.extension().is_some_and(|ext| ext == "proto") {
|
||||||
|
protos.push(path);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Ok(protos)
|
||||||
|
}
|
||||||
49
wfe-containerd-protos/proto/google/rpc/status.proto
Normal file
49
wfe-containerd-protos/proto/google/rpc/status.proto
Normal file
@@ -0,0 +1,49 @@
|
|||||||
|
// Copyright 2025 Google LLC
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
|
||||||
|
syntax = "proto3";
|
||||||
|
|
||||||
|
package google.rpc;
|
||||||
|
|
||||||
|
import "google/protobuf/any.proto";
|
||||||
|
|
||||||
|
option cc_enable_arenas = true;
|
||||||
|
option go_package = "google.golang.org/genproto/googleapis/rpc/status;status";
|
||||||
|
option java_multiple_files = true;
|
||||||
|
option java_outer_classname = "StatusProto";
|
||||||
|
option java_package = "com.google.rpc";
|
||||||
|
option objc_class_prefix = "RPC";
|
||||||
|
|
||||||
|
// The `Status` type defines a logical error model that is suitable for
|
||||||
|
// different programming environments, including REST APIs and RPC APIs. It is
|
||||||
|
// used by [gRPC](https://github.com/grpc). Each `Status` message contains
|
||||||
|
// three pieces of data: error code, error message, and error details.
|
||||||
|
//
|
||||||
|
// You can find out more about this error model and how to work with it in the
|
||||||
|
// [API Design Guide](https://cloud.google.com/apis/design/errors).
|
||||||
|
message Status {
|
||||||
|
// The status code, which should be an enum value of
|
||||||
|
// [google.rpc.Code][google.rpc.Code].
|
||||||
|
int32 code = 1;
|
||||||
|
|
||||||
|
// A developer-facing error message, which should be in English. Any
|
||||||
|
// user-facing error message should be localized and sent in the
|
||||||
|
// [google.rpc.Status.details][google.rpc.Status.details] field, or localized
|
||||||
|
// by the client.
|
||||||
|
string message = 2;
|
||||||
|
|
||||||
|
// A list of messages that carry the error details. There is a common set of
|
||||||
|
// message types for APIs to use.
|
||||||
|
repeated google.protobuf.Any details = 3;
|
||||||
|
}
|
||||||
27
wfe-containerd-protos/src/lib.rs
Normal file
27
wfe-containerd-protos/src/lib.rs
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
//! Generated gRPC stubs for the full containerd API.
|
||||||
|
//!
|
||||||
|
//! Built from the official containerd proto files at
|
||||||
|
//! <https://github.com/containerd/containerd/tree/main/api>.
|
||||||
|
//!
|
||||||
|
//! The module structure mirrors the protobuf package hierarchy:
|
||||||
|
//!
|
||||||
|
//! ```rust,ignore
|
||||||
|
//! use wfe_containerd_protos::containerd::services::containers::v1::containers_client::ContainersClient;
|
||||||
|
//! use wfe_containerd_protos::containerd::services::tasks::v1::tasks_client::TasksClient;
|
||||||
|
//! use wfe_containerd_protos::containerd::services::images::v1::images_client::ImagesClient;
|
||||||
|
//! use wfe_containerd_protos::containerd::services::version::v1::version_client::VersionClient;
|
||||||
|
//! use wfe_containerd_protos::containerd::types::Mount;
|
||||||
|
//! use wfe_containerd_protos::containerd::types::Descriptor;
|
||||||
|
//! ```
|
||||||
|
|
||||||
|
#![allow(clippy::all)]
|
||||||
|
#![allow(warnings)]
|
||||||
|
|
||||||
|
// tonic-build generates a mod.rs that defines the full module tree
|
||||||
|
// matching the protobuf package structure.
|
||||||
|
include!(concat!(env!("OUT_DIR"), "/mod.rs"));
|
||||||
|
|
||||||
|
/// Re-export tonic and prost for downstream convenience.
|
||||||
|
pub use prost;
|
||||||
|
pub use prost_types;
|
||||||
|
pub use tonic;
|
||||||
1
wfe-containerd-protos/vendor/containerd
vendored
Submodule
1
wfe-containerd-protos/vendor/containerd
vendored
Submodule
Submodule wfe-containerd-protos/vendor/containerd added at 546ce38287
Reference in New Issue
Block a user