aboutsummaryrefslogtreecommitdiff
path: root/agent/src/main/java/moe/yuuta/dn42peering/agent/grpc/AgentServiceImpl.java
blob: c1ad43d859907064832ec7c0beb9acba44b526f5 (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
package moe.yuuta.dn42peering.agent.grpc;

import io.vertx.core.CompositeFuture;
import io.vertx.core.Future;
import io.vertx.core.Vertx;
import io.vertx.core.impl.logging.Logger;
import io.vertx.core.impl.logging.LoggerFactory;
import moe.yuuta.dn42peering.agent.proto.DeployResult;
import moe.yuuta.dn42peering.agent.proto.NodeConfig;
import moe.yuuta.dn42peering.agent.proto.VertxAgentGrpc;
import moe.yuuta.dn42peering.agent.provision.BGPProvisioner;
import moe.yuuta.dn42peering.agent.provision.Change;
import moe.yuuta.dn42peering.agent.provision.WireGuardProvisioner;

import javax.annotation.Nonnull;
import java.util.ArrayList;
import java.util.List;
import java.util.stream.Collectors;

class AgentServiceImpl extends VertxAgentGrpc.AgentVertxImplBase {
    private final Logger logger = LoggerFactory.getLogger(getClass().getSimpleName());

    private final Vertx vertx;

    AgentServiceImpl(@Nonnull Vertx vertx) {
        this.vertx = vertx;
    }

    @Override
    public Future<DeployResult> deploy(NodeConfig config) {
        logger.info("Deployment started");
        final BGPProvisioner bgpProvisioner = new BGPProvisioner(vertx);
        final WireGuardProvisioner wireGuardProvisioner = new WireGuardProvisioner(vertx);
        final List<Future> calcFutures = new ArrayList<>();
        calcFutures.add(bgpProvisioner.calculateChanges(config.getNode(), config.getBgpsList()));
        calcFutures.add(wireGuardProvisioner.calculateChanges(config.getNode(), config.getWgsList()));

        return CompositeFuture.all(calcFutures)
                .compose(compositeFuture -> {
                    final List<Future> changes = new ArrayList<>(calcFutures.size());
                    for (int i = 0; i < calcFutures.size(); i ++) {
                        final List<Change> list = compositeFuture.resultAt(i);
                        changes.addAll(list.stream().map(change -> change.execute(vertx)).collect(Collectors.toList()));
                    }
                    return CompositeFuture.all(changes);
                })
                .onComplete(res -> logger.info("Deployment finished. Detailed log can be traced above."))
                .compose(compositeFuture -> Future.succeededFuture(null));
    }
}