Change spring boot version to 1.5.8 in order to be compatible with other services using the same Redis Session
This commit is contained in:
parent
3d6e4891a0
commit
6d8dee3a90
|
@ -64,3 +64,6 @@ fabric.properties
|
||||||
# Android studio 3.1+ serialized cache file
|
# Android studio 3.1+ serialized cache file
|
||||||
.idea/caches/build_file_checksums.ser
|
.idea/caches/build_file_checksums.ser
|
||||||
|
|
||||||
|
# Local Deployment scripts
|
||||||
|
make.sh
|
||||||
|
|
||||||
|
|
65
pom.xml
65
pom.xml
|
@ -1,12 +1,11 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.springframework.boot</groupId>
|
<groupId>eu.dnetlib</groupId>
|
||||||
<artifactId>spring-boot-starter-parent</artifactId>
|
<artifactId>dnet45-parent</artifactId>
|
||||||
<version>2.5.2</version>
|
<version>1.0.0</version>
|
||||||
<relativePath/> <!-- lookup parent from repository -->
|
|
||||||
</parent>
|
</parent>
|
||||||
<groupId>eu.dnetlib</groupId>
|
<groupId>eu.dnetlib</groupId>
|
||||||
<artifactId>dnet-role-management</artifactId>
|
<artifactId>dnet-role-management</artifactId>
|
||||||
|
@ -17,12 +16,23 @@
|
||||||
<properties>
|
<properties>
|
||||||
<java.version>1.8</java.version>
|
<java.version>1.8</java.version>
|
||||||
</properties>
|
</properties>
|
||||||
|
<dependencyManagement>
|
||||||
|
<dependencies>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
<artifactId>spring-boot-dependencies</artifactId>
|
||||||
|
<version>1.5.8.RELEASE</version>
|
||||||
|
<type>pom</type>
|
||||||
|
<scope>import</scope>
|
||||||
|
</dependency>
|
||||||
|
</dependencies>
|
||||||
|
</dependencyManagement>
|
||||||
<dependencies>
|
<dependencies>
|
||||||
|
<!-- Spring Boot -->
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.springframework.boot</groupId>
|
<groupId>org.springframework.boot</groupId>
|
||||||
<artifactId>spring-boot-starter-web</artifactId>
|
<artifactId>spring-boot-starter-web</artifactId>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.springframework.boot</groupId>
|
<groupId>org.springframework.boot</groupId>
|
||||||
<artifactId>spring-boot-starter-tomcat</artifactId>
|
<artifactId>spring-boot-starter-tomcat</artifactId>
|
||||||
|
@ -33,15 +43,48 @@
|
||||||
<artifactId>spring-boot-starter-test</artifactId>
|
<artifactId>spring-boot-starter-test</artifactId>
|
||||||
<scope>test</scope>
|
<scope>test</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
<artifactId>spring-boot-starter-security</artifactId>
|
||||||
|
</dependency>
|
||||||
|
<!-- Redis -->
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.springframework.session</groupId>
|
||||||
|
<artifactId>spring-session-data-redis</artifactId>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>biz.paluch.redis</groupId>
|
||||||
|
<artifactId>lettuce</artifactId>
|
||||||
|
<version>4.3.3.Final</version>
|
||||||
|
</dependency>
|
||||||
|
<!-- Mitre -->
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.mitre</groupId>
|
||||||
|
<artifactId>openid-connect-client</artifactId>
|
||||||
|
<version>1.3.0</version>
|
||||||
|
<exclusions>
|
||||||
|
<exclusion>
|
||||||
|
<groupId>org.bouncycastle</groupId>
|
||||||
|
<artifactId>bcprov-jdk15on</artifactId>
|
||||||
|
</exclusion>
|
||||||
|
</exclusions>
|
||||||
|
</dependency>
|
||||||
|
<!-- Json -->
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.google.code.gson</groupId>
|
||||||
|
<artifactId>gson</artifactId>
|
||||||
|
<version>2.6.2</version>
|
||||||
|
</dependency>
|
||||||
</dependencies>
|
</dependencies>
|
||||||
|
|
||||||
<build>
|
<build>
|
||||||
<plugins>
|
<plugins>
|
||||||
<plugin>
|
<plugin>
|
||||||
<groupId>org.springframework.boot</groupId>
|
<artifactId>maven-war-plugin</artifactId>
|
||||||
<artifactId>spring-boot-maven-plugin</artifactId>
|
<version>2.4</version>
|
||||||
|
<configuration>
|
||||||
|
<failOnMissingWebXml>false</failOnMissingWebXml>
|
||||||
|
</configuration>
|
||||||
</plugin>
|
</plugin>
|
||||||
</plugins>
|
</plugins>
|
||||||
</build>
|
</build>
|
||||||
|
</project>
|
||||||
</project>
|
|
|
@ -1,9 +1,19 @@
|
||||||
package eu.dnetlib.dnetrolemanagement;
|
package eu.dnetlib.dnetrolemanagement;
|
||||||
|
|
||||||
|
import eu.dnetlib.dnetrolemanagement.config.properties.RedisProperties;
|
||||||
|
import eu.dnetlib.dnetrolemanagement.config.properties.RegistryProperties;
|
||||||
import org.springframework.boot.SpringApplication;
|
import org.springframework.boot.SpringApplication;
|
||||||
import org.springframework.boot.autoconfigure.SpringBootApplication;
|
import org.springframework.boot.autoconfigure.SpringBootApplication;
|
||||||
|
import org.springframework.boot.context.properties.EnableConfigurationProperties;
|
||||||
|
import org.springframework.context.annotation.PropertySource;
|
||||||
|
import org.springframework.context.annotation.PropertySources;
|
||||||
|
|
||||||
@SpringBootApplication
|
@SpringBootApplication(scanBasePackages = {"eu.dnetlib.dnetrolemanagement"})
|
||||||
|
@PropertySources({
|
||||||
|
@PropertySource("classpath:registry.properties"),
|
||||||
|
@PropertySource(value = "classpath:dnet-override.properties", ignoreResourceNotFound = true)
|
||||||
|
})
|
||||||
|
@EnableConfigurationProperties({RegistryProperties.class, RedisProperties.class})
|
||||||
public class DnetRoleManagementApplication {
|
public class DnetRoleManagementApplication {
|
||||||
|
|
||||||
public static void main(String[] args) {
|
public static void main(String[] args) {
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
package eu.dnetlib.dnetrolemanagement;
|
package eu.dnetlib.dnetrolemanagement;
|
||||||
|
|
||||||
import org.springframework.boot.builder.SpringApplicationBuilder;
|
import org.springframework.boot.builder.SpringApplicationBuilder;
|
||||||
import org.springframework.boot.web.servlet.support.SpringBootServletInitializer;
|
import org.springframework.boot.web.support.SpringBootServletInitializer;
|
||||||
|
|
||||||
public class ServletInitializer extends SpringBootServletInitializer {
|
public class ServletInitializer extends SpringBootServletInitializer {
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,37 @@
|
||||||
|
package eu.dnetlib.dnetrolemanagement.config.properties;
|
||||||
|
|
||||||
|
import org.springframework.boot.context.properties.ConfigurationProperties;
|
||||||
|
|
||||||
|
@ConfigurationProperties("redis")
|
||||||
|
public class RedisProperties {
|
||||||
|
private String host = "localhost";
|
||||||
|
private String port = "6379";
|
||||||
|
private String password;
|
||||||
|
|
||||||
|
public RedisProperties() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getHost() {
|
||||||
|
return host;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setHost(String host) {
|
||||||
|
this.host = host;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getPort() {
|
||||||
|
return port;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setPort(String port) {
|
||||||
|
this.port = port;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getPassword() {
|
||||||
|
return password;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setPassword(String password) {
|
||||||
|
this.password = password;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,56 @@
|
||||||
|
package eu.dnetlib.dnetrolemanagement.config.properties;
|
||||||
|
|
||||||
|
import org.springframework.boot.context.properties.ConfigurationProperties;
|
||||||
|
|
||||||
|
@ConfigurationProperties("registry")
|
||||||
|
public class RegistryProperties {
|
||||||
|
|
||||||
|
private String coid;
|
||||||
|
private String issuer;
|
||||||
|
private String user;
|
||||||
|
private String password;
|
||||||
|
private String version;
|
||||||
|
|
||||||
|
public RegistryProperties() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getCoid() {
|
||||||
|
return coid;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setCoid(String coid) {
|
||||||
|
this.coid = coid;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getIssuer() {
|
||||||
|
return issuer;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setIssuer(String issuer) {
|
||||||
|
this.issuer = issuer;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getUser() {
|
||||||
|
return user;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setUser(String user) {
|
||||||
|
this.user = user;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getPassword() {
|
||||||
|
return password;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setPassword(String password) {
|
||||||
|
this.password = password;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getVersion() {
|
||||||
|
return version;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setVersion(String version) {
|
||||||
|
this.version = version;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,16 @@
|
||||||
|
package eu.dnetlib.dnetrolemanagement.config.security;
|
||||||
|
|
||||||
|
import org.springframework.context.annotation.Configuration;
|
||||||
|
import org.springframework.web.servlet.config.annotation.CorsRegistry;
|
||||||
|
import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;
|
||||||
|
|
||||||
|
@Configuration
|
||||||
|
public class CorsConfig extends WebMvcConfigurerAdapter {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void addCorsMappings(CorsRegistry registry) {
|
||||||
|
registry.addMapping("/**")
|
||||||
|
.allowedMethods("GET", "POST", "PUT", "DELETE", "HEAD", "OPTIONS")
|
||||||
|
.allowCredentials(true);
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,46 @@
|
||||||
|
package eu.dnetlib.dnetrolemanagement.config.security;
|
||||||
|
|
||||||
|
import eu.dnetlib.dnetrolemanagement.config.properties.RedisProperties;
|
||||||
|
import org.apache.log4j.Logger;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.beans.factory.annotation.Value;
|
||||||
|
import org.springframework.context.annotation.Bean;
|
||||||
|
import org.springframework.context.annotation.Configuration;
|
||||||
|
import org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory;
|
||||||
|
import org.springframework.session.data.redis.config.annotation.web.http.EnableRedisHttpSession;
|
||||||
|
import org.springframework.session.web.http.CookieSerializer;
|
||||||
|
import org.springframework.session.web.http.DefaultCookieSerializer;
|
||||||
|
|
||||||
|
@EnableRedisHttpSession
|
||||||
|
@Configuration
|
||||||
|
public class RedisConfig {
|
||||||
|
|
||||||
|
private static final Logger logger = Logger.getLogger(RedisConfig.class);
|
||||||
|
private RedisProperties redisProperties;
|
||||||
|
|
||||||
|
@Value("${webbapp.front.domain:openaire.eu}")
|
||||||
|
private String domain;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
public RedisConfig(RedisProperties redisProperties) {
|
||||||
|
this.redisProperties = redisProperties;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
public LettuceConnectionFactory connectionFactory() {
|
||||||
|
logger.info(String.format("Redis connection listens to %s:%s ", redisProperties.getHost(), redisProperties.getPort()));
|
||||||
|
LettuceConnectionFactory factory = new LettuceConnectionFactory(redisProperties.getHost(), Integer.parseInt(redisProperties.getPort()));
|
||||||
|
if (redisProperties.getPassword() != null) factory.setPassword(redisProperties.getPassword());
|
||||||
|
return factory;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
public CookieSerializer cookieSerializer() {
|
||||||
|
System.out.println("Cookie Serializer: Domain is " + domain);
|
||||||
|
DefaultCookieSerializer serializer = new DefaultCookieSerializer();
|
||||||
|
serializer.setCookieName("openAIRESession"); // <1>
|
||||||
|
serializer.setCookiePath("/"); // <2>
|
||||||
|
serializer.setDomainNamePattern("^.+?\\.(\\w+\\.[a-z]+)$");
|
||||||
|
return serializer;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,20 @@
|
||||||
|
package eu.dnetlib.dnetrolemanagement.config.security;
|
||||||
|
|
||||||
|
import eu.dnetlib.dnetrolemanagement.utils.EntryPoint;
|
||||||
|
import org.springframework.security.config.annotation.method.configuration.EnableGlobalMethodSecurity;
|
||||||
|
import org.springframework.security.config.annotation.web.builders.HttpSecurity;
|
||||||
|
import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity;
|
||||||
|
import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter;
|
||||||
|
|
||||||
|
@EnableGlobalMethodSecurity(prePostEnabled = true, securedEnabled = true)
|
||||||
|
@EnableWebSecurity
|
||||||
|
public class WebSecurityConfig extends WebSecurityConfigurerAdapter {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void configure(HttpSecurity http) throws Exception {
|
||||||
|
http.csrf();
|
||||||
|
http.authorizeRequests().anyRequest().permitAll();
|
||||||
|
http.httpBasic().authenticationEntryPoint(new EntryPoint());
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,35 @@
|
||||||
|
package eu.dnetlib.dnetrolemanagement.controllers;
|
||||||
|
|
||||||
|
import com.google.gson.Gson;
|
||||||
|
import com.google.gson.JsonArray;
|
||||||
|
import eu.dnetlib.dnetrolemanagement.dto.Manager;
|
||||||
|
import eu.dnetlib.dnetrolemanagement.services.RegistryService;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.http.ResponseEntity;
|
||||||
|
import org.springframework.web.bind.annotation.PathVariable;
|
||||||
|
import org.springframework.web.bind.annotation.RequestMapping;
|
||||||
|
import org.springframework.web.bind.annotation.RequestMethod;
|
||||||
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
|
|
||||||
|
@RestController
|
||||||
|
@RequestMapping("/registry")
|
||||||
|
public class RegistryController {
|
||||||
|
|
||||||
|
private RegistryService registryService;
|
||||||
|
Gson gson = new Gson();
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
public RegistryController(RegistryService registryService) {
|
||||||
|
this.registryService = registryService;
|
||||||
|
}
|
||||||
|
|
||||||
|
@RequestMapping(value = "/{type}/{id}/managers/id", method = RequestMethod.GET)
|
||||||
|
public ResponseEntity<Manager[]> getManagers(@PathVariable("type") String type, @PathVariable("id") String id) {
|
||||||
|
Integer couId = registryService.getCouId(type, id);
|
||||||
|
if(couId != null) {
|
||||||
|
JsonArray managers = registryService.getUserIdByCouId(couId, true);
|
||||||
|
return ResponseEntity.ok(gson.fromJson(managers, Manager[].class));
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,46 @@
|
||||||
|
package eu.dnetlib.dnetrolemanagement.dto;
|
||||||
|
|
||||||
|
import java.util.Date;
|
||||||
|
|
||||||
|
public class Manager {
|
||||||
|
|
||||||
|
private String id;
|
||||||
|
private String email;
|
||||||
|
private String name;
|
||||||
|
private String memberSince;
|
||||||
|
|
||||||
|
public Manager() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getId() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setId(String id) {
|
||||||
|
this.id = id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getEmail() {
|
||||||
|
return email;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setEmail(String email) {
|
||||||
|
this.email = email;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getName() {
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setName(String name) {
|
||||||
|
this.name = name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getMemberSince() {
|
||||||
|
return memberSince;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setMemberSince(String memberSince) {
|
||||||
|
this.memberSince = memberSince;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,425 @@
|
||||||
|
package eu.dnetlib.dnetrolemanagement.services;
|
||||||
|
|
||||||
|
import com.google.gson.JsonArray;
|
||||||
|
import com.google.gson.JsonElement;
|
||||||
|
import com.google.gson.JsonObject;
|
||||||
|
import eu.dnetlib.dnetrolemanagement.config.properties.RegistryProperties;
|
||||||
|
import eu.dnetlib.dnetrolemanagement.utils.HttpUtils;
|
||||||
|
import eu.dnetlib.dnetrolemanagement.utils.JsonUtils;
|
||||||
|
import org.apache.log4j.Logger;
|
||||||
|
import org.mitre.openid.connect.model.OIDCAuthenticationToken;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.security.core.context.SecurityContextHolder;
|
||||||
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
@Service
|
||||||
|
public class RegistryService {
|
||||||
|
|
||||||
|
private static final Logger logger = Logger.getLogger(RegistryService.class);
|
||||||
|
|
||||||
|
private final String coid;
|
||||||
|
|
||||||
|
public HttpUtils httpUtils;
|
||||||
|
|
||||||
|
public JsonUtils jsonUtils;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
public RegistryService(HttpUtils httpUtils, JsonUtils jsonUtils, RegistryProperties registryProperties) {
|
||||||
|
this.coid = registryProperties.getCoid();
|
||||||
|
this.httpUtils = httpUtils;
|
||||||
|
this.jsonUtils = jsonUtils;
|
||||||
|
}
|
||||||
|
|
||||||
|
private String mapType(String type, boolean communityMap) {
|
||||||
|
if(type.equals("organization")) {
|
||||||
|
type = "institution";
|
||||||
|
} else if(type.equals("ri") && communityMap) {
|
||||||
|
type = "community";
|
||||||
|
}
|
||||||
|
return type;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 1. Get CoPersonId by Email
|
||||||
|
*/
|
||||||
|
public Integer getCoPersonIdByEmail() {
|
||||||
|
try {
|
||||||
|
OIDCAuthenticationToken authentication = (OIDCAuthenticationToken) SecurityContextHolder.getContext().getAuthentication();
|
||||||
|
String email = authentication.getUserInfo().getEmail();
|
||||||
|
Map<String, String> params = new HashMap<>();
|
||||||
|
params.put("coid", coid);
|
||||||
|
params.put("mail", email);
|
||||||
|
JsonElement response = httpUtils.get("co_people.json", params);
|
||||||
|
return (response != null) ? response.getAsJsonObject().get("CoPeople").getAsJsonArray().get(0).getAsJsonObject().get("Id").getAsInt() : null;
|
||||||
|
} catch (Exception e) {
|
||||||
|
logger.error("Get User info: An error occurred ", e);
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public Integer getCoPersonIdByEmail(String email) {
|
||||||
|
Map<String, String> params = new HashMap<>();
|
||||||
|
params.put("coid", coid);
|
||||||
|
params.put("mail", email);
|
||||||
|
JsonElement response = httpUtils.get("co_people.json", params);
|
||||||
|
if(response != null) {
|
||||||
|
JsonArray coPeople = response.getAsJsonObject().get("CoPeople").getAsJsonArray();
|
||||||
|
if(coPeople.size() > 0) {
|
||||||
|
return coPeople.get(0).getAsJsonObject().get("Id").getAsInt();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<Integer> getCoPersonIdsByEmail(String email) {
|
||||||
|
List<Integer> coPersonIds = new ArrayList<>();
|
||||||
|
Map<String, String> params = new HashMap<>();
|
||||||
|
params.put("coid", coid);
|
||||||
|
params.put("mail", email);
|
||||||
|
JsonElement response = httpUtils.get("co_people.json", params);
|
||||||
|
if(response != null) {
|
||||||
|
JsonArray coPeople = response.getAsJsonObject().get("CoPeople").getAsJsonArray();
|
||||||
|
for(int i = 0; i < coPeople.size(); i++) {
|
||||||
|
coPersonIds.add(coPeople.get(i).getAsJsonObject().get("Id").getAsInt());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return coPersonIds;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 2. Get CoPersonId by AAI identifier
|
||||||
|
*/
|
||||||
|
public Integer getCoPersonIdByIdentifier() {
|
||||||
|
try {
|
||||||
|
OIDCAuthenticationToken authentication = (OIDCAuthenticationToken) SecurityContextHolder.getContext().getAuthentication();
|
||||||
|
String sub = authentication.getUserInfo().getSub();
|
||||||
|
Map<String, String> params = new HashMap<>();
|
||||||
|
params.put("coid", coid);
|
||||||
|
params.put("search.identifier", sub);
|
||||||
|
JsonElement response = httpUtils.get("co_people.json", params);
|
||||||
|
return (response != null) ? response.getAsJsonObject().get("CoPeople").getAsJsonArray().get(0).getAsJsonObject().get("Id").getAsInt() : null;
|
||||||
|
} catch (Exception e) {
|
||||||
|
logger.error("Get User info: An error occurred ", e);
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public Integer getCoPersonIdByIdentifier(String sub) {
|
||||||
|
Map<String, String> params = new HashMap<>();
|
||||||
|
params.put("coid", coid);
|
||||||
|
params.put("search.identifier", sub);
|
||||||
|
JsonElement response = httpUtils.get("co_people.json", params);
|
||||||
|
return (response != null) ? response.getAsJsonObject().get("CoPeople").getAsJsonArray().get(0).getAsJsonObject().get("Id").getAsInt() : null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 3.1 Get OpenAIRE cous with a specific name(or substring)
|
||||||
|
*/
|
||||||
|
public JsonArray getCous(String name) {
|
||||||
|
Map<String, String> params = new HashMap<>();
|
||||||
|
params.put("coid", coid);
|
||||||
|
if(name != null) {
|
||||||
|
params.put("name", name.toLowerCase());
|
||||||
|
}
|
||||||
|
JsonElement response = httpUtils.get("cous.json", params);
|
||||||
|
return (response != null) ? response.getAsJsonObject().get("Cous").getAsJsonArray() : new JsonArray();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 3.2 Get all OpenAIRE cous
|
||||||
|
*/
|
||||||
|
public JsonArray getCous() {
|
||||||
|
return getCous(null);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 4.1 Get a couId by name
|
||||||
|
*
|
||||||
|
* @param name
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Integer getCouId(String name) {
|
||||||
|
JsonArray cous = getCous(name);
|
||||||
|
for (JsonElement cou : cous) {
|
||||||
|
if (cou.getAsJsonObject().get("Name").getAsString().toLowerCase().equals(name.toLowerCase())) {
|
||||||
|
return cou.getAsJsonObject().get("Id").getAsInt();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 4.2 Get a couId by type.id with/without mapping type
|
||||||
|
*
|
||||||
|
* @param type
|
||||||
|
* @param id
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Integer getCouId(String type, String id, boolean communityMap) {
|
||||||
|
return getCouId(mapType(type, communityMap) + "." + id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 4.3 Get a couId by type.id with mapping type
|
||||||
|
*
|
||||||
|
* @param type
|
||||||
|
* @param id
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public Integer getCouId(String type, String id) {
|
||||||
|
return getCouId(type, id, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 5. Get User non admin roles
|
||||||
|
*/
|
||||||
|
public JsonArray getRoles(Integer coPersonId) {
|
||||||
|
Map<String, String> params = new HashMap<>();
|
||||||
|
params.put("copersonid", coPersonId.toString());
|
||||||
|
JsonElement response = httpUtils.get("co_person_roles.json", params);
|
||||||
|
return (response != null) ? response.getAsJsonObject().get("CoPersonRoles").getAsJsonArray() : new JsonArray();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 6. Get Role id of User base on couId.
|
||||||
|
*/
|
||||||
|
public Integer getRoleId(Integer coPersonId, Integer couId) {
|
||||||
|
JsonArray roles = getRoles(coPersonId);
|
||||||
|
for (JsonElement role : roles) {
|
||||||
|
JsonObject object = role.getAsJsonObject();
|
||||||
|
if (object.get("CouId").getAsInt() == couId && !object.get("Status").getAsString().equals("Deleted")) {
|
||||||
|
return object.get("Id").getAsInt();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 7. Get User Groups
|
||||||
|
*/
|
||||||
|
public JsonArray getUserGroups(Integer coPersonId) {
|
||||||
|
Map<String, String> params = new HashMap<>();
|
||||||
|
params.put("copersonid", coPersonId.toString());
|
||||||
|
JsonElement response = httpUtils.get("co_groups.json", params);
|
||||||
|
return (response != null) ? response.getAsJsonObject().get("CoGroups").getAsJsonArray() : new JsonArray();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 8. Get User Admin Group of a Cou
|
||||||
|
*/
|
||||||
|
public JsonObject getUserAdminGroup(Integer coPersonId, Integer couId) {
|
||||||
|
Map<String, String> params = new HashMap<>();
|
||||||
|
params.put("copersonid", coPersonId.toString());
|
||||||
|
JsonElement response = httpUtils.get("co_groups.json", params);
|
||||||
|
JsonArray roles = (response != null) ? response.getAsJsonObject().get("CoGroups").getAsJsonArray() : new JsonArray();
|
||||||
|
for (JsonElement role : roles) {
|
||||||
|
JsonObject object = role.getAsJsonObject();
|
||||||
|
if (object.get("CouId") != null && object.get("CouId").getAsInt() == couId) {
|
||||||
|
if (object.get("Name").getAsString().contains("admins")) {
|
||||||
|
return object;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 9. Get Groups of a Cou
|
||||||
|
*/
|
||||||
|
public JsonArray getCouGroups(Integer couId) {
|
||||||
|
Map<String, String> params = new HashMap<>();
|
||||||
|
params.put("coid", coid);
|
||||||
|
params.put("couid", couId.toString());
|
||||||
|
JsonElement response = httpUtils.get("co_groups.json", params);
|
||||||
|
return (response != null) ? response.getAsJsonObject().get("CoGroups").getAsJsonArray() : new JsonArray();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 10. Get Admin Group of a Cou
|
||||||
|
*/
|
||||||
|
public JsonObject getCouAdminGroup(Integer couId) {
|
||||||
|
JsonArray groups = getCouGroups(couId);
|
||||||
|
for (JsonElement group : groups) {
|
||||||
|
if (group.getAsJsonObject().get("Name").getAsString().contains("admins")) {
|
||||||
|
return group.getAsJsonObject();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 11. Get users of a group
|
||||||
|
*/
|
||||||
|
public JsonArray getGroupMembers(Integer coGroupId) {
|
||||||
|
Map<String, String> params = new HashMap<>();
|
||||||
|
params.put("cogroupid", coGroupId.toString());
|
||||||
|
JsonElement response = httpUtils.get("co_group_members.json", params);
|
||||||
|
return (response != null) ? response.getAsJsonObject().get("CoGroupMembers").getAsJsonArray() : new JsonArray();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 12. Get Users' email of a Cou
|
||||||
|
*/
|
||||||
|
public JsonArray getUserEmailByCouId(Integer couId, boolean admin) {
|
||||||
|
Map<String, String> params = new HashMap<>();
|
||||||
|
params.put("couid", couId.toString());
|
||||||
|
if (admin) {
|
||||||
|
params.put("admin", "true");
|
||||||
|
}
|
||||||
|
JsonElement response = httpUtils.get("email_addresses.json", params);
|
||||||
|
JsonArray infos = (response != null) ? response.getAsJsonObject().get("EmailAddresses").getAsJsonArray() : new JsonArray();
|
||||||
|
JsonArray emails = new JsonArray();
|
||||||
|
infos.forEach(info -> {
|
||||||
|
JsonObject user = new JsonObject();
|
||||||
|
boolean add = true;
|
||||||
|
String email = info.getAsJsonObject().get("Mail").getAsString();
|
||||||
|
for(JsonElement element : emails) {
|
||||||
|
if(element.getAsJsonObject().get("email").getAsString().equals(email)) {
|
||||||
|
add = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(add) {
|
||||||
|
user.addProperty("email", email);
|
||||||
|
user.addProperty("memberSince", info.getAsJsonObject().get("Created").getAsString());
|
||||||
|
emails.add(user);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
return emails;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 13. Get Users' names of a Cou
|
||||||
|
*/
|
||||||
|
public JsonArray getUserNamesByCouId(Integer couId, boolean admin) {
|
||||||
|
Map<String, String> params = new HashMap<>();
|
||||||
|
params.put("couid", couId.toString());
|
||||||
|
if (admin) {
|
||||||
|
params.put("admin", "true");
|
||||||
|
}
|
||||||
|
JsonElement response = httpUtils.get("names.json", params);
|
||||||
|
JsonArray infos = (response != null) ? response.getAsJsonObject().get("Names").getAsJsonArray() : new JsonArray();
|
||||||
|
JsonArray names = new JsonArray();
|
||||||
|
infos.forEach(info -> {
|
||||||
|
JsonObject user = new JsonObject();
|
||||||
|
user.addProperty("name", info.getAsJsonObject().get("Given").getAsString() + " " + info.getAsJsonObject().get("Family").getAsString());
|
||||||
|
user.addProperty("memberSince", info.getAsJsonObject().get("Created").getAsString());
|
||||||
|
names.add(user);
|
||||||
|
});
|
||||||
|
return names;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 14. Get Users' identifiers of a Cou
|
||||||
|
*/
|
||||||
|
public JsonArray getUserIdByCouId(Integer couId, boolean admin) {
|
||||||
|
Map<String, String> params = new HashMap<>();
|
||||||
|
params.put("couid", couId.toString());
|
||||||
|
if (admin) {
|
||||||
|
params.put("admin", "true");
|
||||||
|
}
|
||||||
|
JsonElement response = httpUtils.get("identifiers.json", params);
|
||||||
|
JsonArray infos = (response != null) ? response.getAsJsonObject().get("Identifiers").getAsJsonArray() : new JsonArray();
|
||||||
|
JsonArray emails = new JsonArray();
|
||||||
|
infos.forEach(info -> {
|
||||||
|
JsonObject user = new JsonObject();
|
||||||
|
user.addProperty("id", info.getAsJsonObject().get("Identifier").getAsString());
|
||||||
|
user.addProperty("memberSince", info.getAsJsonObject().get("Created").getAsString());
|
||||||
|
emails.add(user);
|
||||||
|
});
|
||||||
|
return emails;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 15. Assign a member role to a User
|
||||||
|
*/
|
||||||
|
public void assignMemberRole(Integer coPersonId, Integer couId, Integer id) {
|
||||||
|
if (id != null) {
|
||||||
|
httpUtils.put("co_person_roles/" + id.toString() + ".json", jsonUtils.coPersonRoles(coPersonId, couId, "Active"));
|
||||||
|
} else {
|
||||||
|
httpUtils.post("co_person_roles.json", jsonUtils.coPersonRoles(coPersonId, couId, "Active"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 16. Remove a member role from a User
|
||||||
|
*/
|
||||||
|
public void removeMemberRole(Integer coPersonId, Integer couId, Integer id) {
|
||||||
|
if(id != null) {
|
||||||
|
httpUtils.put("co_person_roles/" + id.toString() + ".json", jsonUtils.coPersonRoles(coPersonId, couId, "Deleted"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 17. Create a new role
|
||||||
|
*/
|
||||||
|
public Integer createRole(String name, String description) {
|
||||||
|
JsonElement element = httpUtils.post("cous.json", jsonUtils.createNewCou(name, description));
|
||||||
|
return element.getAsJsonObject().get("Id").getAsInt();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 18. Get User's email
|
||||||
|
*/
|
||||||
|
public String getUserEmail(Integer coPersonId) {
|
||||||
|
Map<String, String> params = new HashMap<>();
|
||||||
|
params.put("copersonid", coPersonId.toString());
|
||||||
|
JsonElement response = httpUtils.get("email_addresses.json", params);
|
||||||
|
JsonObject info = (response != null) ? response.getAsJsonObject().get("EmailAddresses").getAsJsonArray().get(0).getAsJsonObject() : null;
|
||||||
|
return (info != null) ? info.getAsJsonObject().get("Mail").getAsString() : null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 19. Get User's names
|
||||||
|
*/
|
||||||
|
public String getUserNames(Integer coPersonId) {
|
||||||
|
Map<String, String> params = new HashMap<>();
|
||||||
|
params.put("copersonid", coPersonId.toString());
|
||||||
|
JsonElement response = httpUtils.get("names.json", params);
|
||||||
|
JsonObject info = (response != null) ? response.getAsJsonObject().get("Names").getAsJsonArray().get(0).getAsJsonObject() : null;
|
||||||
|
return (info != null) ? info.getAsJsonObject().get("Given").getAsString() + " " + info.getAsJsonObject().get("Family").getAsString() : null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 20. Get User's identifier
|
||||||
|
*/
|
||||||
|
public String getUserId(Integer coPersonId) {
|
||||||
|
Map<String, String> params = new HashMap<>();
|
||||||
|
params.put("copersonid", coPersonId.toString());
|
||||||
|
JsonElement response = httpUtils.get("identifiers.json", params);
|
||||||
|
JsonObject info = (response != null) ? response.getAsJsonObject().get("Identifiers").getAsJsonArray().get(0).getAsJsonObject() : null;
|
||||||
|
return (info != null) ? info.getAsJsonObject().get("Identifier").getAsString() : null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 21. Assign an admin role to a User
|
||||||
|
*/
|
||||||
|
public void assignAdminRole(Integer coPersonId, Integer couId) {
|
||||||
|
JsonObject group = getCouAdminGroup(couId);
|
||||||
|
if (group != null) {
|
||||||
|
httpUtils.post("co_group_members.json", jsonUtils.coGroupMembers(group.get("Id").getAsInt(), coPersonId, true));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 22. Remove an admin role from a User
|
||||||
|
*/
|
||||||
|
public void removeAdminRole(Integer coPersonId, Integer couId) {
|
||||||
|
JsonObject adminGroup = this.getCouAdminGroup(couId);
|
||||||
|
JsonArray admins = this.getGroupMembers(adminGroup.get("Id").getAsInt());
|
||||||
|
Integer id = null;
|
||||||
|
for (JsonElement admin : admins) {
|
||||||
|
if (admin.getAsJsonObject().get("Person").getAsJsonObject().get("Id").getAsInt() == coPersonId) {
|
||||||
|
id = admin.getAsJsonObject().get("Id").getAsInt();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (id != null) {
|
||||||
|
httpUtils.delete("co_group_members/" + id.toString() + ".json");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,19 @@
|
||||||
|
package eu.dnetlib.dnetrolemanagement.utils;
|
||||||
|
|
||||||
|
import org.springframework.security.core.AuthenticationException;
|
||||||
|
import org.springframework.security.web.AuthenticationEntryPoint;
|
||||||
|
|
||||||
|
import javax.servlet.http.HttpServletRequest;
|
||||||
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
public class EntryPoint implements AuthenticationEntryPoint {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void commence(HttpServletRequest request, HttpServletResponse response,
|
||||||
|
AuthenticationException authException) throws IOException {
|
||||||
|
response.sendError(HttpServletResponse.SC_UNAUTHORIZED, authException.getMessage());
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
|
@ -0,0 +1,103 @@
|
||||||
|
package eu.dnetlib.dnetrolemanagement.utils;
|
||||||
|
|
||||||
|
import com.google.gson.JsonElement;
|
||||||
|
import com.google.gson.JsonObject;
|
||||||
|
import com.google.gson.JsonParser;
|
||||||
|
import eu.dnetlib.dnetrolemanagement.config.properties.RegistryProperties;
|
||||||
|
import org.apache.log4j.Logger;
|
||||||
|
import org.apache.tomcat.util.codec.binary.Base64;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.http.*;
|
||||||
|
import org.springframework.stereotype.Component;
|
||||||
|
import org.springframework.web.client.RestTemplate;
|
||||||
|
|
||||||
|
import java.nio.charset.Charset;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
@Component
|
||||||
|
public class HttpUtils {
|
||||||
|
|
||||||
|
private static final Logger logger = Logger.getLogger(eu.dnetlib.dnetrolemanagement.utils.HttpUtils.class);
|
||||||
|
|
||||||
|
private RegistryProperties registryProperties;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
public HttpUtils(RegistryProperties registryProperties) {
|
||||||
|
this.registryProperties = registryProperties;
|
||||||
|
}
|
||||||
|
|
||||||
|
public JsonElement post(String path, JsonObject body) {
|
||||||
|
RestTemplate restTemplate = new RestTemplate();
|
||||||
|
HttpHeaders headers = createHeaders(registryProperties.getUser(), registryProperties.getPassword());
|
||||||
|
headers.setContentType(MediaType.APPLICATION_JSON);
|
||||||
|
HttpEntity<String> request = new HttpEntity<>(body.toString(), headers);
|
||||||
|
ResponseEntity<String> responseEntity = restTemplate.exchange(registryProperties.getIssuer() + path, HttpMethod.POST, request, String.class);
|
||||||
|
if (responseEntity.getBody() != null) {
|
||||||
|
return new JsonParser().parse(responseEntity.getBody());
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public JsonElement put(String path, JsonObject body) {
|
||||||
|
RestTemplate restTemplate = new RestTemplate();
|
||||||
|
HttpHeaders headers = createHeaders(registryProperties.getUser(), registryProperties.getPassword());
|
||||||
|
headers.setContentType(MediaType.APPLICATION_JSON);
|
||||||
|
HttpEntity<String> request = new HttpEntity<>(body.toString(), headers);
|
||||||
|
ResponseEntity<String> responseEntity = restTemplate.exchange(registryProperties.getIssuer() + path, HttpMethod.PUT, request, String.class);
|
||||||
|
if (responseEntity.getBody() != null) {
|
||||||
|
return new JsonParser().parse(responseEntity.getBody());
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public JsonElement get(String path, Map<String, String> params) {
|
||||||
|
RestTemplate restTemplate = new RestTemplate();
|
||||||
|
String url = registryProperties.getIssuer() + path + ((params != null) ? createParams(params) : null);
|
||||||
|
ResponseEntity<String> responseEntity = restTemplate.exchange
|
||||||
|
(url, HttpMethod.GET, new HttpEntity<>(createHeaders(registryProperties.getUser(), registryProperties.getPassword())), String.class);
|
||||||
|
if (responseEntity.getBody() != null) {
|
||||||
|
return new JsonParser().parse(responseEntity.getBody());
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public JsonElement delete(String path) {
|
||||||
|
RestTemplate restTemplate = new RestTemplate();
|
||||||
|
String url = registryProperties.getIssuer() + path;
|
||||||
|
ResponseEntity<String> responseEntity = restTemplate.exchange
|
||||||
|
(url, HttpMethod.DELETE, new HttpEntity<>(createHeaders(registryProperties.getUser(), registryProperties.getPassword())), String.class);
|
||||||
|
if (responseEntity.getBody() != null) {
|
||||||
|
return new JsonParser().parse(responseEntity.getBody());
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private String createParams(Map<String, String> params) {
|
||||||
|
StringBuilder ret = new StringBuilder("?");
|
||||||
|
int count = 0;
|
||||||
|
for (Map.Entry<String, String> param : params.entrySet()) {
|
||||||
|
ret.append(param.getKey()).append("=");
|
||||||
|
ret.append(param.getValue());
|
||||||
|
count++;
|
||||||
|
if (count != params.entrySet().size()) {
|
||||||
|
ret.append("&");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return ret.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
private HttpHeaders createHeaders(String username, String password) {
|
||||||
|
return new HttpHeaders() {{
|
||||||
|
String auth = username + ":" + password;
|
||||||
|
byte[] encodedAuth = Base64.encodeBase64(
|
||||||
|
auth.getBytes(Charset.forName("US-ASCII")));
|
||||||
|
String authHeader = "Basic " + new String(encodedAuth);
|
||||||
|
set("Authorization", authHeader);
|
||||||
|
}};
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,110 @@
|
||||||
|
package eu.dnetlib.dnetrolemanagement.utils;
|
||||||
|
|
||||||
|
import com.google.gson.JsonArray;
|
||||||
|
import com.google.gson.JsonElement;
|
||||||
|
import com.google.gson.JsonObject;
|
||||||
|
import eu.dnetlib.dnetrolemanagement.config.properties.RegistryProperties;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
|
@Component
|
||||||
|
public class JsonUtils {
|
||||||
|
|
||||||
|
private final String version;
|
||||||
|
private final String coid;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
public JsonUtils(RegistryProperties registryProperties) {
|
||||||
|
this.version = registryProperties.getVersion();
|
||||||
|
this.coid = registryProperties.getCoid();
|
||||||
|
}
|
||||||
|
|
||||||
|
public JsonObject coPersonRoles(Integer coPersonId, Integer couId, String status) {
|
||||||
|
JsonObject role = new JsonObject();
|
||||||
|
JsonArray coPersonRoles = new JsonArray();
|
||||||
|
JsonObject coPersonRole = new JsonObject();
|
||||||
|
JsonObject person = new JsonObject();
|
||||||
|
person.addProperty("Type", "CO");
|
||||||
|
person.addProperty("Id", coPersonId.toString());
|
||||||
|
coPersonRole.addProperty("Version", version);
|
||||||
|
coPersonRole.add("Person", person);
|
||||||
|
coPersonRole.addProperty("CouId", couId.toString());
|
||||||
|
coPersonRole.addProperty("Affiliation", "member");
|
||||||
|
coPersonRole.addProperty("Title", "");
|
||||||
|
coPersonRole.addProperty("O", "Openaire");
|
||||||
|
coPersonRole.addProperty("Status", status);
|
||||||
|
coPersonRole.addProperty("ValidFrom", "");
|
||||||
|
coPersonRole.addProperty("ValidThrough", "");
|
||||||
|
coPersonRoles.add(coPersonRole);
|
||||||
|
role.addProperty("RequestType", "CoPersonRoles");
|
||||||
|
role.addProperty("Version", version);
|
||||||
|
role.add("CoPersonRoles", coPersonRoles);
|
||||||
|
return role;
|
||||||
|
}
|
||||||
|
|
||||||
|
public JsonObject coGroupMembers(Integer coGroupId, Integer coPersonId, boolean member) {
|
||||||
|
JsonObject coGroup = new JsonObject();
|
||||||
|
JsonArray coGroupMembers = new JsonArray();
|
||||||
|
JsonObject coGroupMember = new JsonObject();
|
||||||
|
JsonObject person = new JsonObject();
|
||||||
|
person.addProperty("Type", "CO");
|
||||||
|
person.addProperty("Id", coPersonId.toString());
|
||||||
|
coGroupMember.addProperty("Version", version);
|
||||||
|
coGroupMember.add("Person", person);
|
||||||
|
coGroupMember.addProperty("CoGroupId", coGroupId.toString());
|
||||||
|
coGroupMember.addProperty("Member", member);
|
||||||
|
coGroupMember.addProperty("Owner", false);
|
||||||
|
coGroupMember.addProperty("ValidFrom", "");
|
||||||
|
coGroupMember.addProperty("ValidThrough", "");
|
||||||
|
coGroupMembers.add(coGroupMember);
|
||||||
|
coGroup.addProperty("RequestType", "CoGroupMembers");
|
||||||
|
coGroup.addProperty("Version", version);
|
||||||
|
coGroup.add("CoGroupMembers", coGroupMembers);
|
||||||
|
return coGroup;
|
||||||
|
}
|
||||||
|
|
||||||
|
public JsonObject createNewCou(String name, String description) {
|
||||||
|
JsonObject cou = new JsonObject();
|
||||||
|
JsonArray cous = new JsonArray();
|
||||||
|
JsonObject newCou = new JsonObject();
|
||||||
|
newCou.addProperty("Version", version);
|
||||||
|
newCou.addProperty("CoId", coid);
|
||||||
|
newCou.addProperty("Name",name);
|
||||||
|
newCou.addProperty("Description", description);
|
||||||
|
cous.add(newCou);
|
||||||
|
cou.addProperty("RequestType", "Cous");
|
||||||
|
cou.addProperty("Version", version);
|
||||||
|
cou.add("Cous", cous);
|
||||||
|
return cou;
|
||||||
|
}
|
||||||
|
|
||||||
|
public JsonObject createResponse(JsonElement response) {
|
||||||
|
JsonObject json = new JsonObject();
|
||||||
|
json.add("response", response);
|
||||||
|
return json;
|
||||||
|
}
|
||||||
|
|
||||||
|
public JsonObject createResponse(String response) {
|
||||||
|
JsonObject json = new JsonObject();
|
||||||
|
json.addProperty("response", response);
|
||||||
|
return json;
|
||||||
|
}
|
||||||
|
|
||||||
|
public JsonObject createResponse(Number response) {
|
||||||
|
JsonObject json = new JsonObject();
|
||||||
|
json.addProperty("response", response);
|
||||||
|
return json;
|
||||||
|
}
|
||||||
|
|
||||||
|
public JsonObject createResponse(Boolean response) {
|
||||||
|
JsonObject json = new JsonObject();
|
||||||
|
json.addProperty("response", response);
|
||||||
|
return json;
|
||||||
|
}
|
||||||
|
|
||||||
|
public JsonObject createResponse(Character response) {
|
||||||
|
JsonObject json = new JsonObject();
|
||||||
|
json.addProperty("response", response);
|
||||||
|
return json;
|
||||||
|
}
|
||||||
|
}
|
|
@ -1 +1 @@
|
||||||
server.port = 8090
|
|
||||||
|
|
|
@ -0,0 +1,7 @@
|
||||||
|
registry.coid=2
|
||||||
|
registry.issuer=https://openaire-dev.aai-dev.grnet.gr/registry/
|
||||||
|
registry.user=***REMOVED***
|
||||||
|
registry.password=***REMOVED***
|
||||||
|
registry.version=1.0
|
||||||
|
server.port=8090
|
||||||
|
webbapp.front.domain=.di.uoa.gr
|
|
@ -1,6 +1,6 @@
|
||||||
package eu.dnetlib.dnetrolemanagement;
|
package eu.dnetlib.dnetrolemanagement;
|
||||||
|
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.Test;
|
||||||
import org.springframework.boot.test.context.SpringBootTest;
|
import org.springframework.boot.test.context.SpringBootTest;
|
||||||
|
|
||||||
@SpringBootTest
|
@SpringBootTest
|
||||||
|
|
Loading…
Reference in New Issue