Project

General

Profile

1
package eu.dnetlib.uoaadmintools.controllers;
2

    
3
import com.mongodb.BasicDBObject;
4
import com.mongodb.CommandResult;
5
import com.mongodb.DBObject;
6
import eu.dnetlib.uoaadmintools.configuration.mongo.MongoConnection;
7
import eu.dnetlib.uoaadmintools.configuration.properties.ManagersApiConfig;
8
import eu.dnetlib.uoaadmintools.configuration.properties.MongoConfig;
9
import org.apache.log4j.Logger;
10
import org.springframework.beans.factory.annotation.Autowired;
11
import org.springframework.data.mongodb.core.MongoTemplate;
12
import org.springframework.security.access.prepost.PreAuthorize;
13
import org.springframework.web.bind.annotation.CrossOrigin;
14
import org.springframework.web.bind.annotation.RequestMapping;
15
import org.springframework.web.bind.annotation.RequestMethod;
16
import org.springframework.web.bind.annotation.RestController;
17

    
18
import java.util.HashMap;
19
import java.util.Map;
20

    
21
@RestController
22
@CrossOrigin(origins = "*")
23
public class AdminToolsCheckDeployController {
24
    private final Logger log = Logger.getLogger(this.getClass());
25

    
26
    @Autowired
27
    private MongoConnection mongoConnection;
28

    
29
    @Autowired
30
    private MongoConfig mongoConfig;
31

    
32
    @Autowired
33
    private ManagersApiConfig managersApiConfig;
34

    
35
    @RequestMapping(value = {"", "/health_check"}, method = RequestMethod.GET)
36
    public String hello() {
37
        log.debug("Hello from uoa-admin-tools!");
38
        return "Hello from uoa-admin-tools!";
39
    }
40

    
41
    @PreAuthorize("hasAnyAuthority(@AuthorizationService.PORTAL_ADMIN)")
42
    @RequestMapping(value = "/health_check/advanced", method = RequestMethod.GET)
43
    public Map<String, String> checkEverything() {
44
        Map<String, String> response = new HashMap<>();
45

    
46
        MongoTemplate mt = mongoConnection.getMongoTemplate();
47
        DBObject ping = new BasicDBObject("ping", "1");
48
        try {
49
            CommandResult answer = mt.getDb().command(ping);
50
            response.put("Mongo try: error", answer.getErrorMessage());
51
        } catch (Exception e) {
52
            response.put("Mongo catch: error", e.getMessage());
53
        }
54

    
55
        response.put("admintool.mongodb.database", mongoConfig.getDatabase());
56
        response.put("admintool.mongodb.host", mongoConfig.getHost());
57
        response.put("admintool.mongodb.port", mongoConfig.getPort()+"");
58
        response.put("admintool.mongodb.username", mongoConfig.getUsername() == null ? null : "[unexposed value]");
59
        response.put("admintool.mongodb.password", mongoConfig.getPassword() == null ? null : "[unexposed value]");
60
//        response.put("Define also", "admintool.mongodb.username, admintool.mongodb.password");
61

    
62
        response.put("admintool.managers.api.id", managersApiConfig.getId());
63
        response.put("admintool.managers.api.email", managersApiConfig.getEmail());
64
        return response;
65
    }
66
}
(1-1/10)