Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: bootstrap Connection aggregate #131

Merged
merged 92 commits into from
Nov 28, 2024
Merged
Changes from 1 commit
Commits
Show all changes
92 commits
Select commit Hold shift + click to select a range
f61e9b5
WIP
nanderstabel Jun 26, 2024
4ffa6d1
feat init agetn_holder
nanderstabel Aug 22, 2024
ebfc36d
feat: add `HolderState`
nanderstabel Aug 26, 2024
bca826e
feat: add Holder functionality to `agent_store` and `agent_api_rest`
nanderstabel Aug 26, 2024
75d7a31
feat: add Holder functionality to Event Publisher
nanderstabel Aug 26, 2024
c2b2d62
feat: add `SendCredentialOffer` to `agent_verification`
nanderstabel Aug 26, 2024
87d061f
feat: add `/offers/send` issuance endpoint to `agent_api_rest`
nanderstabel Aug 26, 2024
34ff280
fix: remove incorrect Content Type
nanderstabel Aug 27, 2024
7f1ab4f
feat: add `Status` enum
nanderstabel Aug 27, 2024
302e63f
feat: add REST API for Holder
nanderstabel Aug 27, 2024
2673bac
feat: add `AllOffersView`
nanderstabel Aug 27, 2024
5ee0ae4
feat: add Holder views to `init.sql`
nanderstabel Aug 27, 2024
1babdd4
fix: fix `OfferView` update
nanderstabel Aug 27, 2024
7bcc730
feat: add credentials endpoint for Holder
nanderstabel Aug 27, 2024
2000769
refactor: refactor Router
nanderstabel Aug 27, 2024
7599bee
test: refactor test framework
nanderstabel Aug 30, 2024
805591e
refactor: deprecate `path` closure
nanderstabel Aug 30, 2024
dc8c25d
refactor: remove unused dependencies
nanderstabel Aug 30, 2024
9f20fb6
style: add clippy exception
nanderstabel Aug 30, 2024
7c13929
build: bump oid4vc dependencies
nanderstabel Aug 30, 2024
384244c
refactor: move all `CustomQuery` logic to `agent_shared`
nanderstabel Aug 30, 2024
4c39ac7
fix: add Into<SubjectSyntaxType> for SupportedDidMethod
nanderstabel Aug 30, 2024
29f25da
fix: return 200 OK when list is empty
nanderstabel Aug 30, 2024
e08a045
refactor: clean up code
nanderstabel Aug 30, 2024
f307da3
fix: Fix error handling for the Offer aggregate
nanderstabel Aug 30, 2024
29e90d1
fix: add error handling for to Offer aggregate
nanderstabel Aug 30, 2024
cda0b76
refactor: apply clippy suggestion
nanderstabel Aug 30, 2024
bb43a33
test: update Postman Collection
nanderstabel Aug 30, 2024
5aae168
feat: add Events to `config.rs`
nanderstabel Aug 30, 2024
3056a09
docs: add new Holder events to `agent_event_publisher_http` document…
nanderstabel Aug 30, 2024
fa0e631
Merge branch 'dev' into feat/holder-init
nanderstabel Aug 30, 2024
c3fc105
Merge branch 'dev' into feat/linked-vp
nanderstabel Sep 5, 2024
005cf5d
Merge branch 'feat/holder-init' into feat/linked-vp
nanderstabel Sep 12, 2024
ecf05c4
feat: init `agent_identity`
nanderstabel Sep 18, 2024
1bf0c72
style: use consistent nameing for `View` variables
nanderstabel Sep 18, 2024
ceed053
Merge branch 'feat/holder-init' into feat/linked-vp
nanderstabel Sep 18, 2024
961fb2f
style: rename variables
nanderstabel Sep 18, 2024
e4783b3
refactor: use `type` for `View`s to reduce code duplication
nanderstabel Sep 18, 2024
a20cffe
refactor: use `Jwt` instead of `Value`
nanderstabel Sep 18, 2024
504c3ea
feat: add error handling
nanderstabel Sep 18, 2024
24507cb
fix: remove `presentation_id` from route
nanderstabel Sep 18, 2024
0cabb68
refactor: add error handling and comments
nanderstabel Sep 18, 2024
3f24ce4
refactor: remove unused dependencies
nanderstabel Sep 18, 2024
1647121
build: remove unused dependencies
nanderstabel Sep 18, 2024
5acfef1
feat: add `UnsupportedCredentialFormatError` error
nanderstabel Sep 18, 2024
afefa88
test: update Postman Collection
nanderstabel Sep 19, 2024
3649e63
feat: update `init.sql` file
nanderstabel Sep 19, 2024
d936087
feat: add tests and error handling
nanderstabel Sep 19, 2024
9170c6f
Merge branch 'dev' into feat/linked-vp
nanderstabel Oct 3, 2024
5ef35b6
feat: add error handling
nanderstabel Oct 3, 2024
ffd1754
test: add unit tests for `Service`, `Presentation` and received `Offer`
nanderstabel Oct 4, 2024
0068581
feat: add `GET` method for `/v0/services` endpoint
nanderstabel Oct 4, 2024
610af21
test: update Postman collection
nanderstabel Oct 4, 2024
2ff7d34
docs: add document, service and presentation events
nanderstabel Oct 4, 2024
3b4987f
fix: remove unused import
nanderstabel Oct 4, 2024
a8b5dc4
ci: add DS_Store to .gitignore file
nanderstabel Oct 5, 2024
ca3a9ed
feat: add Document and Service to config.rs
nanderstabel Oct 5, 2024
ae83256
fix: update .env.example variables
nanderstabel Oct 7, 2024
6f614e8
feat: make `/accept` endpoint respond with the Offer
nanderstabel Oct 7, 2024
b25c5f9
feat: add individual aggregate instance endpoints
nanderstabel Oct 4, 2024
64cd02c
test: update Postman collection
nanderstabel Oct 4, 2024
18bd045
fix: add `all_authorization_requests` table
nanderstabel Oct 4, 2024
98d7709
test: update test
nanderstabel Oct 5, 2024
42cf68c
feat: init identity `Connection` aggregate
nanderstabel Oct 5, 2024
f8ce95d
refactor: merge verification Connection into AuthorizationRequest agg…
nanderstabel Oct 5, 2024
594864e
feat: add `Connection` aggregate and corresponding endpoints
nanderstabel Oct 6, 2024
06bc359
feat: add `Connection` related endpoints to Postman collection
nanderstabel Oct 9, 2024
d2df459
fix: add `all_connections` table
nanderstabel Oct 9, 2024
129b6b2
fix: undo openbadgesv3_credentials change
nanderstabel Oct 9, 2024
9bd3161
Merge branch 'beta' into feat/linked-vp
nanderstabel Nov 19, 2024
3526cb1
feat: change `openid4vci/offers` from GET to POST
nanderstabel Oct 15, 2024
76f96fe
test: add `services/:service_id` endpoints to Postman collection
nanderstabel Oct 15, 2024
dbbc5ba
fix: change method from `get` to `post`
nanderstabel Oct 15, 2024
82f0562
feat: add public `/linked-verifiable-presentations` endpoint
nanderstabel Oct 15, 2024
3feb807
feat: add `offers_params` endpoint handler
nanderstabel Oct 17, 2024
b56c6dd
style: make requests human-readable
nanderstabel Nov 19, 2024
215e030
test: update path of linked VP in test
nanderstabel Nov 19, 2024
ba5d001
Merge branch 'feat/linked-vp' into nanderstabel/issue129
nanderstabel Nov 19, 2024
bdb7f5c
style: use human-readable names for requests
nanderstabel Nov 19, 2024
78f491a
Merge branch 'beta' into nanderstabel/issue129
nanderstabel Nov 25, 2024
dcf0ade
fix: remove duplicate functions
nanderstabel Nov 25, 2024
b2a4d37
feat: add GET service by ID endpoint
nanderstabel Nov 25, 2024
0272098
Merge branch 'nanderstabel/issue129' into nanderstabel/issue125
nanderstabel Nov 26, 2024
c3bb3aa
docs: add aggregate fields
nanderstabel Nov 26, 2024
d58092c
docs: add README file for `AuthorizationRequest` aggregate
nanderstabel Nov 26, 2024
05523a1
fix: remove duplicate request
nanderstabel Nov 26, 2024
57e5701
Merge branch 'nanderstabel/issue129' into nanderstabel/issue125
nanderstabel Nov 26, 2024
b2088c9
Merge branch 'beta' into nanderstabel/issue125
nanderstabel Nov 26, 2024
25cd91c
fix: change `credential_offer_endpoint` to camelCase
nanderstabel Nov 26, 2024
250deef
fix: change request names
nanderstabel Nov 27, 2024
9030b59
feat: add optional `alias` field to `Connection` aggregate
nanderstabel Nov 27, 2024
002ee60
feat: add `Query Connection by Alias` request
nanderstabel Nov 27, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
feat: add individual aggregate instance endpoints
  • Loading branch information
nanderstabel committed Oct 8, 2024
commit b25c5f9c5555778a8cc071c56334c61cc9673fdb
11 changes: 10 additions & 1 deletion agent_api_rest/src/holder/holder/credentials/mod.rs
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
use agent_holder::state::HolderState;
use agent_shared::handlers::query_handler;
use axum::{
extract::State,
extract::{Path, State},
response::{IntoResponse, Response},
Json,
};
@@ -16,3 +16,12 @@ pub(crate) async fn credentials(State(state): State<HolderState>) -> Response {
_ => StatusCode::INTERNAL_SERVER_ERROR.into_response(),
}
}

#[axum_macros::debug_handler]
pub(crate) async fn credential(State(state): State<HolderState>, Path(holder_credential_id): Path<String>) -> Response {
match query_handler(&holder_credential_id, &state.query.holder_credential).await {
Ok(Some(holder_credential_view)) => (StatusCode::OK, Json(holder_credential_view)).into_response(),
Ok(None) => StatusCode::NOT_FOUND.into_response(),
_ => StatusCode::INTERNAL_SERVER_ERROR.into_response(),
}
}
11 changes: 10 additions & 1 deletion agent_api_rest/src/holder/holder/offers/mod.rs
Original file line number Diff line number Diff line change
@@ -4,7 +4,7 @@ pub mod reject;
use agent_holder::state::HolderState;
use agent_shared::handlers::query_handler;
use axum::{
extract::State,
extract::{Path, State},
response::{IntoResponse, Response},
Json,
};
@@ -19,3 +19,12 @@ pub(crate) async fn offers(State(state): State<HolderState>) -> Response {
_ => StatusCode::INTERNAL_SERVER_ERROR.into_response(),
}
}

#[axum_macros::debug_handler]
pub(crate) async fn offer(State(state): State<HolderState>, Path(received_offer_id): Path<String>) -> Response {
match query_handler(&received_offer_id, &state.query.received_offer).await {
Ok(Some(received_offer_view)) => (StatusCode::OK, Json(received_offer_view)).into_response(),
Ok(None) => StatusCode::NOT_FOUND.into_response(),
_ => StatusCode::INTERNAL_SERVER_ERROR.into_response(),
}
}
11 changes: 10 additions & 1 deletion agent_api_rest/src/holder/holder/presentations/mod.rs
Original file line number Diff line number Diff line change
@@ -5,7 +5,7 @@ use agent_holder::{
};
use agent_shared::handlers::{command_handler, query_handler};
use axum::{
extract::State,
extract::{Path, State},
response::{IntoResponse, Response},
Json,
};
@@ -23,6 +23,15 @@ pub(crate) async fn get_presentations(State(state): State<HolderState>) -> Respo
}
}

#[axum_macros::debug_handler]
pub(crate) async fn presentation(State(state): State<HolderState>, Path(presentation_id): Path<String>) -> Response {
match query_handler(&presentation_id, &state.query.presentation).await {
Ok(Some(presentation_view)) => (StatusCode::OK, Json(presentation_view)).into_response(),
Ok(None) => StatusCode::NOT_FOUND.into_response(),
_ => StatusCode::INTERNAL_SERVER_ERROR.into_response(),
}
}

#[derive(Deserialize, Serialize)]
#[serde(rename_all = "camelCase")]
pub struct PresentationsEndpointRequest {
8 changes: 7 additions & 1 deletion agent_api_rest/src/holder/mod.rs
Original file line number Diff line number Diff line change
@@ -11,20 +11,26 @@ use crate::API_VERSION;
use agent_holder::state::HolderState;
use axum::routing::get;
use axum::{routing::post, Router};
use holder::presentations::{get_presentations, post_presentations, presentation_signed::presentation_signed};
use holder::{
credentials::credential,
presentations::{get_presentations, post_presentations, presentation, presentation_signed::presentation_signed},
};

pub fn router(holder_state: HolderState) -> Router {
Router::new()
.nest(
API_VERSION,
Router::new()
.route("/holder/credentials", get(credentials))
.route("/holder/credentials/:credential_id", get(credential))
.route("/holder/presentations", get(get_presentations).post(post_presentations))
.route("/holder/presentations/:presentation_id", get(presentation))
.route(
"/holder/presentations/:presentation_id/signed",
get(presentation_signed),
)
.route("/holder/offers", get(offers))
.route("/holder/offers/:offer_id", get(offer))
.route("/holder/offers/:offer_id/accept", post(accept))
.route("/holder/offers/:offer_id/reject", post(reject)),
)
8 changes: 2 additions & 6 deletions agent_api_rest/src/issuance/credentials.rs
Original file line number Diff line number Diff line change
@@ -20,13 +20,9 @@ use tracing::info;
use serde_json::json;

#[axum_macros::debug_handler]
pub(crate) async fn get_credentials(State(state): State<IssuanceState>, Path(credential_id): Path<String>) -> Response {
// Get the credential if it exists.
pub(crate) async fn credential(State(state): State<IssuanceState>, Path(credential_id): Path<String>) -> Response {
match query_handler(&credential_id, &state.query.credential).await {
Ok(Some(CredentialView {
data: Some(Data { raw }),
..
})) => (StatusCode::OK, Json(raw)).into_response(),
Ok(Some(credential_view)) => (StatusCode::OK, Json(credential_view)).into_response(),
Ok(None) => StatusCode::NOT_FOUND.into_response(),
_ => StatusCode::INTERNAL_SERVER_ERROR.into_response(),
}
7 changes: 4 additions & 3 deletions agent_api_rest/src/issuance/mod.rs
Original file line number Diff line number Diff line change
@@ -6,14 +6,14 @@ use agent_issuance::state::IssuanceState;
use axum::routing::get;
use axum::{routing::post, Router};
use credentials::all_credentials;
use offers::all_offers;
use offers::{all_offers, offer};

use crate::issuance::{
credential_issuer::{
credential::credential, token::token, well_known::oauth_authorization_server::oauth_authorization_server,
well_known::openid_credential_issuer::openid_credential_issuer,
},
credentials::{credentials, get_credentials},
credentials::credentials,
offers::{offers, send::send},
};
use crate::API_VERSION;
@@ -24,8 +24,9 @@ pub fn router(issuance_state: IssuanceState) -> Router {
API_VERSION,
Router::new()
.route("/credentials", post(credentials).get(all_credentials))
.route("/credentials/:credential_id", get(get_credentials))
.route("/credentials/:credential_id", get(credentials::credential))
.route("/offers", post(offers).get(all_offers))
.route("/offers/:offer_id", get(offer))
.route("/offers/send", post(send)),
)
.route(
11 changes: 10 additions & 1 deletion agent_api_rest/src/issuance/offers/mod.rs
Original file line number Diff line number Diff line change
@@ -7,7 +7,7 @@ use agent_issuance::{
};
use agent_shared::handlers::{command_handler, query_handler};
use axum::{
extract::{Json, State},
extract::{Json, Path, State},
http::StatusCode,
response::{IntoResponse, Response},
};
@@ -91,6 +91,15 @@ pub(crate) async fn all_offers(State(state): State<IssuanceState>) -> Response {
}
}

#[axum_macros::debug_handler]
pub(crate) async fn offer(State(state): State<IssuanceState>, Path(offer_id): Path<String>) -> Response {
match query_handler(&offer_id, &state.query.offer).await {
Ok(Some(offer_view)) => (StatusCode::OK, Json(offer_view)).into_response(),
Ok(None) => StatusCode::NOT_FOUND.into_response(),
_ => StatusCode::INTERNAL_SERVER_ERROR.into_response(),
}
}

#[cfg(test)]
pub mod tests {
use super::*;
25 changes: 16 additions & 9 deletions agent_api_rest/src/verification/authorization_requests.rs
Original file line number Diff line number Diff line change
@@ -4,7 +4,7 @@ use agent_shared::{
handlers::{command_handler, query_handler},
};
use agent_verification::{
authorization_request::{command::AuthorizationRequestCommand, queries::AuthorizationRequestView},
authorization_request::{command::AuthorizationRequestCommand, views::AuthorizationRequestView},
state::VerificationState,
};
use axum::{
@@ -16,20 +16,27 @@ use axum::{
use hyper::header;
use oid4vp::PresentationDefinition;
use serde::{Deserialize, Serialize};
use serde_json::Value;
use serde_json::{json, Value};
use tracing::info;

#[axum_macros::debug_handler]
pub(crate) async fn get_authorization_requests(
pub(crate) async fn all_authorization_requests(State(state): State<VerificationState>) -> Response {
match query_handler("all_authorization_requests", &state.query.all_authorization_requests).await {
Ok(Some(all_authorization_requests_view)) => {
(StatusCode::OK, Json(all_authorization_requests_view)).into_response()
}
Ok(None) => (StatusCode::OK, Json(json!({}))).into_response(),
_ => StatusCode::INTERNAL_SERVER_ERROR.into_response(),
}
}

#[axum_macros::debug_handler]
pub(crate) async fn authorization_request(
State(state): State<VerificationState>,
Path(authorization_request_id): Path<String>,
) -> Response {
// Get the authorization request if it exists.
match query_handler(&authorization_request_id, &state.query.authorization_request).await {
Ok(Some(AuthorizationRequestView {
authorization_request: Some(authorization_request),
..
})) => (StatusCode::OK, Json(authorization_request)).into_response(),
Ok(Some(authorization_request_view)) => (StatusCode::OK, Json(authorization_request_view)).into_response(),
Ok(None) => StatusCode::NOT_FOUND.into_response(),
_ => StatusCode::INTERNAL_SERVER_ERROR.into_response(),
}
@@ -114,7 +121,7 @@ pub(crate) async fn authorization_requests(
return StatusCode::INTERNAL_SERVER_ERROR.into_response();
};

// Return the credential.
// Return the authorization_request.
match query_handler(&state, &verification_state.query.authorization_request).await {
Ok(Some(AuthorizationRequestView {
form_url_encoded_authorization_request: Some(form_url_encoded_authorization_request),
10 changes: 7 additions & 3 deletions agent_api_rest/src/verification/mod.rs
Original file line number Diff line number Diff line change
@@ -2,11 +2,12 @@ pub mod authorization_requests;
pub mod relying_party;

use agent_verification::state::VerificationState;
use authorization_requests::all_authorization_requests;
use axum::routing::get;
use axum::{routing::post, Router};

use crate::verification::{
authorization_requests::authorization_requests, authorization_requests::get_authorization_requests,
authorization_requests::authorization_request, authorization_requests::authorization_requests,
relying_party::redirect::redirect, relying_party::request::request,
};
use crate::API_VERSION;
@@ -16,10 +17,13 @@ pub fn router(verification_state: VerificationState) -> Router {
.nest(
API_VERSION,
Router::new()
.route("/authorization_requests", post(authorization_requests))
.route(
"/authorization_requests",
post(authorization_requests).get(all_authorization_requests),
)
.route(
"/authorization_requests/:authorization_request_id",
get(get_authorization_requests),
get(authorization_request),
),
)
.route("/request/:request_id", get(request))
2 changes: 1 addition & 1 deletion agent_api_rest/src/verification/relying_party/redirect.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
use agent_shared::handlers::{command_handler, query_handler};
use agent_verification::{
authorization_request::queries::AuthorizationRequestView, connection::command::ConnectionCommand,
authorization_request::views::AuthorizationRequestView, connection::command::ConnectionCommand,
generic_oid4vc::GenericAuthorizationResponse, state::VerificationState,
};
use axum::{
2 changes: 1 addition & 1 deletion agent_api_rest/src/verification/relying_party/request.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
use agent_shared::handlers::query_handler;
use agent_verification::{authorization_request::queries::AuthorizationRequestView, state::VerificationState};
use agent_verification::{authorization_request::views::AuthorizationRequestView, state::VerificationState};
use axum::{
extract::{Path, State},
http::StatusCode,
9 changes: 8 additions & 1 deletion agent_store/src/in_memory.rs
Original file line number Diff line number Diff line change
@@ -306,8 +306,13 @@ pub async fn verification_state(
) -> VerificationState {
// Initialize the in-memory repositories.
let authorization_request = Arc::new(MemRepository::default());
let all_authorization_requests = Arc::new(MemRepository::default());
let connection = Arc::new(MemRepository::default());

// Create custom-queries for the offer aggregate.
let all_authorization_requests_query =
ListAllQuery::new(all_authorization_requests.clone(), "all_authorization_requests");

// Partition the event_publishers into the different aggregates.
let Partitions {
authorization_request_event_publishers,
@@ -321,7 +326,8 @@ pub async fn verification_state(
authorization_request_event_publishers.into_iter().fold(
AggregateHandler::new(verification_services.clone())
.append_query(SimpleLoggingQuery {})
.append_query(generic_query(authorization_request.clone())),
.append_query(generic_query(authorization_request.clone()))
.append_query(all_authorization_requests_query),
|aggregate_handler, event_publisher| aggregate_handler.append_event_publisher(event_publisher),
),
),
@@ -336,6 +342,7 @@ pub async fn verification_state(
},
query: agent_verification::state::ViewRepositories {
authorization_request,
all_authorization_requests,
connection,
},
}
9 changes: 8 additions & 1 deletion agent_store/src/postgres.rs
Original file line number Diff line number Diff line change
@@ -279,8 +279,13 @@ pub async fn verification_state(

// Initialize the postgres repositories.
let authorization_request = Arc::new(PostgresViewRepository::new("authorization_request", pool.clone()));
let all_authorization_requests = Arc::new(PostgresViewRepository::new("all_authorization_requests", pool.clone()));
let connection = Arc::new(PostgresViewRepository::new("connection", pool.clone()));

// Create custom-queries for the offer aggregate.
let all_authorization_requests_query =
ListAllQuery::new(all_authorization_requests.clone(), "all_authorization_requests");

// Partition the event_publishers into the different aggregates.
let Partitions {
authorization_request_event_publishers,
@@ -294,7 +299,8 @@ pub async fn verification_state(
authorization_request_event_publishers.into_iter().fold(
AggregateHandler::new(pool.clone(), verification_services.clone())
.append_query(SimpleLoggingQuery {})
.append_query(generic_query(authorization_request.clone())),
.append_query(generic_query(authorization_request.clone()))
.append_query(all_authorization_requests_query),
|aggregate_handler, event_publisher| aggregate_handler.append_event_publisher(event_publisher),
),
),
@@ -309,6 +315,7 @@ pub async fn verification_state(
},
query: agent_verification::state::ViewRepositories {
authorization_request,
all_authorization_requests,
connection,
},
}
8 changes: 4 additions & 4 deletions agent_verification/src/authorization_request/aggregate.rs
Original file line number Diff line number Diff line change
@@ -12,11 +12,11 @@ use serde::{Deserialize, Serialize};
use std::sync::Arc;
use tracing::info;

#[derive(Debug, Serialize, Deserialize, Default)]
#[derive(Debug, Serialize, Deserialize, Default, Clone)]
pub struct AuthorizationRequest {
authorization_request: Option<GenericAuthorizationRequest>,
form_url_encoded_authorization_request: Option<String>,
signed_authorization_request_object: Option<String>,
pub authorization_request: Option<GenericAuthorizationRequest>,
pub form_url_encoded_authorization_request: Option<String>,
pub signed_authorization_request_object: Option<String>,
}

#[async_trait]
2 changes: 1 addition & 1 deletion agent_verification/src/authorization_request/mod.rs
Original file line number Diff line number Diff line change
@@ -2,4 +2,4 @@ pub mod aggregate;
pub mod command;
pub mod error;
pub mod event;
pub mod queries;
pub mod views;
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
use super::AuthorizationRequestView;
use crate::authorization_request::views::AuthorizationRequest;
use cqrs_es::{EventEnvelope, View};
use serde::{Deserialize, Serialize};
use std::collections::HashMap;

#[derive(Debug, Default, Serialize, Deserialize, Clone)]
pub struct AllAuthorizationRequestsView {
#[serde(flatten)]
pub authorization_requests: HashMap<String, AuthorizationRequestView>,
}

impl View<AuthorizationRequest> for AllAuthorizationRequestsView {
fn update(&mut self, event: &EventEnvelope<AuthorizationRequest>) {
self.authorization_requests
// Get the entry for the aggregate_id
.entry(event.aggregate_id.clone())
// or insert a new one if it doesn't exist
.or_default()
// update the view with the event
.update(event);
}
}
Loading