2019-08-03 03:49:22 +00:00
|
|
|
use futures::{FutureExt, TryStreamExt};
|
2018-06-27 04:00:26 +00:00
|
|
|
use openssl::ssl::{SslConnector, SslMethod};
|
2018-11-27 06:45:14 +00:00
|
|
|
use tokio::net::TcpStream;
|
2019-03-05 05:26:10 +00:00
|
|
|
use tokio_postgres::tls::TlsConnect;
|
2018-06-27 04:00:26 +00:00
|
|
|
|
2018-12-19 05:39:05 +00:00
|
|
|
use super::*;
|
2018-06-27 04:00:26 +00:00
|
|
|
|
2019-08-03 03:49:22 +00:00
|
|
|
async fn smoke_test<T>(s: &str, tls: T)
|
2018-11-27 06:45:14 +00:00
|
|
|
where
|
2019-01-13 22:53:19 +00:00
|
|
|
T: TlsConnect<TcpStream>,
|
2019-08-03 03:49:22 +00:00
|
|
|
T::Stream: 'static + Send,
|
2018-11-27 06:45:14 +00:00
|
|
|
{
|
2019-08-03 03:49:22 +00:00
|
|
|
let stream = TcpStream::connect(&"127.0.0.1:5433".parse().unwrap())
|
|
|
|
.await
|
|
|
|
.unwrap();
|
2018-06-27 04:00:26 +00:00
|
|
|
|
2018-12-30 05:00:58 +00:00
|
|
|
let builder = s.parse::<tokio_postgres::Config>().unwrap();
|
2019-08-03 03:49:22 +00:00
|
|
|
let (mut client, connection) = builder.connect_raw(stream, tls).await.unwrap();
|
2018-12-28 18:51:30 +00:00
|
|
|
|
2019-08-03 03:49:22 +00:00
|
|
|
let connection = connection.map(|r| r.unwrap());
|
|
|
|
tokio::spawn(connection);
|
2018-06-27 04:00:26 +00:00
|
|
|
|
2019-08-03 03:49:22 +00:00
|
|
|
let stmt = client.prepare("SELECT $1::INT4").await.unwrap();
|
|
|
|
let rows = client
|
|
|
|
.query(&stmt, &[&1i32])
|
|
|
|
.try_collect::<Vec<_>>()
|
|
|
|
.await
|
|
|
|
.unwrap();
|
2018-06-27 04:00:26 +00:00
|
|
|
|
2019-08-03 03:49:22 +00:00
|
|
|
assert_eq!(rows.len(), 1);
|
|
|
|
assert_eq!(rows[0].get::<_, i32>(0), 1);
|
2018-06-27 04:00:26 +00:00
|
|
|
}
|
|
|
|
|
2019-08-03 03:49:22 +00:00
|
|
|
#[tokio::test]
|
|
|
|
async fn require() {
|
2018-06-27 04:00:26 +00:00
|
|
|
let mut builder = SslConnector::builder(SslMethod::tls()).unwrap();
|
|
|
|
builder.set_ca_file("../test/server.crt").unwrap();
|
2018-11-27 06:45:14 +00:00
|
|
|
let ctx = builder.build();
|
2018-06-27 04:00:26 +00:00
|
|
|
smoke_test(
|
2019-01-13 22:53:19 +00:00
|
|
|
"user=ssl_user dbname=postgres sslmode=require",
|
|
|
|
TlsConnector::new(ctx.configure().unwrap(), "localhost"),
|
2019-08-03 03:49:22 +00:00
|
|
|
)
|
|
|
|
.await;
|
2018-06-27 04:00:26 +00:00
|
|
|
}
|
|
|
|
|
2019-08-03 03:49:22 +00:00
|
|
|
#[tokio::test]
|
|
|
|
async fn prefer() {
|
2018-06-27 04:00:26 +00:00
|
|
|
let mut builder = SslConnector::builder(SslMethod::tls()).unwrap();
|
|
|
|
builder.set_ca_file("../test/server.crt").unwrap();
|
2018-11-27 06:45:14 +00:00
|
|
|
let ctx = builder.build();
|
2018-06-27 04:00:26 +00:00
|
|
|
smoke_test(
|
2018-12-28 18:51:30 +00:00
|
|
|
"user=ssl_user dbname=postgres",
|
2019-01-13 22:53:19 +00:00
|
|
|
TlsConnector::new(ctx.configure().unwrap(), "localhost"),
|
2019-08-03 03:49:22 +00:00
|
|
|
)
|
|
|
|
.await;
|
2018-06-27 04:00:26 +00:00
|
|
|
}
|
|
|
|
|
2019-08-03 03:49:22 +00:00
|
|
|
#[tokio::test]
|
|
|
|
async fn scram_user() {
|
2018-06-27 04:00:26 +00:00
|
|
|
let mut builder = SslConnector::builder(SslMethod::tls()).unwrap();
|
|
|
|
builder.set_ca_file("../test/server.crt").unwrap();
|
2018-11-27 06:45:14 +00:00
|
|
|
let ctx = builder.build();
|
2018-06-27 04:00:26 +00:00
|
|
|
smoke_test(
|
2019-01-13 22:53:19 +00:00
|
|
|
"user=scram_user password=password dbname=postgres sslmode=require",
|
|
|
|
TlsConnector::new(ctx.configure().unwrap(), "localhost"),
|
2019-08-03 03:49:22 +00:00
|
|
|
)
|
|
|
|
.await;
|
2018-06-27 04:00:26 +00:00
|
|
|
}
|
2018-12-19 05:39:05 +00:00
|
|
|
|
2019-08-03 03:49:22 +00:00
|
|
|
#[tokio::test]
|
2018-12-19 05:39:05 +00:00
|
|
|
#[cfg(feature = "runtime")]
|
2019-08-03 03:49:22 +00:00
|
|
|
async fn runtime() {
|
2018-12-19 05:39:05 +00:00
|
|
|
let mut builder = SslConnector::builder(SslMethod::tls()).unwrap();
|
|
|
|
builder.set_ca_file("../test/server.crt").unwrap();
|
|
|
|
let connector = MakeTlsConnector::new(builder.build());
|
|
|
|
|
2019-08-03 03:49:22 +00:00
|
|
|
let (mut client, connection) = tokio_postgres::connect(
|
2019-01-13 22:53:19 +00:00
|
|
|
"host=localhost port=5433 user=postgres sslmode=require",
|
|
|
|
connector,
|
2019-08-03 03:49:22 +00:00
|
|
|
)
|
|
|
|
.await
|
|
|
|
.unwrap();
|
|
|
|
let connection = connection.map(|r| r.unwrap());
|
|
|
|
tokio::spawn(connection);
|
|
|
|
|
|
|
|
let stmt = client.prepare("SELECT $1::INT4").await.unwrap();
|
|
|
|
let rows = client
|
|
|
|
.query(&stmt, &[&1i32])
|
|
|
|
.try_collect::<Vec<_>>()
|
|
|
|
.await
|
|
|
|
.unwrap();
|
2018-12-19 05:39:05 +00:00
|
|
|
|
2019-08-03 03:49:22 +00:00
|
|
|
assert_eq!(rows.len(), 1);
|
|
|
|
assert_eq!(rows[0].get::<_, i32>(0), 1);
|
2018-12-19 05:39:05 +00:00
|
|
|
}
|