Files
pubky-core/pubky-client
Severin Alexander Bühler 8a0cec71ef feat: Flexible endpoint rate limiting (#124)
* before ThrottledBody

* added upload rate limiting

* before dynamic rate limiting

* flexible rate limiter + config

* fixed tests

* fmt and clippy

* reset auth.js e2e

* more cleaning up

* improved code and added comments

* limit downloads too

* fmt and clippy

* improved sample comments

* fixed comment

* removed http dependency in favour of axum:http

* parse speed units as lowercase

* replaced regex with glob

* clippy and fmt
2025-05-13 11:06:23 +03:00
..

Pubky

Rust implementation implementation of Pubky client.

Quick Start

use pubky_testnet::EphemeralTestnet;
use pubky::Keypair;

#[tokio::main]
async fn main () {
  // Mainline Dht testnet and a temporary homeserver for unit testing.
  let testnet = EphemeralTestnet::start().await.unwrap();
  let client = testnet.pubky_client_builder().build().unwrap();

  let homeserver = testnet.homeserver_suite();

  // Generate a keypair
  let keypair = Keypair::random();

  // Signup to a Homeserver
  let keypair = Keypair::random();
  client.signup(&keypair, &homeserver.public_key(), None).await.unwrap();

  // Write data.
  let url = format!("pubky://{}/pub/foo.txt", keypair.public_key());
  let url = url.as_str();

  let data = [0, 1, 2, 3, 4].to_vec();

  // The client has the same familiar API of a reqwest client
  client.put(url).body(data.clone()).send().await.unwrap();

  // Read using a Public key based link
  let response = client.get(url).send().await.unwrap();
  let response_data = response.bytes().await.unwrap();

  assert_eq!(response_data, data);

  // Delete an entry.
  client.delete(url).send().await.unwrap();

  let response = client.get(url).send().await.unwrap();

  assert_eq!(response.status(), 404);
}

Example code

Check more examples for using the Pubky client.

Wasm Rust Analyzer

In vscode with the rust-analyzer, wasm behind the #[cfg(wasm_browser)] guard is not type checked. To fix this, add a .vscode/settings.json file in the root of this project with the following content:

{
    "rust-analyzer.cargo.target": "wasm32-unknown-unknown"
}

If not done already, you need to add the wasm target: cargo target add wasm32-unknown-unknown.

This is just a workaround because it enables the wasm feature in all workspace member which creates problems. So it is best to enable this settings only temporarily for wasm development and then turn it off again before commiting the changes. This is a rust-analyzer issue.

How To Build/Test the NPM Package

  1. Go to pubky-client/pkg.
  2. Run npm run build.
  3. Run a testnet mainline DHT, Pkarr relay and Homeserver npm run testnet
  4. Run tests with npm run test.