blob: 083741cb9b9fb6a87a563d587474a56e10bf0a5b (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
|
use activitypub_federation::config::FederationConfig;
use url::Url;
use crate::{
config::{Config, Environment},
server::state::AppState,
};
pub async fn add_federation(
state: AppState,
config: &Config,
) -> anyhow::Result<FederationConfig<AppState>> {
let url = match config.server.environment {
Environment::Dev => {
format!("http://{}", config.server.domain)
}
Environment::Prod => {
format!("https://{}", config.server.domain)
}
};
let mut url = Url::parse(&url)?;
if Environment::Dev == config.server.environment {
let _ = url.set_port(Some(config.server.port));
}
let mut ap_id = url.clone();
{
let mut ps = ap_id.path_segments_mut().expect("path segments in url");
ps.push("users");
ps.push(&config.server.system_name);
}
// let user = if let Some(user) = state.users_service.get_by_ap_id(ap_id.as_str()).await? {
// user
// } else {
// let mut inbox = ap_id.clone();
// {
// let mut ps = inbox.path_segments_mut().expect("path segments in url");
// ps.push("inbox");
// }
// state
// .users_service
// .create_user(
// &ap_id,
// &config.server.system_name,
// PersonType::Service,
// &inbox,
// true,
// )
// .await?
// };
//
// let user = User::from(user);
let config = FederationConfig::builder()
.domain(url.domain().expect("system domain"))
//.signed_fetch_actor(&user)
.app_data(state)
.build()
.await?;
Ok(config)
}
|