2 * ============LICENSE_START==========================================
4 * ===================================================================
5 * Copyright (C) 2019 AT&T Intellectual Property. All rights reserved.
6 * ===================================================================
7 * Modifications Copyright (c) 2019 Samsung
8 * ===================================================================
10 * Unless otherwise specified, all software contained herein is licensed
11 * under the Apache License, Version 2.0 (the "License");
12 * you may not use this software except in compliance with the License.
13 * You may obtain a copy of the License at
15 * http://www.apache.org/licenses/LICENSE-2.0
17 * Unless required by applicable law or agreed to in writing, software
18 * distributed under the License is distributed on an "AS IS" BASIS,
19 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
20 * See the License for the specific language governing permissions and
21 * limitations under the License.
23 * Unless otherwise specified, all documentation contained herein is licensed
24 * under the Creative Commons License, Attribution 4.0 Intl. (the "License");
25 * you may not use this documentation except in compliance with the License.
26 * You may obtain a copy of the License at
28 * https://creativecommons.org/licenses/by/4.0/
30 * Unless required by applicable law or agreed to in writing, documentation
31 * distributed under the License is distributed on an "AS IS" BASIS,
32 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
33 * See the License for the specific language governing permissions and
34 * limitations under the License.
36 * ============LICENSE_END============================================
41 package org.onap.portal.domain.db.fn;
43 import java.io.Serializable;
44 import java.util.ArrayList;
45 import java.util.List;
46 import javax.persistence.CascadeType;
47 import javax.persistence.Column;
48 import javax.persistence.Embeddable;
49 import javax.persistence.Entity;
50 import javax.persistence.FetchType;
51 import javax.persistence.GeneratedValue;
52 import javax.persistence.GenerationType;
53 import javax.persistence.Id;
54 import javax.persistence.NamedQueries;
55 import javax.persistence.NamedQuery;
56 import javax.persistence.OneToMany;
57 import javax.persistence.Table;
58 import javax.validation.constraints.Digits;
59 import javax.validation.constraints.NotNull;
60 import javax.validation.constraints.Pattern;
61 import javax.validation.constraints.Size;
62 import lombok.AllArgsConstructor;
63 import lombok.EqualsAndHashCode;
65 import lombok.NoArgsConstructor;
67 import org.hibernate.validator.constraints.SafeHtml;
68 import org.hibernate.validator.constraints.URL;
69 import org.onap.portal.domain.db.ep.EpAppFunction;
70 import org.onap.portal.domain.db.ep.EpAppRoleFunction;
71 import org.onap.portal.domain.db.ep.EpMicroservice;
72 import org.onap.portal.domain.db.ep.EpUserRolesRequest;
73 import org.onap.portal.domain.db.ep.EpWebAnalyticsSource;
74 import org.onap.portal.domain.db.ep.EpWidgetCatalogRole;
75 import org.onap.portal.domain.dto.DomainVo;
78 CREATE TABLE `fn_app` (
79 `app_id` int(11) NOT NULL AUTO_INCREMENT,
80 `app_name` varchar(100) NOT NULL DEFAULT '?',
81 `app_image_url` varchar(256) DEFAULT NULL,
82 `app_description` varchar(512) DEFAULT NULL,
83 `app_notes` varchar(4096) DEFAULT NULL,
84 `app_url` varchar(256) DEFAULT NULL,
85 `app_alternate_url` varchar(256) DEFAULT NULL,
86 `app_rest_endpoint` varchar(2000) DEFAULT NULL,
87 `ml_app_name` varchar(50) NOT NULL DEFAULT '?',
88 `ml_app_admin_id` varchar(7) NOT NULL DEFAULT '?',
89 `mots_id` int(11) DEFAULT NULL,
90 `app_password` varchar(256) NOT NULL DEFAULT '?',
91 `open` char(1) DEFAULT 'N',
92 `enabled` char(1) DEFAULT 'Y',
93 `thumbnail` mediumblob DEFAULT NULL,
94 `app_username` varchar(50) DEFAULT NULL,
95 `ueb_key` varchar(256) DEFAULT NULL,
96 `ueb_secret` varchar(256) DEFAULT NULL,
97 `ueb_topic_name` varchar(256) DEFAULT NULL,
98 `app_type` int(11) NOT NULL DEFAULT 1,
99 `auth_central` char(1) NOT NULL DEFAULT 'N',
100 `auth_namespace` varchar(100) DEFAULT NULL,
101 PRIMARY KEY (`app_id`)
107 name = "FnApp.retrieveWhereAuthCentralIsYAndOpenIsNAndAuthNamespaceIsNotNull",
108 query = "from FnApp where auth_central = 'Y' and open = 'N' and auth_namespace is not null")
111 @Table(name = "fn_app")
114 @EqualsAndHashCode(callSuper = true)
119 public class FnApp extends DomainVo implements Serializable {
122 @GeneratedValue(strategy = GenerationType.AUTO)
123 @Column(name = "app_Id", length = 11, nullable = false, columnDefinition = "int(11) AUTO_INCREMENT")
124 @Digits(integer = 11, fraction = 0)
126 @Column(name = "app_name", length = 100, nullable = false, columnDefinition = "varchar(100) not null default '?'")
130 private String appName;
131 @Column(name = "app_image_url", length = 256)
134 private String appImageUrl;
135 @Column(name = "app_description", length = 512)
138 private String appDescription;
139 @Column(name = "app_notes", length = 4096)
142 private String appNotes;
143 @Column(name = "app_url", length = 256)
148 private String appUrl;
149 @Column(name = "app_alternate_url", length = 256)
152 private String appAlternateUrl;
153 @Column(name = "app_rest_endpoint", length = 2000)
156 private String appRestEndpoint;
157 @Column(name = "ml_app_name", length = 50, nullable = false, columnDefinition = "varchar(50) not null default '?'")
161 private String ml_app_name;
162 @Column(name = "ml_app_admin_id", length = 7, nullable = false, columnDefinition = "varchar(7) not null default '?'")
166 private String mlAppAdminId;
167 @Column(name = "mots_id", length = 11)
168 @Digits(integer = 11, fraction = 0)
170 @Column(name = "app_password", length = 256, nullable = false, columnDefinition = "varchar(256) not null default '?'")
174 private String appPassword;
175 @Column(name = "open", length = 1, columnDefinition = "char(1) default 'N'")
176 @Pattern(regexp = "[YNyn]")
181 @Column(name = "ENABLED", length = 1, columnDefinition = "char(1) default 'N'")
182 @Pattern(regexp = "[YNyn]")
186 private String enabled;
187 @Column(name = "active_yn", length = 1, columnDefinition = "char(1) default 'Y'")
188 @Pattern(regexp = "[YNyn]")
192 private String activeYn;
193 @Column(name = "thumbnail", columnDefinition = "mediumblob null default null")
194 private byte[] thumbnail;
195 @Column(name = "app_username", length = 50)
198 private String appUsername;
199 @Column(name = "ueb_key", length = 256)
202 private String uebKey;
203 @Column(name = "ueb_secret", length = 256)
206 private String uebSecret;
207 @Column(name = "ueb_topic_name", length = 256)
210 private String uebTopicName;
211 @Column(name = "app_type", length = 11, columnDefinition = "int(11) not null default 1")
212 @Digits(integer = 11, fraction = 0)
213 private Long appType;
214 @Column(name = "auth_central", length = 1, columnDefinition = "char(1) not null default 'N'", nullable = false)
215 @Pattern(regexp = "[YNyn]")
219 private String authCentral;
220 @Column(name = "auth_namespace", length = 100)
223 private String authNamespace;
225 targetEntity = FnMenuFunctionalRoles.class,
227 cascade = CascadeType.ALL,
228 fetch = FetchType.LAZY
230 private List<FnMenuFunctionalRoles> fnMenuFunctionalRoles = new ArrayList<>();
232 targetEntity = EpUserRolesRequest.class,
234 cascade = CascadeType.ALL,
235 fetch = FetchType.LAZY
237 private List<EpUserRolesRequest> epUserRolesRequests = new ArrayList<>();
239 targetEntity = EpAppFunction.class,
241 cascade = CascadeType.ALL,
242 fetch = FetchType.LAZY
244 private List<EpAppFunction> epAppFunctions = new ArrayList<>();
246 targetEntity = EpAppRoleFunction.class,
248 cascade = CascadeType.ALL,
249 fetch = FetchType.LAZY
251 private List<EpAppRoleFunction> epAppRoleFunctions = new ArrayList<>();
253 targetEntity = FnUserRole.class,
255 cascade = CascadeType.ALL,
256 fetch = FetchType.LAZY
258 private List<FnUserRole> fnUserRoles = new ArrayList<>();
260 targetEntity = EpWebAnalyticsSource.class,
262 cascade = CascadeType.ALL,
263 fetch = FetchType.LAZY
265 private List<EpWebAnalyticsSource> epWebAnalyticsSources = new ArrayList<>();
267 targetEntity = EpWidgetCatalogRole.class,
269 cascade = CascadeType.ALL,
270 fetch = FetchType.LAZY
272 private List<EpWidgetCatalogRole> epWidgetCatalogRoles = new ArrayList<>();
274 targetEntity = EpMicroservice.class,
276 cascade = CascadeType.ALL,
277 fetch = FetchType.LAZY
279 private List<EpMicroservice> epMicroservices = new ArrayList<>();
281 targetEntity = FnPersUserAppSel.class,
283 cascade = CascadeType.ALL,
284 fetch = FetchType.LAZY
286 private List<FnPersUserAppSel> fnPersUserAppSels = new ArrayList<>();