Project

General

Profile

1
package eu.dnetlib.openaire.exporter.project;
2

    
3
import java.io.BufferedOutputStream;
4
import java.io.IOException;
5
import java.io.OutputStream;
6
import java.sql.SQLException;
7
import java.text.SimpleDateFormat;
8
import java.util.Date;
9
import java.util.Map;
10
import java.util.zip.ZipOutputStream;
11
import javax.servlet.ServletResponse;
12
import javax.servlet.http.HttpServletRequest;
13
import javax.servlet.http.HttpServletResponse;
14

    
15
import com.google.common.xml.XmlEscapers;
16
import eu.dnetlib.OpenaireExporterConfig;
17
import eu.dnetlib.OpenaireExporterConfig.Project;
18
import eu.dnetlib.common.rmi.DNetRestDocumentation;
19
import eu.dnetlib.openaire.exporter.AbstractExporterController;
20
import io.swagger.annotations.ApiOperation;
21
import io.swagger.annotations.ApiResponse;
22
import io.swagger.annotations.ApiResponses;
23
import org.antlr.stringtemplate.StringTemplate;
24
import org.apache.commons.io.IOUtils;
25
import org.apache.commons.lang3.StringUtils;
26
import org.apache.commons.logging.Log;
27
import org.apache.commons.logging.LogFactory;
28
import org.springframework.beans.factory.annotation.Autowired;
29
import org.springframework.core.io.Resource;
30
import org.springframework.stereotype.Controller;
31
import org.springframework.web.bind.annotation.RequestMapping;
32
import org.springframework.web.bind.annotation.RequestMethod;
33
import org.springframework.web.bind.annotation.RequestParam;
34

    
35
@Controller
36
@DNetRestDocumentation
37
public class ProjectsController extends AbstractExporterController {
38

    
39
	private static final Log log = LogFactory.getLog(ProjectsController.class); // NOPMD by marko on 11/24/08 5:02 PM
40

    
41
	public final static String UTF8 = "UTF-8";
42

    
43
	@Autowired
44
	private OpenaireExporterConfig config;
45

    
46
	@Autowired
47
	private JdbcApiDao dao;
48

    
49
	@Autowired
50
	private ProjectQueryParamsFactory projectQueryParamsFactory;
51

    
52
	@RequestMapping(value = "/export/**/project/dspace.do", method = RequestMethod.GET)
53
	void processDspace(final HttpServletRequest request, final ServletResponse response,
54
			@RequestParam(value = "startFrom", required = false) final String startFrom,
55
			@RequestParam(value = "startUntil", required = false) final String startUntil,
56
			@RequestParam(value = "endFrom", required = false) final String endFrom,
57
			@RequestParam(value = "endUntil", required = false) final String endUntil) throws Exception {
58

    
59
		final Project conf = config.getProject();
60

    
61
		final ProjectQueryParams params = projectQueryParamsFactory.generateParams(request, startFrom, startUntil, endFrom, endUntil);
62
		final StringTemplate headSt = new StringTemplate(IOUtils.toString(conf.getDspaceHeadTemplate().getInputStream(), UTF8));
63

    
64
		headSt.setAttribute("fundingProgramme", params.getFundingProgramme());
65

    
66
		final StringTemplate tailSt = new StringTemplate(IOUtils.toString(conf.getDspaceTailTemplate().getInputStream(), UTF8));
67

    
68
		response.setContentType("text/xml");
69
		doProcess(response, params, headSt.toString(), conf.getDspaceTemplate(), tailSt.toString(), s -> XmlEscapers.xmlContentEscaper().escape(oneLiner(s)));
70
	}
71

    
72
	@RequestMapping(value = "/export/**/project/eprints.do", method = RequestMethod.GET)
73
	void processEprints(final HttpServletRequest request, final ServletResponse response,
74
			@RequestParam(value = "startFrom", required = false) final String startFrom,
75
			@RequestParam(value = "startUntil", required = false) final String startUntil,
76
			@RequestParam(value = "endFrom", required = false) final String endFrom,
77
			@RequestParam(value = "endUntil", required = false) final String endUntil) throws Exception {
78

    
79
		final ProjectQueryParams params = projectQueryParamsFactory.generateParams(request, startFrom, startUntil, endFrom, endUntil);
80
		response.setContentType("text/html");
81
		doProcess(response, params, null, config.getProject().getEprintsTemplate(), null, s -> oneLiner(s));
82
	}
83

    
84
	private String oneLiner(final String s) {
85
		return StringUtils.isNotBlank(s) ? s.replaceAll("\\n", " ").trim() : "";
86
	}
87

    
88
	private void doProcess(
89
			final ServletResponse response,
90
			final ProjectQueryParams params,
91
			final String head, final Resource projectTemplate, final String tail,
92
			final ValueCleaner cleaner) throws IOException, SQLException {
93

    
94
		final StringTemplate st = new StringTemplate(IOUtils.toString(projectTemplate.getInputStream(), UTF8));
95
		try(final OutputStream out = new BufferedOutputStream(response.getOutputStream())) {
96
			dao.streamProjects(obtainQuery(params), out, head, st, tail, cleaner);
97
		}
98
	}
99

    
100
	@RequestMapping(value = "/export/project2tsv.do", method = RequestMethod.GET)
101
	void processTsv(final HttpServletRequest request, final HttpServletResponse response,
102
			@RequestParam(value = "funding", required = true) final String funding,
103
			@RequestParam(value = "article293", required = false) final Boolean article293) throws Exception {
104

    
105
		final String fundingPrefix = getFundingPrefix(funding, null);
106

    
107
		final String date = new SimpleDateFormat("yyyyMMdd").format(new Date());
108
		final String filename = "projects_" + funding + "_" + date + ".tsv";
109
		response.setContentType("text/tab-separated-values");
110
		response.setHeader("Content-Disposition", "attachment; filename=\"" + filename + ".zip\"");
111
		try(final ZipOutputStream out = new ZipOutputStream(new BufferedOutputStream(response.getOutputStream()))) {
112
			dao.processTsvRequest(out, article293, fundingPrefix, filename);
113
		} catch (Throwable e) {
114
			throw new RuntimeException("Error processing the request", e);
115
		}
116
	}
117

    
118
	@RequestMapping(value = "/export/streamProjectDetails.do", method = RequestMethod.GET)
119
	void streamProjectDetails(final HttpServletResponse response,
120
			@RequestParam(value = "format", required = true) final String format,
121
			@RequestParam(value = "compress", required = false) final Boolean compress) throws IOException, SQLException {
122

    
123
		if (compress != null && compress) {
124
			response.setHeader("Content-Encoding", "gzip");
125
		}
126
		switch (format) {
127
			case "csv":
128
				response.setContentType("text/csv");
129
				break;
130
			case "json":
131
				response.setContentType("text/plain");
132
				break;
133
			default: throw new IllegalArgumentException("unsupported format: " + format);
134
		}
135

    
136
		dao.processProjectDetails(response.getOutputStream(), format, compress);
137
	}
138

    
139
	@ApiOperation(value = "drop the project exporter caches", notes = "drop the project exporter caches", httpMethod = "GET")
140
	@ApiResponses(value = {
141
			@ApiResponse(code = 200, message = "OK"),
142
			@ApiResponse(code = 500, message = "unexpected error") })
143
	@RequestMapping(value = "/export/dropcache.do", method = RequestMethod.GET)
144
	public void dropDsCaches() {
145
		dao.dropCache();
146
	}
147

    
148
	/**
149
	 * Creates the query on the fundingProgramme specified in the given parameters.
150
	 *
151
	 * @param params
152
	 *            request parameters
153
	 * @return the query string
154
	 * @throws IllegalArgumentException
155
	 *             if the funding program is not recognized
156
	 * @throws IOException
157
	 *             if there are problem loading the query temlate
158
	 * @throws IllegalArgumentException
159
	 *             if the funding program is not recognized
160
	 */
161
	protected String obtainQuery(final ProjectQueryParams params) throws IllegalArgumentException, IOException {
162
		String funding = params.getFundingProgramme();
163
		String suffix = params.getFundingPath();
164

    
165
		final StringTemplate st = new StringTemplate(IOUtils.toString(config.getProject().getProjectsFundingQueryTemplate().getInputStream(), UTF8));
166
		st.setAttribute("fundingprefix", getFundingPrefix(funding, suffix));
167
		String theQuery = setDateParameters(st.toString(), params);
168
		log.debug("Generated query: " + theQuery);
169
		return theQuery;
170
	}
171

    
172
	private String getFundingPrefix(final String funding, final String suffix) {
173
		final Map<String, String> fundingIds = dao.readFundingpathIds();
174
		if (!fundingIds.containsKey(funding.toUpperCase())) {
175
			throw new IllegalArgumentException("invalid funding " + funding);
176
		}
177
		String fundingPrefix = fundingIds.get(funding.toUpperCase());
178
		return StringUtils.isBlank(suffix) ? fundingPrefix : fundingPrefix + "::" + suffix.toUpperCase();
179
	}
180

    
181
	private String setDateParameters(final String query, final ProjectQueryParams params) {
182
		String queryWithDates = query;
183
		if (params.getStartFrom() != null) {
184
			queryWithDates += " AND startdate >= '" + params.getStartFrom() + "'";
185
		}
186
		if (params.getStartUntil() != null) {
187
			queryWithDates += " AND startdate <= '" + params.getStartUntil() + "'";
188
		}
189
		if (params.getEndFrom() != null) {
190
			queryWithDates += " AND enddate >= '" + params.getEndFrom() + "'";
191
		}
192
		if (params.getEndUntil() != null) {
193
			queryWithDates += " AND enddate <= '" + params.getEndUntil() + "'";
194
		}
195
		return queryWithDates;
196
	}
197

    
198
}
(4-4/5)