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;
45 import javax.persistence.CascadeType;
46 import javax.persistence.Column;
47 import javax.persistence.Embeddable;
48 import javax.persistence.Entity;
49 import javax.persistence.FetchType;
50 import javax.persistence.GeneratedValue;
51 import javax.persistence.GenerationType;
52 import javax.persistence.Id;
53 import javax.persistence.NamedQueries;
54 import javax.persistence.NamedQuery;
55 import javax.persistence.OneToMany;
56 import javax.persistence.Table;
57 import javax.validation.constraints.Digits;
58 import javax.validation.constraints.NotNull;
59 import javax.validation.constraints.Pattern;
60 import javax.validation.constraints.Size;
61 import lombok.AllArgsConstructor;
62 import lombok.EqualsAndHashCode;
64 import lombok.NoArgsConstructor;
66 import org.hibernate.validator.constraints.SafeHtml;
67 import org.hibernate.validator.constraints.URL;
68 import org.onap.portal.domain.db.ep.EpAppFunction;
69 import org.onap.portal.domain.db.ep.EpAppRoleFunction;
70 import org.onap.portal.domain.db.ep.EpMicroservice;
71 import org.onap.portal.domain.db.ep.EpUserRolesRequest;
72 import org.onap.portal.domain.db.ep.EpWebAnalyticsSource;
73 import org.onap.portal.domain.db.ep.EpWidgetCatalogRole;
74 import org.onap.portal.domain.dto.DomainVo;
77 CREATE TABLE `fn_app` (
78 `app_id` int(11) NOT NULL AUTO_INCREMENT,
79 `app_name` varchar(100) NOT NULL DEFAULT '?',
80 `app_image_url` varchar(256) DEFAULT NULL,
81 `app_description` varchar(512) DEFAULT NULL,
82 `app_notes` varchar(4096) DEFAULT NULL,
83 `app_url` varchar(256) DEFAULT NULL,
84 `app_alternate_url` varchar(256) DEFAULT NULL,
85 `app_rest_endpoint` varchar(2000) DEFAULT NULL,
86 `ml_app_name` varchar(50) NOT NULL DEFAULT '?',
87 `ml_app_admin_id` varchar(7) NOT NULL DEFAULT '?',
88 `mots_id` int(11) DEFAULT NULL,
89 `app_password` varchar(256) NOT NULL DEFAULT '?',
90 `open` char(1) DEFAULT 'N',
91 `enabled` char(1) DEFAULT 'Y',
92 `thumbnail` mediumblob DEFAULT NULL,
93 `app_username` varchar(50) DEFAULT NULL,
94 `ueb_key` varchar(256) DEFAULT NULL,
95 `ueb_secret` varchar(256) DEFAULT NULL,
96 `ueb_topic_name` varchar(256) DEFAULT NULL,
97 `app_type` int(11) NOT NULL DEFAULT 1,
98 `auth_central` char(1) NOT NULL DEFAULT 'N',
99 `auth_namespace` varchar(100) DEFAULT NULL,
100 PRIMARY KEY (`app_id`)
106 name = "FnApp.retrieveWhereAuthCentralIsYAndOpenIsNAndAuthNamespaceIsNotNull",
107 query = "from FnApp where auth_central = 'Y' and open = 'N' and auth_namespace is not null")
110 @Table(name = "fn_app")
113 @EqualsAndHashCode(callSuper = true)
118 public class FnApp extends DomainVo implements Serializable {
121 @GeneratedValue(strategy = GenerationType.AUTO)
122 @Column(name = "app_Id", length = 11, nullable = false)
123 @Digits(integer = 11, fraction = 0)
125 @Column(name = "app_name", length = 100, nullable = false, columnDefinition = "varchar(100) not null default '?'")
129 private String appName;
130 @Column(name = "app_image_url", length = 256)
133 private String appImageUrl;
134 @Column(name = "app_description", length = 512)
137 private String appDescription;
138 @Column(name = "app_notes", length = 4096)
141 private String appNotes;
142 @Column(name = "app_url", length = 256)
147 private String appUrl;
148 @Column(name = "app_alternate_url", length = 256)
151 private String appAlternateUrl;
152 @Column(name = "app_rest_endpoint", length = 2000)
155 private String appRestEndpoint;
156 @Column(name = "ml_app_name", length = 50, nullable = false, columnDefinition = "varchar(50) not null default '?'")
160 private String ml_app_name;
161 @Column(name = "ml_app_admin_id", length = 7, nullable = false, columnDefinition = "varchar(7) not null default '?'")
165 private String mlAppAdminId;
166 @Column(name = "mots_id", length = 11)
167 @Digits(integer = 11, fraction = 0)
169 @Column(name = "app_password", length = 256, nullable = false, columnDefinition = "varchar(256) not null default '?'")
173 private String appPassword;
174 @Column(name = "_open", length = 1, columnDefinition = "char(1) default 'N'")
175 private Boolean open;
176 @Column(name = "_enabled", length = 1, columnDefinition = "char(1) default 'N'")
177 private Boolean enabled;
178 @Column(name = "active_yn", length = 1, columnDefinition = "char(1) default 'Y'")
179 @Pattern(regexp = "[YNyn]")
183 private String activeYn;
184 @Column(name = "_thumbnail", columnDefinition = "mediumblob null default null")
185 private byte[] thumbnail;
186 @Column(name = "app_username", length = 50)
189 private String appUsername;
190 @Column(name = "ueb_key", length = 256)
193 private String uebKey;
194 @Column(name = "ueb_secret", length = 256)
197 private String uebSecret;
198 @Column(name = "ueb_topic_name", length = 256)
201 private String uebTopicName;
202 @Column(name = "app_type", length = 11, columnDefinition = "int(11) not null default 1")
203 @Digits(integer = 11, fraction = 0)
204 private Long appType;
205 @Column(name = "auth_central", length = 1, columnDefinition = "char(1) not null default 'N'", nullable = false)
206 private Boolean authCentral;
207 @Column(name = "auth_namespace", length = 100)
210 private String authNamespace;
212 targetEntity = FnMenuFunctionalRoles.class,
214 cascade = CascadeType.ALL,
215 fetch = FetchType.LAZY
217 private Set<FnMenuFunctionalRoles> fnMenuFunctionalRoles;
219 targetEntity = EpUserRolesRequest.class,
221 cascade = CascadeType.ALL,
222 fetch = FetchType.LAZY
224 private Set<EpUserRolesRequest> epUserRolesRequests;
226 targetEntity = EpAppFunction.class,
228 cascade = CascadeType.ALL,
229 fetch = FetchType.LAZY
231 private Set<EpAppFunction> epAppFunctions;
233 targetEntity = EpAppRoleFunction.class,
235 cascade = CascadeType.ALL,
236 fetch = FetchType.LAZY
238 private Set<EpAppRoleFunction> epAppRoleFunctions;
240 targetEntity = FnUserRole.class,
242 cascade = CascadeType.ALL,
243 fetch = FetchType.LAZY
245 private Set<FnUserRole> fnUserRoles;
247 targetEntity = EpWebAnalyticsSource.class,
249 cascade = CascadeType.ALL,
250 fetch = FetchType.LAZY
252 private Set<EpWebAnalyticsSource> epWebAnalyticsSources;
254 targetEntity = EpWidgetCatalogRole.class,
256 cascade = CascadeType.ALL,
257 fetch = FetchType.LAZY
259 private Set<EpWidgetCatalogRole> epWidgetCatalogRoles;
261 targetEntity = EpMicroservice.class,
263 cascade = CascadeType.ALL,
264 fetch = FetchType.LAZY
266 private Set<EpMicroservice> epMicroservices;
268 targetEntity = FnPersUserAppSel.class,
270 cascade = CascadeType.ALL,
271 fetch = FetchType.LAZY
273 private Set<FnPersUserAppSel> fnPersUserAppSels;
275 public Boolean isRestrictedApp() {
276 return (this.appType == 2);