2 * Copyright (C) 2016 - 2018 Free Software Foundation
4 * This program is free software: you can redistribute it and/or modify
5 * it under the terms of the GNU Affero General Public License as
6 * published by the Free Software Foundation, either version 3 of the
7 * License, or (at your option) any later version.
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU Affero General Public License for more details.
14 * You should have received a copy of the GNU Affero General Public License
15 * along with this program. If not, see <http://www.gnu.org/licenses/>.
17 package org.mxchange.jjobs.beans.features;
19 import javax.annotation.PostConstruct;
20 import javax.enterprise.context.ApplicationScoped;
21 import javax.inject.Named;
22 import org.mxchange.jjobs.beans.BaseJobsBean;
27 * @author Roland Häder<roland@mxchange.org>
29 @Named ("featureController")
31 public class JobsFeatureWebApplicationBean extends BaseJobsBean implements JobsFeaturesWebApplicationController {
36 private static final long serialVersionUID = 64_237_512_690_168_674L;
41 public JobsFeatureWebApplicationBean () {
42 // Call super constructor
47 * Post-construction method
54 public boolean isFeatureEnabled (final String feature) {
55 // The parameter must be set
56 if (null == feature) {
58 throw new NullPointerException("feature is null"); //NOI18N
59 } else if (feature.isEmpty()) {
61 throw new IllegalArgumentException("feature is empty"); //NOI18N
64 // Default is not enabled
65 boolean isEnabled = false;
67 // Get value from property
68 final String contextParameter = this.getStringContextParameter(String.format("is_feature_%s_enabled", feature)); //NOI18N
70 // Is the context parameter found?
71 if (contextParameter instanceof String) {
73 isEnabled = (Boolean.parseBoolean(contextParameter) == Boolean.TRUE);