build: made it easier to build bind-shell

This commit is contained in:
Andrew Rioux
2023-05-07 00:08:04 -04:00
parent 318e1b6d05
commit 52e458296c
10 changed files with 63 additions and 21 deletions

View File

@@ -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"

View File

@@ -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<()> {

View File

@@ -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" }

View File

@@ -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())

View File

@@ -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"

View 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(())
}

View 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"));

View File

@@ -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(())
}