build: made it easier to build bind-shell
This commit is contained in:
@@ -8,8 +8,9 @@ edition = "2021"
|
||||
[dependencies]
|
||||
tokio = { version = "1.21.2", features = ["net", "rt", "macros", "rt-multi-thread", "sync", "process", "io-util"] }
|
||||
pcap-sys = { path = "../../../pcap-sys" }
|
||||
ex-bind-shell-key-generator = { path = "../key-generator" }
|
||||
anyhow = "1.0.70"
|
||||
tokio-stream = "0.1.14"
|
||||
ed25519-dalek = "1.0.1"
|
||||
log = "0.4.17"
|
||||
simple_logger = "4.1.0"
|
||||
simple_logger = "4.1.0"
|
||||
@@ -8,7 +8,7 @@ use pcap_sys::{self, packets::EthernetPacket};
|
||||
use tokio::{self, io::AsyncReadExt, process, sync::mpsc};
|
||||
use tokio_stream::StreamExt;
|
||||
|
||||
const PUBKEY: &[u8] = include_bytes!("../../key-generator/pubkey");
|
||||
use ex_bind_shell_key_generator::PUBKEY;
|
||||
|
||||
#[tokio::main]
|
||||
async fn main() -> anyhow::Result<()> {
|
||||
|
||||
@@ -7,4 +7,5 @@ edition = "2021"
|
||||
|
||||
[dependencies]
|
||||
anyhow = "1.0.70"
|
||||
ed25519-dalek = "1.0.1"
|
||||
ed25519-dalek = "1.0.1"
|
||||
ex-bind-shell-key-generator = { path = "../key-generator" }
|
||||
@@ -3,8 +3,7 @@ use std::{io::prelude::*, net::UdpSocket, thread};
|
||||
use anyhow::{anyhow, Context};
|
||||
use ed25519_dalek::{Keypair, Signer};
|
||||
|
||||
const PUBKEY: &[u8] = include_bytes!("../../key-generator/pubkey");
|
||||
const PRIVKEY: &[u8] = include_bytes!("../../key-generator/privkey");
|
||||
use ex_bind_shell_key_generator::{PRIVKEY, PUBKEY};
|
||||
|
||||
fn main() -> anyhow::Result<()> {
|
||||
let privkey = Keypair::from_bytes(&[PRIVKEY, PUBKEY].concat())
|
||||
|
||||
@@ -5,6 +5,6 @@ edition = "2021"
|
||||
|
||||
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
|
||||
|
||||
[dependencies]
|
||||
[build-dependencies]
|
||||
ed25519-dalek = "1.0.1"
|
||||
rand = "0.7"
|
||||
|
||||
31
examples/bind-shell/key-generator/build.rs
Normal file
31
examples/bind-shell/key-generator/build.rs
Normal file
@@ -0,0 +1,31 @@
|
||||
// Copyright (C) 2023 Andrew Rioux
|
||||
//
|
||||
// This program is free software: you can redistribute it and/or modify
|
||||
// it under the terms of the GNU Affero General Public License as
|
||||
// published by the Free Software Foundation, either version 3 of the
|
||||
// License, or (at your option) any later version.
|
||||
//
|
||||
// This program is distributed in the hope that it will be useful,
|
||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
// GNU Affero General Public License for more details.
|
||||
//
|
||||
// You should have received a copy of the GNU Affero General Public License
|
||||
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
use std::{fs, io, path::Path};
|
||||
|
||||
use ed25519_dalek::Keypair;
|
||||
|
||||
fn main() -> io::Result<()> {
|
||||
let mut csprng = rand::thread_rng();
|
||||
let keypair = Keypair::generate(&mut csprng);
|
||||
|
||||
let path_str = std::env::var("OUT_DIR").unwrap();
|
||||
let path = <String as AsRef<Path>>::as_ref(&path_str);
|
||||
|
||||
fs::write(path.join("privkey"), keypair.secret)?;
|
||||
fs::write(path.join("pubkey"), keypair.public)?;
|
||||
|
||||
Ok(())
|
||||
}
|
||||
17
examples/bind-shell/key-generator/src/lib.rs
Normal file
17
examples/bind-shell/key-generator/src/lib.rs
Normal file
@@ -0,0 +1,17 @@
|
||||
// Copyright (C) 2023 Andrew Rioux
|
||||
//
|
||||
// This program is free software: you can redistribute it and/or modify
|
||||
// it under the terms of the GNU Affero General Public License as
|
||||
// published by the Free Software Foundation, either version 3 of the
|
||||
// License, or (at your option) any later version.
|
||||
//
|
||||
// This program is distributed in the hope that it will be useful,
|
||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
// GNU Affero General Public License for more details.
|
||||
//
|
||||
// You should have received a copy of the GNU Affero General Public License
|
||||
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
pub const PUBKEY: &[u8] = include_bytes!(concat!(env!("OUT_DIR"), "/pubkey"));
|
||||
pub const PRIVKEY: &[u8] = include_bytes!(concat!(env!("OUT_DIR"), "/pubkey"));
|
||||
@@ -1,13 +0,0 @@
|
||||
use std::{fs, io};
|
||||
|
||||
use ed25519_dalek::Keypair;
|
||||
|
||||
fn main() -> io::Result<()> {
|
||||
let mut csprng = rand::thread_rng();
|
||||
let keypair = Keypair::generate(&mut csprng);
|
||||
|
||||
fs::write("privkey", keypair.secret)?;
|
||||
fs::write("pubkey", keypair.public)?;
|
||||
|
||||
Ok(())
|
||||
}
|
||||
Reference in New Issue
Block a user