#client #status #segment #error #timeout #server #api #concord

concord-client

A client library for walmartlabs/concord written in async Rust

7 releases

Uses new Rust 2024

new 0.0.7 Apr 3, 2025
0.0.6 Mar 27, 2025
0.0.5 Aug 28, 2024
0.0.1 Jul 28, 2024

#13 in #segment

Download history 2/week @ 2024-12-11 6/week @ 2025-02-05 3/week @ 2025-02-12 134/week @ 2025-03-26

134 downloads per month

Apache-2.0

28KB
686 lines

concord-client

A work-in-progress high-level wrapper for Concord API. Uses tokio for async I/O.

Depends on reqwest and tokio-tungstenite for HTTP and WebSocket support, respectively.

Status

  • basic QueueClient implementation:
    • maintains a WebSocket connection to the Concord server
    • provides high-level API like next_process and next_command
    • graceful shutdown
    • automatic re-connection on errors
    • timeouts
  • basic ApiClient implementation:
    • can update process status
    • download process state
    • create and update log segments
    • timeouts
    • everything else

Code Conventions

  • warn! and error! messages should include how likely the error is a bug: (possibly a bug), (likely a bug), etc. ApiError messages, however, should not include this information, as the interpretation of the error is up to the caller.

Dependencies

~8–20MB
~266K SLoC