summaryrefslogtreecommitdiff
path: root/src/invite/handlers/issue
diff options
context:
space:
mode:
Diffstat (limited to 'src/invite/handlers/issue')
-rw-r--r--src/invite/handlers/issue/mod.rs22
-rw-r--r--src/invite/handlers/issue/test.rs27
2 files changed, 49 insertions, 0 deletions
diff --git a/src/invite/handlers/issue/mod.rs b/src/invite/handlers/issue/mod.rs
new file mode 100644
index 0000000..6085f7a
--- /dev/null
+++ b/src/invite/handlers/issue/mod.rs
@@ -0,0 +1,22 @@
+use axum::extract::{Json, State};
+
+use crate::{
+ app::App, clock::RequestedAt, error::Internal, invite::Invite, token::extract::Identity,
+};
+
+#[cfg(test)]
+mod test;
+
+pub async fn handler(
+ State(app): State<App>,
+ RequestedAt(issued_at): RequestedAt,
+ identity: Identity,
+ _: Json<Request>,
+) -> Result<Json<Invite>, Internal> {
+ let invite = app.invites().issue(&identity.user, &issued_at).await?;
+ Ok(Json(invite))
+}
+
+// Require `{}` as the only valid request for this endpoint.
+#[derive(Default, serde::Deserialize)]
+pub struct Request {}
diff --git a/src/invite/handlers/issue/test.rs b/src/invite/handlers/issue/test.rs
new file mode 100644
index 0000000..2bf5400
--- /dev/null
+++ b/src/invite/handlers/issue/test.rs
@@ -0,0 +1,27 @@
+use axum::extract::{Json, State};
+
+use crate::test::fixtures;
+
+#[tokio::test]
+async fn create_invite() {
+ // Set up the environment
+
+ let app = fixtures::scratch_app().await;
+ let issuer = fixtures::identity::create(&app, &fixtures::now()).await;
+ let issued_at = fixtures::now();
+
+ // Call the endpoint
+
+ let Json(invite) = super::handler(
+ State(app),
+ issued_at.clone(),
+ issuer.clone(),
+ Json(super::Request {}),
+ )
+ .await
+ .expect("creating an invite always succeeds");
+
+ // Verify the response
+ assert_eq!(issuer.user.id, invite.issuer);
+ assert_eq!(&*issued_at, &invite.issued_at);
+}