]> git.basschouten.com Git - openhab-addons.git/blob
affda36052fa9d9881ddc6466957493e6f877721
[openhab-addons.git] /
1 /**
2  * Copyright (c) 2010-2022 Contributors to the openHAB project
3  *
4  * See the NOTICE file(s) distributed with this work for additional
5  * information.
6  *
7  * This program and the accompanying materials are made available under the
8  * terms of the Eclipse Public License 2.0 which is available at
9  * http://www.eclipse.org/legal/epl-2.0
10  *
11  * SPDX-License-Identifier: EPL-2.0
12  */
13 package org.openhab.transform.javascript.internal.profiles;
14
15 import org.eclipse.jdt.annotation.NonNullByDefault;
16 import org.eclipse.jdt.annotation.Nullable;
17 import org.openhab.core.library.types.StringType;
18 import org.openhab.core.thing.profiles.ProfileCallback;
19 import org.openhab.core.thing.profiles.ProfileContext;
20 import org.openhab.core.thing.profiles.ProfileTypeUID;
21 import org.openhab.core.thing.profiles.StateProfile;
22 import org.openhab.core.transform.TransformationException;
23 import org.openhab.core.transform.TransformationHelper;
24 import org.openhab.core.transform.TransformationService;
25 import org.openhab.core.types.Command;
26 import org.openhab.core.types.State;
27 import org.openhab.core.types.Type;
28 import org.slf4j.Logger;
29 import org.slf4j.LoggerFactory;
30
31 /**
32  * Profile to offer the JavascriptTransformationservice on an ItemChannelLink
33  *
34  * @author Stefan Triller - Initial contribution
35  */
36 @NonNullByDefault
37 public class JavaScriptTransformationProfile implements StateProfile {
38
39     private final Logger logger = LoggerFactory.getLogger(JavaScriptTransformationProfile.class);
40
41     public static final ProfileTypeUID PROFILE_TYPE_UID = new ProfileTypeUID(
42             TransformationService.TRANSFORM_PROFILE_SCOPE, "JS");
43
44     private static final String FUNCTION_PARAM = "function";
45     private static final String SOURCE_FORMAT_PARAM = "sourceFormat";
46
47     private final TransformationService service;
48     private final ProfileCallback callback;
49
50     private final @Nullable String function;
51     private final @Nullable String sourceFormat;
52
53     public JavaScriptTransformationProfile(ProfileCallback callback, ProfileContext context,
54             TransformationService service) {
55         this.service = service;
56         this.callback = callback;
57
58         Object paramFunction = context.getConfiguration().get(FUNCTION_PARAM);
59         Object paramSource = context.getConfiguration().get(SOURCE_FORMAT_PARAM);
60
61         logger.debug("Profile configured with '{}'='{}', '{}'={}", FUNCTION_PARAM, paramFunction, SOURCE_FORMAT_PARAM,
62                 paramSource);
63         // SOURCE_FORMAT_PARAM is an advanced parameter and we assume "%s" if it is not set
64         if (paramSource == null) {
65             paramSource = "%s";
66         }
67         if (paramFunction instanceof String && paramSource instanceof String) {
68             function = (String) paramFunction;
69             sourceFormat = (String) paramSource;
70         } else {
71             logger.error("Parameter '{}' and '{}' have to be Strings. Profile will be inactive.", FUNCTION_PARAM,
72                     SOURCE_FORMAT_PARAM);
73             function = null;
74             sourceFormat = null;
75         }
76     }
77
78     @Override
79     public ProfileTypeUID getProfileTypeUID() {
80         return PROFILE_TYPE_UID;
81     }
82
83     @Override
84     public void onStateUpdateFromItem(State state) {
85     }
86
87     @Override
88     public void onCommandFromItem(Command command) {
89         callback.handleCommand(command);
90     }
91
92     @Override
93     public void onCommandFromHandler(Command command) {
94         if (function == null || sourceFormat == null) {
95             logger.warn(
96                     "Please specify a function and a source format for this Profile in the '{}', and '{}' parameters. Returning the original command now.",
97                     FUNCTION_PARAM, SOURCE_FORMAT_PARAM);
98             callback.sendCommand(command);
99             return;
100         }
101         callback.sendCommand((Command) transformState(command));
102     }
103
104     @Override
105     public void onStateUpdateFromHandler(State state) {
106         if (function == null || sourceFormat == null) {
107             logger.warn(
108                     "Please specify a function and a source format for this Profile in the '{}' and '{}' parameters. Returning the original state now.",
109                     FUNCTION_PARAM, SOURCE_FORMAT_PARAM);
110             callback.sendUpdate(state);
111             return;
112         }
113         callback.sendUpdate((State) transformState(state));
114     }
115
116     private Type transformState(Type state) {
117         String localFunction = function, localSourceFormat = sourceFormat;
118         if (localFunction != null && localSourceFormat != null) {
119             String result = state.toFullString();
120             try {
121                 result = TransformationHelper.transform(service, localFunction, localSourceFormat, result);
122             } catch (TransformationException e) {
123                 logger.warn("Could not transform state '{}' with function '{}' and format '{}'", state, function,
124                         sourceFormat);
125             }
126             StringType resultType = new StringType(result);
127             logger.debug("Transformed '{}' into '{}'", state, resultType);
128             return resultType;
129         } else {
130             logger.warn(
131                     "Please specify a function and a source format for this Profile in the '{}' and '{}' parameters. Returning the original state now.",
132                     FUNCTION_PARAM, SOURCE_FORMAT_PARAM);
133             return state;
134         }
135     }
136 }