stripe/model/account_session.rs
1use serde::{Serialize, Deserialize};
2use super::ConnectEmbeddedAccountSessionCreateComponents;
3/**An AccountSession allows a Connect platform to grant access to a connected account in Connect embedded components.
4
5We recommend that you create an AccountSession each time you need to display an embedded component
6to your user. Do not save AccountSessions to your database as they expire relatively
7quickly, and cannot be used more than once.
8
9Related guide: [Connect embedded components](https://stripe.com/docs/connect/get-started-connect-embedded-components)*/
10#[derive(Debug, Clone, Serialize, Deserialize, Default)]
11pub struct AccountSession {
12 ///The ID of the account the AccountSession was created for
13 pub account: String,
14 /**The client secret of this AccountSession. Used on the client to set up secure access to the given `account`.
15
16The client secret can be used to provide access to `account` from your frontend. It should not be stored, logged, or exposed to anyone other than the connected account. Make sure that you have TLS enabled on any page that includes the client secret.
17
18Refer to our docs to [setup Connect embedded components](https://stripe.com/docs/connect/get-started-connect-embedded-components) and learn about how `client_secret` should be handled.*/
19 pub client_secret: String,
20 ///
21 pub components: ConnectEmbeddedAccountSessionCreateComponents,
22 ///The timestamp at which this AccountSession will expire.
23 pub expires_at: i64,
24 ///Has the value `true` if the object exists in live mode or the value `false` if the object exists in test mode.
25 pub livemode: bool,
26 ///String representing the object's type. Objects of the same type share the same value.
27 pub object: String,
28}
29impl std::fmt::Display for AccountSession {
30 fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> Result<(), std::fmt::Error> {
31 write!(f, "{}", serde_json::to_string(self).unwrap())
32 }
33}