aboutsummaryrefslogtreecommitdiffstats
path: root/winery/org.eclipse.winery.repository/src/main/java/org/eclipse/winery/repository/resources/interfaces/ParametersResource.java
blob: c3afcbcb43f2bf3ab0a061883c1d0be48f12821d (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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
/*******************************************************************************
 * Copyright (c) 2012-2013 University of Stuttgart.
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v1.0
 * and the Apache License 2.0 which both accompany this distribution,
 * and are available at http://www.eclipse.org/legal/epl-v10.html
 * and http://www.apache.org/licenses/LICENSE-2.0
 *
 * Contributors:
 *     Oliver Kopp - initial API and implementation
 *******************************************************************************/
package org.eclipse.winery.repository.resources.interfaces;

import java.util.List;

import javax.ws.rs.Consumes;
import javax.ws.rs.FormParam;
import javax.ws.rs.POST;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.Response;
import javax.ws.rs.core.Response.Status;

import org.apache.commons.lang3.StringUtils;
import org.eclipse.winery.model.tosca.TBoolean;
import org.eclipse.winery.model.tosca.TParameter;
import org.eclipse.winery.repository.backend.BackendUtils;
import org.eclipse.winery.repository.resources._support.IPersistable;
import org.eclipse.winery.repository.resources._support.collections.withid.EntityWithIdCollectionResource;
import org.restdoc.annotations.RestDocParam;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import com.sun.jersey.api.view.Viewable;

public class ParametersResource extends EntityWithIdCollectionResource<ParameterResource, TParameter> {
	
	private static final Logger logger = LoggerFactory.getLogger(ParametersResource.class);
	
	
	public ParametersResource(List<TParameter> parameters, IPersistable typeResource) {
		super(ParameterResource.class, TParameter.class, parameters, typeResource);
	}
	
	@POST
	@Consumes(MediaType.APPLICATION_FORM_URLENCODED)
	@Produces(MediaType.TEXT_PLAIN)
	// @formatter:off
	public Response createParamter(
			@FormParam("name") String name,
			@FormParam("type") String type,
			@FormParam("required") @RestDocParam(description="type tYesNo, not Boolean. For convenience, on/off is also supported. In case this parameter is not provided, 'off' is assumed. This is in contrast to the specification, but it eases implementing the UI") String required) {
		// @formatter:on
		if (StringUtils.isEmpty(name)) {
			return Response.status(Status.BAD_REQUEST).entity("name must not be null").build();
		}
		if (StringUtils.isEmpty(type)) {
			return Response.status(Status.BAD_REQUEST).entity("type must not be null").build();
		}
		
		TParameter param = new TParameter();
		param.setName(name);
		param.setType(type);
		TBoolean tb;
		if (required == null) {
			// The specification states that the default value is "yes"
			// We assume "no", because Chrome does not send the checkbox data if a checkbox is not checked
			tb = TBoolean.NO;
		} else {
			if (required.equalsIgnoreCase("on")) {
				tb = TBoolean.YES;
			} else if (required.equalsIgnoreCase("off")) {
				tb = TBoolean.NO;
			} else {
				try {
					tb = TBoolean.valueOf(required);
				} catch (java.lang.IllegalArgumentException e) {
					return Response.status(Status.BAD_REQUEST).entity("Wrong format of required").build();
				}
			}
		}
		param.setRequired(tb);
		
		this.list.add(param);
		
		return BackendUtils.persist(this.res);
	}
	
	@Override
	public String getId(TParameter entity) {
		return entity.getName();
	}
	
	@Override
	public Viewable getHTML() {
		throw new IllegalStateException("Not yet implemented.");
	}
	
}