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

Add back the relay #1134

Closed
wants to merge 2 commits into from
Closed

Add back the relay #1134

wants to merge 2 commits into from

Conversation

tomaka
Copy link
Member

@tomaka tomaka commented May 19, 2019

Fix #725

Non-working work-in-progress.
Adds back the relay protocol.

Continuing this PR is basically blocked on resolving the questions in #725.

@dingxiangfei2009
Copy link

Hello, @tomaka. I wonder if you still have interest in the work to reinstate support for circuit relay at the moment. Would you mind that I take this partial work and try to complete it? 😄

@tomaka
Copy link
Member Author

tomaka commented May 22, 2020

Hi, sure!
From what I remember, the work on this PR wasn't really being blocked on anything.
You might encounter some of the challenges described in #725.

If you work on this, be aware that at the moment I might unfortunately not necessarily have the time to answer questions about difficulties that you might face.

@mxinden
Copy link
Member

mxinden commented Oct 19, 2020

A rudimentary merge of current master that compiles can be found here: mxinden@ccbc906

@mxinden
Copy link
Member

mxinden commented Nov 15, 2020

Closing here in favor of #1838.

@mxinden mxinden closed this Nov 15, 2020
mxinden added a commit that referenced this pull request Mar 11, 2021
This commit implements the [libp2p circuit
relay](https://github.com/libp2p/specs/tree/master/relay) specification. It is
based on previous work from #1134.

Instead of altering the `Transport` trait, the approach taken in this commit
is to wrap an existing implementation of `Transport` allowing one to:

- Intercept `dial` requests with a relayed address.

- Inject incoming relayed connections with the local node being the destination.

- Intercept `listen_on` requests pointing to a relay, ensuring to keep a
  constant connection to the relay, waiting for incoming requests with the local
  node being the destination.

More concretely one would wrap an existing `Transport` implementation as seen
below, allowing the `Relay` behaviour and the `RelayTransport` to communicate
via channels.

### Example

```rust
let (relay_transport, relay_behaviour) = new_transport_and_behaviour(
    RelayConfig::default(),
    MemoryTransport::default(),
);

let transport = relay_transport
    .upgrade(upgrade::Version::V1)
    .authenticate(plaintext)
    .multiplex(YamuxConfig::default())
    .boxed();

let mut swarm = Swarm::new(transport, relay_behaviour, local_peer_id);

let relay_addr = Multiaddr::from_str("/memory/1234").unwrap()
    .with(Protocol::P2p(PeerId::random().into()))
    .with(Protocol::P2pCircuit);
let dst_addr = relay_addr.clone().with(Protocol::Memory(5678));

// Listen for incoming connections via relay node (1234).
Swarm::listen_on(&mut swarm, relay_addr).unwrap();

// Dial node (5678) via relay node (1234).
Swarm::dial_addr(&mut swarm, dst_addr).unwrap();
```

Co-authored-by: Pierre Krieger <[email protected]>
Co-authored-by: Roman Borschel <[email protected]>
Co-authored-by: David Craven <[email protected]>
santos227 pushed a commit to santos227/rustlib that referenced this pull request Jun 20, 2022
This commit implements the [libp2p circuit
relay](https://github.com/libp2p/specs/tree/master/relay) specification. It is
based on previous work from libp2p/rust-libp2p#1134.

Instead of altering the `Transport` trait, the approach taken in this commit
is to wrap an existing implementation of `Transport` allowing one to:

- Intercept `dial` requests with a relayed address.

- Inject incoming relayed connections with the local node being the destination.

- Intercept `listen_on` requests pointing to a relay, ensuring to keep a
  constant connection to the relay, waiting for incoming requests with the local
  node being the destination.

More concretely one would wrap an existing `Transport` implementation as seen
below, allowing the `Relay` behaviour and the `RelayTransport` to communicate
via channels.

### Example

```rust
let (relay_transport, relay_behaviour) = new_transport_and_behaviour(
    RelayConfig::default(),
    MemoryTransport::default(),
);

let transport = relay_transport
    .upgrade(upgrade::Version::V1)
    .authenticate(plaintext)
    .multiplex(YamuxConfig::default())
    .boxed();

let mut swarm = Swarm::new(transport, relay_behaviour, local_peer_id);

let relay_addr = Multiaddr::from_str("/memory/1234").unwrap()
    .with(Protocol::P2p(PeerId::random().into()))
    .with(Protocol::P2pCircuit);
let dst_addr = relay_addr.clone().with(Protocol::Memory(5678));

// Listen for incoming connections via relay node (1234).
Swarm::listen_on(&mut swarm, relay_addr).unwrap();

// Dial node (5678) via relay node (1234).
Swarm::dial_addr(&mut swarm, dst_addr).unwrap();
```

Co-authored-by: Pierre Krieger <[email protected]>
Co-authored-by: Roman Borschel <[email protected]>
Co-authored-by: David Craven <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Add back the relay
3 participants