Cloning private Github repos in Rust
Cloning a private Github repo using SSH auth in Rust has proved to be a pretty gnarly problem (for my anyway), so I thought I'd share this quick tutorial to help anyone else out that might be struggling with the same issue. I'm using git2-rs which has good interface documentation, but very few pieces of example code, so I set out to fix that somewhat with this post.
Header photo by Mark Wilson
Boosh. Straight in:
let repo_url = "[email protected]:jamwaffles/git2-rs-github-clone-demo.git";
let repo_clone_path = "workspace/";
println!;
let mut builder = new;
let mut callbacks = new;
let mut fetch_options = new;
callbacks.credentials;
fetch_options.remote_callbacks;
builder.fetch_options;
let repo = builder.clone.expect;
println!;
// Do things with `repo` here
The key here is the Cred::ssh_key()
call. This will load a SSH key from your filesystem (don't
forget to change the path) and attach it to the clone request as part of the RemoteCallbacks
object. The callbacks are in turn attached to the fetch options which are passed to the builder.
This rather convoluted chain is what got me so confused.
A full demo of this code on Github. The
code there will clone the repo itself to a folder called workspace/
. Ironically the repo is
public, but you could fork it and make your fork private if you want to test it properly.