Compare commits
2 commits
Author | SHA1 | Date | |
---|---|---|---|
db523065e0 | |||
3f87d011e7 |
6 changed files with 28 additions and 21 deletions
|
@ -4,6 +4,5 @@ version = "0.1.0"
|
||||||
edition = "2021"
|
edition = "2021"
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
kxio = "5.0"
|
kxio = "5.1"
|
||||||
native-tls = { version = "0.2", features = ["vendored"] }
|
|
||||||
tokio = { version = "1.43", features = ["full"] }
|
tokio = { version = "1.43", features = ["full"] }
|
||||||
|
|
|
@ -39,6 +39,7 @@ RUN apk add --no-cache \
|
||||||
libssl3 \
|
libssl3 \
|
||||||
openssl-dev \
|
openssl-dev \
|
||||||
perl \
|
perl \
|
||||||
|
dbus-dev \
|
||||||
git
|
git
|
||||||
|
|
||||||
# clang \
|
# clang \
|
||||||
|
|
26
README.md
26
README.md
|
@ -42,6 +42,7 @@ The available toolchain in the image are:
|
||||||
- cargo-chef
|
- cargo-chef
|
||||||
- cargo-hack
|
- cargo-hack
|
||||||
- release-plz
|
- release-plz
|
||||||
|
- dbus-dev
|
||||||
- perl
|
- perl
|
||||||
|
|
||||||
### Scripts
|
### Scripts
|
||||||
|
@ -61,10 +62,33 @@ steps:
|
||||||
|
|
||||||
## Caveats
|
## Caveats
|
||||||
|
|
||||||
### native-tls
|
### openssl
|
||||||
|
|
||||||
|
The alpine linux install doesn't build with this dependency. You can either compile `native-tls` with the `vendored` feature, or not use `openssl`.
|
||||||
|
|
||||||
|
#### vendoered native-tls
|
||||||
|
|
||||||
This crate *must* use the `vendored` feature in order to compile in the Alpine Linux image.
|
This crate *must* use the `vendored` feature in order to compile in the Alpine Linux image.
|
||||||
|
|
||||||
```toml
|
```toml
|
||||||
native-tls = { version = "0.2", features = ["vendored"] }
|
native-tls = { version = "0.2", features = ["vendored"] }
|
||||||
```
|
```
|
||||||
|
|
||||||
|
#### Don't use `openssl`
|
||||||
|
|
||||||
|
Check that none of your dependencies require `openssl`:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
cargo tree --edges normal -i openssl
|
||||||
|
```
|
||||||
|
|
||||||
|
This will list the tree of dependencies that are bringing in `openssl`.
|
||||||
|
|
||||||
|
If you do need ssl/tls, try using `rustls`. e.g.
|
||||||
|
|
||||||
|
```toml
|
||||||
|
reqwest = { version = "0.12", default-features = false, features = [
|
||||||
|
"json",
|
||||||
|
"rustls-tls",
|
||||||
|
] }
|
||||||
|
```
|
||||||
|
|
2
justfile
2
justfile
|
@ -1,4 +1,4 @@
|
||||||
image := "git.kemitix.get/kemitix/rust:test"
|
image := "git.kemitix.net/kemitix/rust:test"
|
||||||
|
|
||||||
build:
|
build:
|
||||||
docker build . -t {{ image }}
|
docker build . -t {{ image }}
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
//
|
//
|
||||||
mod kxio;
|
mod kxio;
|
||||||
mod tls;
|
|
||||||
|
|
||||||
fn main() -> Result<(), Box<dyn std::error::Error>> {
|
fn main() -> Result<(), Box<dyn std::error::Error>> {
|
||||||
println!("Hello, world!");
|
println!("Hello, world!");
|
||||||
tls::main();
|
|
||||||
|
|
||||||
let rt = tokio::runtime::Runtime::new()?;
|
let rt = tokio::runtime::Runtime::new()?;
|
||||||
Ok(rt.block_on(crate::kxio::main())?)
|
Ok(rt.block_on(crate::kxio::main())?)
|
||||||
|
|
15
src/tls.rs
15
src/tls.rs
|
@ -1,15 +0,0 @@
|
||||||
use native_tls::TlsConnector;
|
|
||||||
use std::io::{Read, Write};
|
|
||||||
use std::net::TcpStream;
|
|
||||||
|
|
||||||
pub fn main() {
|
|
||||||
let connector = TlsConnector::new().unwrap();
|
|
||||||
|
|
||||||
let stream = TcpStream::connect("google.com:443").unwrap();
|
|
||||||
let mut stream = connector.connect("google.com", stream).unwrap();
|
|
||||||
|
|
||||||
stream.write_all(b"GET / HTTP/1.0\r\n\r\n").unwrap();
|
|
||||||
let mut res = vec![];
|
|
||||||
stream.read_to_end(&mut res).unwrap();
|
|
||||||
println!("{}", String::from_utf8_lossy(&res));
|
|
||||||
}
|
|
Loading…
Add table
Reference in a new issue