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.");
}
}
|