Project

General

Profile

1
package eu.dnetlib.openaire.directindex.api;
2

    
3
import java.io.StringWriter;
4
import java.util.*;
5
import java.util.stream.Collectors;
6
import java.util.stream.Collectors;
7

    
8
import com.google.common.base.Function;
9
import com.google.common.collect.Lists;
10
import eu.dnetlib.miscutils.functional.hash.Hashing;
11
import eu.dnetlib.openaire.directindex.objects.ZenodoContextList;
12
import org.apache.commons.lang.StringUtils;
13
import org.springframework.web.client.RestClientException;
14
import org.springframework.web.client.RestTemplate;
15

    
16
/**
17
 * Created by michele on 15/01/16.
18
 */
19
public class OpenAIRESubmitterUtils {
20

    
21
	private static final org.apache.commons.logging.Log log = org.apache.commons.logging.LogFactory.getLog(OpenAIRESubmitterUtils.class);
22
	private static final String ZENODO_COMMUNITY = "zenodo.org/communities/";
23
	private String community_api;
24
	public OpenAIRESubmitterUtils(String community_api){
25
		this.community_api = community_api;
26
	}
27

    
28
	public Map<String, String> calculateProjectInfo(final String link) {
29
		final Map<String, String> info = new HashMap<String, String>();
30
		final String[] arr = link.split("/");
31
		// info:eu-repo/grantAgreement/EC/FP7/244909/EU/Making Capabilities Work/WorkAble
32

    
33
		if (arr.length > 4) {
34
			final String acronym = arr.length > 7 ? arr[7] : "";
35
			final String title = arr.length > 6 ? StringUtils.isNotBlank(arr[6]) ? arr[6] : acronym : "";
36
			final String jurisdiction = arr.length > 5 ? arr[5] : "";
37
			final String funderId = calculateFunderId(arr[2], arr[3]);
38
			info.put("id", calculateProjectId(arr[2], arr[3], arr[4]));
39
			info.put("funderShortName", arr[2]);
40
			info.put("fundingName", arr[3]);
41
			info.put("code", arr[4]);
42
			info.put("jurisdiction", jurisdiction);
43
			info.put("title", title);
44
			info.put("acronym", acronym);
45
			info.put("funderId", funderId);
46
			info.put("funderName", calculateFunderName(arr[2]));
47
			info.put("fundingId", funderId + "::" + arr[3]);
48
		}
49
		return info;
50
	}
51

    
52
	protected String calculateFunderPrefix(final String funderShortName, final String funding){
53
		switch(funderShortName.toLowerCase()){
54
		case "conicyt":
55
			return "conicytf____::";
56
		case "dfg":
57
			return "dfgf________::";
58
		case "ec":
59
			if (funding.equalsIgnoreCase("fp7")) {
60
				return "corda_______::";
61
			} else {
62
				return "corda__h2020::";
63
			}
64
		case "eea":
65
			return "euenvagency_::";
66
		case "hrzz":
67
		case "mzos":
68
			return "irb_hr______::";
69
		case "tara":
70
			return "taraexp_____::";
71
		case "tubitak":
72
			return "tubitakf____::";
73
		default:
74
			String prefix = funderShortName.toLowerCase();
75
			//ensure we have 12 chars
76
			while(prefix.length() < 12) prefix += "_";
77
			return prefix +"::";
78
		}
79
	}
80

    
81
	protected String calculateProjectId(final String funderShortName, final String funding, final String code) {
82
		final String suffix = Hashing.md5(code);
83
		final String funderPrefix = calculateFunderPrefix(funderShortName, funding);
84
		return funderPrefix + suffix;
85
	}
86

    
87
	protected String calculateFunderId(final String funderShortName, final String funding) {
88
		switch (funderShortName.toLowerCase()) {
89
		case "ec":
90
			return "ec__________::EC";
91
		default:
92
			String prefix = calculateFunderPrefix(funderShortName, funding);
93
			return prefix + funderShortName.toUpperCase();
94
		}
95
	}
96

    
97

    
98
	protected String calculateFunderName(final String funderShortName) {
99

    
100
		switch (funderShortName.toLowerCase()) {
101
		case "aff":
102
		case "aka":
103
			return "Academy of Finland";
104
		case "anr":
105
			return "French National Research Agency (ANR)";
106
		case "arc":
107
			return "Australian Research Council (ARC)";
108
		case "cihr":
109
			return "Canadian Institutes of Health Research";
110
		case "conicyt":
111
			return "Comisión Nacional de Investigación Científica y Tecnológica";
112
		case "dfg":
113
			return "Deutsche Forschungsgemeinschaft";
114
		case "ec":
115
			return "European Commission";
116
		case "eea":
117
			return "European Environment Agency";
118
		case "fct":
119
			return "Fundação para a Ciência e a Tecnologia, I.P.";
120
		case "fwf":
121
			return "Austrian Science Fund (FWF)";
122
		case "gsrt":
123
			return "General Secretariat of Research and Technology (GSRT)";
124
		case "hrzz":
125
			return "Croatian Science Foundation (CSF)";
126
		case "innoviris":
127
			return "INNOVIRIS";
128
		case "mestd":
129
			return "Ministry of Education, Science and Technological Development of Republic of Serbia";
130
		case "miur":
131
			return "Ministero dell'Istruzione dell'Università e della Ricerca";
132
		case "mzos":
133
			return "Ministry of Science, Education and Sports of the Republic of Croatia (MSES)";
134
		case "nhmrc":
135
			return "National Health and Medical Research Council (NHMRC)";
136
		case "nih":
137
			return "National Institutes of Health";
138
		case "nsf":
139
			return "National Science Foundation";
140
		case "nserc":
141
			return "Natural Sciences and Engineering Research Council of Canada";
142
		case "nwo":
143
			return "Netherlands Organisation for Scientific Research (NWO)";
144
		case "rcuk":
145
			return "Research Council UK";
146
		case "rif":
147
		case "rpf":
148
			return "Research and Innovation Foundation";
149
		case "rsf":
150
			return "Russian Science Foundation";
151
		case "sfi":
152
			return "Science Foundation Ireland";
153
		case "sgov":
154
			return "Gobierno de España";
155
		case "snsf":
156
			return "Swiss National Science Foundation";
157
		case "sshrc":
158
			return "Social Sciences and Humanities Research Council";
159
		case "tara":
160
			return "Tara Expeditions Foundation";
161
		case "tubitak":
162
			return "Türkiye Bilimsel ve Teknolojik Araştırma Kurumu";
163
		case "wt":
164
			return "Wellcome Trust";
165
		default:
166
			log.error("Funder short name '"+funderShortName+"' not managed");
167
			return "";
168
		}
169
	}
170

    
171
	private List<String> filterContexts(List<String> contexts){
172

    
173
		List<String> zenodoContexts
174
				= contexts.stream()
175
				.map(c -> {
176
					if(c.contains(ZENODO_COMMUNITY))
177
						return c.substring(c.lastIndexOf("/")+1);
178
					return null;
179
				}).collect(Collectors.toList());
180

    
181
		if (zenodoContexts.size()>0){
182
			contexts = contexts.stream().filter(c -> !c.contains(ZENODO_COMMUNITY)).collect(Collectors.toList());
183
			RestTemplate rt = new RestTemplate();
184
			Set<String> zenodoOpenAIRE = new HashSet<>();
185
			for (String context: zenodoContexts){
186
				//String ct = context.substring(context.lastIndexOf("/")+1);
187
				try{
188
					zenodoOpenAIRE.addAll(rt.getForObject(community_api +context+"/openairecommunities", ZenodoContextList.class).getOpenAirecommunitylist());
189
				}catch(RestClientException rce){
190
					log.error("Unable to get object for " + community_api +context+"/openairecommunities");
191
				}
192

    
193

    
194
			}
195
			contexts.addAll(zenodoOpenAIRE);
196
		}
197

    
198
		return contexts;
199

    
200
	}
201
	public List<ContextInfo> processContexts(final List<String> list) {
202
		filterContexts(list);
203
		return Lists.newArrayList(Lists.transform(filterContexts(list), new Function<String, ContextInfo>() {
204

    
205
			@Override
206
			public ContextInfo apply(final String s) {
207
				return createContextInfo(s.split("::"), 0);
208
			}
209

    
210
			private ContextInfo createContextInfo(final String[] arr, final int pos) {
211
				final StringWriter id = new StringWriter();
212
				id.write(arr[0]);
213
				for (int i = 0; i < pos; i++) {
214
					id.write("::");
215
					id.write(arr[i + 1]);
216
				}
217
				final String elem = (pos == 0) ? "context" : (pos == 1) ? "category" : "concept";
218
				final ContextInfo info = new ContextInfo(elem, id.toString());
219
				if ((pos + 1) < arr.length) {
220
					info.getChildren().add(createContextInfo(arr, pos + 1));
221
				}
222
				return info;
223
			}
224
		}));
225

    
226
	}
227

    
228
	public class ContextInfo {
229

    
230
		private String elem;
231
		private String id;
232
		private List<ContextInfo> children = new ArrayList<ContextInfo>();
233

    
234
		public ContextInfo(final String elem,
235
				final String id) {
236
			this.elem = elem;
237
			this.id = id;
238
		}
239

    
240
		public String getElem() {
241
			return elem;
242
		}
243

    
244
		public void setElem(final String elem) {
245
			this.elem = elem;
246
		}
247

    
248
		public String getId() {
249
			return id;
250
		}
251

    
252
		public void setId(final String id) {
253
			this.id = id;
254
		}
255

    
256
		public List<ContextInfo> getChildren() {
257
			return children;
258
		}
259

    
260
		public void setChildren(final List<ContextInfo> children) {
261
			this.children = children;
262
		}
263

    
264
		public boolean isRoot() {
265
			return elem.equals("context");
266
		}
267
	}
268
}
(5-5/8)