aboutsummaryrefslogtreecommitdiff
path: root/juick-server/src/main/java/com/juick/server/api/xnodeinfo2/Info.java
blob: c12df55f5c4180bcf872cd937472c00ef5a57a00 (plain) (blame)
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
package com.juick.server.api.xnodeinfo2;

import com.juick.server.api.xnodeinfo2.model.*;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

import javax.inject.Inject;
import java.time.Instant;
import java.time.ZonedDateTime;
import java.time.temporal.ChronoUnit;
import java.util.Arrays;

@RestController
public class Info {
    @Value("${ap_base_uri:http://localhost:8080/}")
    private String baseUri;
    @Inject
    private JdbcTemplate jdbcTemplate;

    @GetMapping("/.well-known/x-nodeinfo2")
    public NodeInfo showNodeInfo() {
        NodeInfo nodeInfo = new NodeInfo();
        Server server = new Server();
        server.setBaseUrl(baseUri);
        server.setName("Juick");
        server.setSoftware("Juick");
        server.setVersion("2.x");
        nodeInfo.setServer(server);
        nodeInfo.setProtocols(Arrays.asList("xmpp", "activitypub", "smtp"));
        ServiceInfo serviceInfo = new ServiceInfo();
        serviceInfo.setInbound(Arrays.asList("jabber", "mastodon", "email", "telegram"));
        serviceInfo.setOutbound(Arrays.asList("jabber", "mastodon", "telegram", "twitter", "email", "rss"));
        nodeInfo.setServices(serviceInfo);
        UserStats userStats = new UserStats();
        userStats.setTotal(jdbcTemplate.queryForObject("SELECT COUNT(*) FROM users WHERE banned=0", Integer.class));
        userStats.setActiveMonth(jdbcTemplate.queryForObject("SELECT COUNT(*) FROM users WHERE banned=0 AND last_seen > ?",
                Integer.class, ZonedDateTime.now().minus(1, ChronoUnit.MONTHS).toInstant()));
        userStats.setActiveHalfyear(jdbcTemplate.queryForObject("SELECT COUNT(*) FROM users WHERE banned=0 AND last_seen > ?",
                Integer.class, ZonedDateTime.now().minus(6, ChronoUnit.MONTHS).toInstant()));
        Usage usage = new Usage();
        usage.setUsers(userStats);
        usage.setLocalPosts(jdbcTemplate.queryForObject("SELECT COUNT(*) FROM messages",
                Integer.class));
        usage.setLocalComments(jdbcTemplate.queryForObject("SELECT COUNT(*) FROM replies",
                Integer.class));
        nodeInfo.setUsage(usage);
        return nodeInfo;
    }
}