From ff57db83966107d7a22febf0e782cc92df00bf0b Mon Sep 17 00:00:00 2001 From: Hilbrand Bouwkamp Date: Fri, 26 Apr 2019 13:03:28 +0200 Subject: [PATCH] Added maven archetype project to generate binding skeletons (#589) This archetype generates bindings for the new bnd based build system. It also updates specific bundle files that need information about the new binding. This doesn't yet include generation of test projects. Signed-off-by: Hilbrand Bouwkamp --- pom.xml | 2 +- tools/archetype/binding/.project | 17 ++ tools/archetype/binding/pom.xml | 59 +++++++ .../META-INF/archetype-post-generate.groovy | 157 ++++++++++++++++++ .../META-INF/maven/archetype-metadata.xml | 51 ++++++ .../resources/archetype-resources/.classpath | 32 ++++ .../resources/archetype-resources/.project | 23 +++ .../main/resources/archetype-resources/NOTICE | 13 ++ .../resources/archetype-resources/README.md | 56 +++++++ .../resources/archetype-resources/pom.xml | 16 ++ ..._bindingIdCamelCase__BindingConstants.java | 37 +++++ .../__bindingIdCamelCase__Configuration.java | 29 ++++ .../__bindingIdCamelCase__Handler.java | 103 ++++++++++++ .../__bindingIdCamelCase__HandlerFactory.java | 60 +++++++ .../resources/ESH-INF/binding/binding.xml | 10 ++ .../i18n/__bindingId___xx_XX.properties | 13 ++ .../resources/ESH-INF/thing/thing-types.xml | 32 ++++ tools/archetype/pom.xml | 45 +++++ tools/pom.xml | 21 +++ 19 files changed, 775 insertions(+), 1 deletion(-) create mode 100644 tools/archetype/binding/.project create mode 100644 tools/archetype/binding/pom.xml create mode 100644 tools/archetype/binding/src/main/resources/META-INF/archetype-post-generate.groovy create mode 100644 tools/archetype/binding/src/main/resources/META-INF/maven/archetype-metadata.xml create mode 100644 tools/archetype/binding/src/main/resources/archetype-resources/.classpath create mode 100644 tools/archetype/binding/src/main/resources/archetype-resources/.project create mode 100644 tools/archetype/binding/src/main/resources/archetype-resources/NOTICE create mode 100644 tools/archetype/binding/src/main/resources/archetype-resources/README.md create mode 100644 tools/archetype/binding/src/main/resources/archetype-resources/pom.xml create mode 100644 tools/archetype/binding/src/main/resources/archetype-resources/src/main/java/internal/__bindingIdCamelCase__BindingConstants.java create mode 100644 tools/archetype/binding/src/main/resources/archetype-resources/src/main/java/internal/__bindingIdCamelCase__Configuration.java create mode 100644 tools/archetype/binding/src/main/resources/archetype-resources/src/main/java/internal/__bindingIdCamelCase__Handler.java create mode 100644 tools/archetype/binding/src/main/resources/archetype-resources/src/main/java/internal/__bindingIdCamelCase__HandlerFactory.java create mode 100644 tools/archetype/binding/src/main/resources/archetype-resources/src/main/resources/ESH-INF/binding/binding.xml create mode 100644 tools/archetype/binding/src/main/resources/archetype-resources/src/main/resources/ESH-INF/i18n/__bindingId___xx_XX.properties create mode 100644 tools/archetype/binding/src/main/resources/archetype-resources/src/main/resources/ESH-INF/thing/thing-types.xml create mode 100644 tools/archetype/pom.xml create mode 100644 tools/pom.xml diff --git a/pom.xml b/pom.xml index 136fdb585..15919a675 100644 --- a/pom.xml +++ b/pom.xml @@ -775,7 +775,7 @@ Import-Package: \\ demo bundles features - + tools diff --git a/tools/archetype/binding/.project b/tools/archetype/binding/.project new file mode 100644 index 000000000..09c556ff6 --- /dev/null +++ b/tools/archetype/binding/.project @@ -0,0 +1,17 @@ + + + org.openhab.archetype.binding + + + + + + org.eclipse.m2e.core.maven2Builder + + + + + + org.eclipse.m2e.core.maven2Nature + + diff --git a/tools/archetype/binding/pom.xml b/tools/archetype/binding/pom.xml new file mode 100644 index 000000000..21870d4d6 --- /dev/null +++ b/tools/archetype/binding/pom.xml @@ -0,0 +1,59 @@ + + + 4.0.0 + + + org.openhab.core + org.openhab.core.tools.archetypes + 2.5.0-SNAPSHOT + + + org.openhab.core.tools.archetypes.binding + maven-archetype + + openHAB Core :: Tools :: Archetypes :: Binding + This is the Maven-Archetype for building new bindings for openHAB. + + + + + true + src/main/resources + + archetype-resources/pom.xml + + + + false + src/main/resources + + archetype-resources/pom.xml + + + + + + + org.apache.maven.plugins + maven-archetype-plugin + 3.0.1 + + + org.apache.maven.plugins + maven-resources-plugin + 3.1.0 + + @ + + + + + + + org.apache.maven.archetype + archetype-packaging + 3.0.1 + + + + diff --git a/tools/archetype/binding/src/main/resources/META-INF/archetype-post-generate.groovy b/tools/archetype/binding/src/main/resources/META-INF/archetype-post-generate.groovy new file mode 100644 index 000000000..852988cb7 --- /dev/null +++ b/tools/archetype/binding/src/main/resources/META-INF/archetype-post-generate.groovy @@ -0,0 +1,157 @@ +/** + * Copyright (c) 2010-2019 Contributors to the openHAB project + * + * See the NOTICE file(s) distributed with this work for additional + * information. + * + * This program and the accompanying materials are made available under the + * terms of the Eclipse Public License 2.0 which is available at + * http://www.eclipse.org/legal/epl-2.0 + * + * SPDX-License-Identifier: EPL-2.0 + */ + +nl = System.getProperty("line.separator") +bundleName = request.getProperties().get('bindingIdCamelCase') +githubUser = request.getProperties().get('githubUser') +outputDirectory = new File(request.getOutputDirectory()) + +/** + * Find which bundle the new binding should be added + */ +def String findAfterBundle(newBundle, codeownersFile) { + def codeowners = codeownersFile.getText('UTF-8') + '/bundles/' + newBundle + def lines = codeowners.split('\n').sort() + def lastIndex + + lines.eachWithIndex { line, index -> + if (line.contains(newBundle)) { + lastIndex = index-1 + } + } + return lines[lastIndex].replaceAll(/\/bundles\/([^\/]+)\/.+/, '$1') +} + +/** + * Add the new bundle to the CODEWONERS file + */ +def addUserToCodewoners(githubUser, codeownersFile, bundleAfter, newBundle) { + def newContent = '' + def lines = codeownersFile.eachLine { line, index -> + newContent += line + nl + if (line.contains(bundleAfter)) { + newContent += '/bundles/' + newBundle + '/ @' + githubUser + nl + } + } + codeownersFile.write(newContent) + println 'Added github user to CODEOWNERS file' +} + +/** + * Add the new bundle to the addons bom pom.xml + */ +def addBundleToBom(bundleAfter, newBundle) { + def bomDependency = +''' + org.openhab.addons.bundles + ### + ${project.version} + +'''.replace('###', newBundle) + def bomFile = new File(outputDirectory, '../bom/openhab-addons/pom.xml') + def newContent = '' + def insertIndex = 0; + def lines = bomFile.eachLine { line, index -> + newContent += line + nl + if (line.contains(bundleAfter)) { + insertIndex = index + 2 + } + if (insertIndex > 0 && index == insertIndex) { + newContent += bomDependency + insertIndex = 0 + } + } + bomFile.write(newContent) + println 'Added bundle to bom pom' +} + +/** + * Add the new bundle to the feature.xml + */ +def addBundleToFeature(bundleAfter, newBundle, bundleName) { + def feature = ''' + + openhab-runtime-base + mvn:org.openhab.addons.bundles/##3/${project.version} + +'''.replace('##1', newBundle.replace('org.', '').replace('.', '-')).replace('##2', bundleName).replace('##3', newBundle) + def bomFile = new File(outputDirectory, '../features/karaf/openhab-addons/src/main/feature/feature.xml') + def newContent = '' + def insertIndex = 0; + def lines = bomFile.eachLine { line, index -> + newContent += line + nl + if (line.contains(bundleAfter) && line.contains(' 0 && index == insertIndex) { + newContent += feature + insertIndex = 0 + } + } + bomFile.write(newContent) + println 'Added bundle to feature.xml' +} + +// +/** + * Fix the bundle parent pom. The maven archytype adds the bundle, but add the end of the module list. + * It also modifies the first and last line + */ +def fixBundlePom(bundleAfter, newBundle) { + def bomFile = new File(outputDirectory, 'pom.xml') + def module = ' ' + newBundle + '' + def newContent = '' + def insertIndex = 0; + def lines = bomFile.eachLine { line, index -> + if (!line.contains(module)) { + // filter out the already added module by the achetype + newContent += line + nl + } + if (line.contains(bundleAfter)) { + insertIndex = index + } + if (insertIndex > 0 && index == insertIndex) { + newContent += module + nl + insertIndex = 0 + } + } + bomFile.write(newContent) + println 'Fix bundle parent pom.xml' +} + +//-------------------------------------------------------------------------- +// Main +def newBundle = request.getPackage() +def codeownersFile = new File(outputDirectory, '../CODEOWNERS') + +if (codeownersFile.exists()) { + def bundleAfter = findAfterBundle(newBundle, codeownersFile) + println 'Add new bundle after: ' + bundleAfter + addUserToCodewoners(githubUser, codeownersFile, bundleAfter, newBundle) + addBundleToBom(bundleAfter, newBundle) + addBundleToFeature(bundleAfter, newBundle, bundleName) + fixBundlePom(bundleAfter, newBundle) + + println '' + println '*********************************************' + println '' + println ' Start your new binding on a new git branch:' + println '' + println ' git checkout -b ' + bundleName.toLowerCase() + println '' + println '*********************************************' + println '' +} else { + println 'Could not find the CODEOWNERS files to perform additional annotations: ' + codeownersFile +} + diff --git a/tools/archetype/binding/src/main/resources/META-INF/maven/archetype-metadata.xml b/tools/archetype/binding/src/main/resources/META-INF/maven/archetype-metadata.xml new file mode 100644 index 000000000..bbee5f973 --- /dev/null +++ b/tools/archetype/binding/src/main/resources/META-INF/maven/archetype-metadata.xml @@ -0,0 +1,51 @@ + + + + + openHAB + + + org.openhab + + + + + + + + + + + 2010 + + + + + + + + NOTICE + pom.xml + .project + .classpath + README.md + + + + src/main/resources/ESH-INF + + **/*.* + + + + + src/main/java + + **/*.java + + + + diff --git a/tools/archetype/binding/src/main/resources/archetype-resources/.classpath b/tools/archetype/binding/src/main/resources/archetype-resources/.classpath new file mode 100644 index 000000000..5616244f3 --- /dev/null +++ b/tools/archetype/binding/src/main/resources/archetype-resources/.classpath @@ -0,0 +1,32 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/tools/archetype/binding/src/main/resources/archetype-resources/.project b/tools/archetype/binding/src/main/resources/archetype-resources/.project new file mode 100644 index 000000000..d20cb7385 --- /dev/null +++ b/tools/archetype/binding/src/main/resources/archetype-resources/.project @@ -0,0 +1,23 @@ + + + ${artifactId} + + + + + + org.eclipse.jdt.core.javabuilder + + + + + org.eclipse.m2e.core.maven2Builder + + + + + + org.eclipse.jdt.core.javanature + org.eclipse.m2e.core.maven2Nature + + diff --git a/tools/archetype/binding/src/main/resources/archetype-resources/NOTICE b/tools/archetype/binding/src/main/resources/archetype-resources/NOTICE new file mode 100644 index 000000000..4ce688fce --- /dev/null +++ b/tools/archetype/binding/src/main/resources/archetype-resources/NOTICE @@ -0,0 +1,13 @@ +This content is produced and maintained by the openHAB project. + +* Project home: https://www.openhab.org + +== Declared Project Licenses + +This program and the accompanying materials are made available under the terms +of the Eclipse Public License 2.0 which is available at +https://www.eclipse.org/legal/epl-2.0/. + +== Source Code + +https://github.com/openhab/openhab-core diff --git a/tools/archetype/binding/src/main/resources/archetype-resources/README.md b/tools/archetype/binding/src/main/resources/archetype-resources/README.md new file mode 100644 index 000000000..2c48f1ff3 --- /dev/null +++ b/tools/archetype/binding/src/main/resources/archetype-resources/README.md @@ -0,0 +1,56 @@ +# ${bindingIdCamelCase} Binding + +_Give some details about what this binding is meant for - a protocol, system, specific device._ + +_If possible, provide some resources like pictures, a YouTube video, etc. to give an impression of what can be done with this binding. You can place such resources into a `doc` folder next to this README.md._ + +#[[##]]# Supported Things + +_Please describe the different supported things / devices within this section._ +_Which different types are supported, which models were tested etc.?_ +_Note that it is planned to generate some part of this based on the XML files within ```src/main/resources/ESH-INF/thing``` of your binding._ + +#[[##]]# Discovery + +_Describe the available auto-discovery features here. Mention for what it works and what needs to be kept in mind when using it._ + +#[[##]]# Binding Configuration + +_If your binding requires or supports general configuration settings, please create a folder ```cfg``` and place the configuration file ```.cfg``` inside it. In this section, you should link to this file and provide some information about the options. The file could e.g. look like:_ + +``` +# Configuration for the Philips Hue Binding +# +# Default secret key for the pairing of the Philips Hue Bridge. +# It has to be between 10-40 (alphanumeric) characters +# This may be changed by the user for security reasons. +secret=openHABSecret +``` + +_Note that it is planned to generate some part of this based on the information that is available within ```src/main/resources/ESH-INF/binding``` of your binding._ + +_If your binding does not offer any generic configurations, you can remove this section completely._ + +#[[##]]# Thing Configuration + +_Describe what is needed to manually configure a thing, either through the (Paper) UI or via a thing-file. This should be mainly about its mandatory and optional configuration parameters. A short example entry for a thing file can help!_ + +_Note that it is planned to generate some part of this based on the XML files within ```src/main/resources/ESH-INF/thing``` of your binding._ + +#[[##]]# Channels + +_Here you should provide information about available channel types, what their meaning is and how they can be used._ + +_Note that it is planned to generate some part of this based on the XML files within ```src/main/resources/ESH-INF/thing``` of your binding._ + +| channel | type | description | +|----------|--------|------------------------------| +| control | Switch | This is the control channel | + +#[[##]]# Full Example + +_Provide a full usage example based on textual configuration files (*.things, *.items, *.sitemap)._ + +#[[##]]# Any custom content here! + +_Feel free to add additional sections for whatever you think should also be mentioned about your binding!_ diff --git a/tools/archetype/binding/src/main/resources/archetype-resources/pom.xml b/tools/archetype/binding/src/main/resources/archetype-resources/pom.xml new file mode 100644 index 000000000..4dae33db3 --- /dev/null +++ b/tools/archetype/binding/src/main/resources/archetype-resources/pom.xml @@ -0,0 +1,16 @@ + + + + 4.0.0 + + + org.openhab.addons.bundles + org.openhab.addons.reactor.bundles + @${version} + + + ${rootArtifactId} + + openHAB Add-ons :: Bundles :: ${bindingIdCamelCase} Binding + + diff --git a/tools/archetype/binding/src/main/resources/archetype-resources/src/main/java/internal/__bindingIdCamelCase__BindingConstants.java b/tools/archetype/binding/src/main/resources/archetype-resources/src/main/java/internal/__bindingIdCamelCase__BindingConstants.java new file mode 100644 index 000000000..b06865065 --- /dev/null +++ b/tools/archetype/binding/src/main/resources/archetype-resources/src/main/java/internal/__bindingIdCamelCase__BindingConstants.java @@ -0,0 +1,37 @@ +#set( $dt = $package.getClass().forName("java.util.Date").newInstance() ) +#set( $year = $dt.getYear() + 1900 ) +#set( $copyright = "Contributors to the ${vendorName} project" ) +/** + * Copyright (c) ${startYear},${year} ${copyright} + * + * See the NOTICE file(s) distributed with this work for additional + * information regarding copyright ownership. + * + * This program and the accompanying materials are made available under the + * terms of the Eclipse Public License 2.0 which is available at + * http://www.eclipse.org/legal/epl-2.0 + * + * SPDX-License-Identifier: EPL-2.0 + */ +package ${package}.internal; + +import org.eclipse.jdt.annotation.NonNullByDefault; +import org.eclipse.smarthome.core.thing.ThingTypeUID; + +/** + * The {@link ${bindingIdCamelCase}BindingConstants} class defines common constants, which are + * used across the whole binding. + * + * @author ${author} - Initial contribution + */ +@NonNullByDefault +public class ${bindingIdCamelCase}BindingConstants { + + private static final String BINDING_ID = "${bindingId}"; + + // List of all Thing Type UIDs + public static final ThingTypeUID THING_TYPE_SAMPLE = new ThingTypeUID(BINDING_ID, "sample"); + + // List of all Channel ids + public static final String CHANNEL_1 = "channel1"; +} diff --git a/tools/archetype/binding/src/main/resources/archetype-resources/src/main/java/internal/__bindingIdCamelCase__Configuration.java b/tools/archetype/binding/src/main/resources/archetype-resources/src/main/java/internal/__bindingIdCamelCase__Configuration.java new file mode 100644 index 000000000..a6940c70d --- /dev/null +++ b/tools/archetype/binding/src/main/resources/archetype-resources/src/main/java/internal/__bindingIdCamelCase__Configuration.java @@ -0,0 +1,29 @@ +#set( $dt = $package.getClass().forName("java.util.Date").newInstance() ) +#set( $year = $dt.getYear() + 1900 ) +#set( $copyright = "Contributors to the ${vendorName} project" ) +/** + * Copyright (c) ${startYear},${year} ${copyright} + * + * See the NOTICE file(s) distributed with this work for additional + * information regarding copyright ownership. + * + * This program and the accompanying materials are made available under the + * terms of the Eclipse Public License 2.0 which is available at + * http://www.eclipse.org/legal/epl-2.0 + * + * SPDX-License-Identifier: EPL-2.0 + */ +package ${package}.internal; + +/** + * The {@link ${bindingIdCamelCase}Configuration} class contains fields mapping thing configuration parameters. + * + * @author ${author} - Initial contribution + */ +public class ${bindingIdCamelCase}Configuration { + + /** + * Sample configuration parameter. Replace with your own. + */ + public String config1; +} diff --git a/tools/archetype/binding/src/main/resources/archetype-resources/src/main/java/internal/__bindingIdCamelCase__Handler.java b/tools/archetype/binding/src/main/resources/archetype-resources/src/main/java/internal/__bindingIdCamelCase__Handler.java new file mode 100644 index 000000000..bdf6041ad --- /dev/null +++ b/tools/archetype/binding/src/main/resources/archetype-resources/src/main/java/internal/__bindingIdCamelCase__Handler.java @@ -0,0 +1,103 @@ +#set( $dt = $package.getClass().forName("java.util.Date").newInstance() ) +#set( $year = $dt.getYear() + 1900 ) +#set( $copyright = "Contributors to the ${vendorName} project" ) +/** + * Copyright (c) ${startYear},${year} ${copyright} + * + * See the NOTICE file(s) distributed with this work for additional + * information regarding copyright ownership. + * + * This program and the accompanying materials are made available under the + * terms of the Eclipse Public License 2.0 which is available at + * http://www.eclipse.org/legal/epl-2.0 + * + * SPDX-License-Identifier: EPL-2.0 + */ +package ${package}.internal; + +import static ${package}.internal.${bindingIdCamelCase}BindingConstants.*; + +import org.eclipse.jdt.annotation.NonNullByDefault; +import org.eclipse.jdt.annotation.Nullable; +import ${package}.internal.${bindingIdCamelCase}Configuration; +import org.eclipse.smarthome.core.thing.ChannelUID; +import org.eclipse.smarthome.core.thing.Thing; +import org.eclipse.smarthome.core.thing.ThingStatus; +import org.eclipse.smarthome.core.thing.binding.BaseThingHandler; +import org.eclipse.smarthome.core.types.Command; +import org.eclipse.smarthome.core.types.RefreshType; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + +/** + * The {@link ${bindingIdCamelCase}Handler} is responsible for handling commands, which are + * sent to one of the channels. + * + * @author ${author} - Initial contribution + */ +@NonNullByDefault +public class ${bindingIdCamelCase}Handler extends BaseThingHandler { + + private final Logger logger = LoggerFactory.getLogger(${bindingIdCamelCase}Handler.class); + + @Nullable + private ${bindingIdCamelCase}Configuration config; + + public ${bindingIdCamelCase}Handler(Thing thing) { + super(thing); + } + + @Override + public void handleCommand(ChannelUID channelUID, Command command) { + if (CHANNEL_1.equals(channelUID.getId())) { + if (command instanceof RefreshType) { + // TODO: handle data refresh + } + + // TODO: handle command + + // Note: if communication with thing fails for some reason, + // indicate that by setting the status with detail information: + // updateStatus(ThingStatus.OFFLINE, ThingStatusDetail.COMMUNICATION_ERROR, + // "Could not control device at IP address x.x.x.x"); + } + } + + @Override + public void initialize() { + // logger.debug("Start initializing!"); + config = getConfigAs(${bindingIdCamelCase}Configuration.class); + + // TODO: Initialize the handler. + // The framework requires you to return from this method quickly. Also, before leaving this method a thing + // status from one of ONLINE, OFFLINE or UNKNOWN must be set. This might already be the real thing status in + // case you can decide it directly. + // In case you can not decide the thing status directly (e.g. for long running connection handshake using WAN + // access or similar) you should set status UNKNOWN here and then decide the real status asynchronously in the + // background. + + // set the thing status to UNKNOWN temporarily and let the background task decide for the real status. + // the framework is then able to reuse the resources from the thing handler initialization. + // we set this upfront to reliably check status updates in unit tests. + updateStatus(ThingStatus.UNKNOWN); + + // Example for background initialization: + scheduler.execute(() -> { + boolean thingReachable = true; // + // when done do: + if (thingReachable) { + updateStatus(ThingStatus.ONLINE); + } else { + updateStatus(ThingStatus.OFFLINE); + } + }); + + // logger.debug("Finished initializing!"); + + // Note: When initialization can NOT be done set the status with more details for further + // analysis. See also class ThingStatusDetail for all available status details. + // Add a description to give user information to understand why thing does not work as expected. E.g. + // updateStatus(ThingStatus.OFFLINE, ThingStatusDetail.CONFIGURATION_ERROR, + // "Can not access device as username and/or password are invalid"); + } +} diff --git a/tools/archetype/binding/src/main/resources/archetype-resources/src/main/java/internal/__bindingIdCamelCase__HandlerFactory.java b/tools/archetype/binding/src/main/resources/archetype-resources/src/main/java/internal/__bindingIdCamelCase__HandlerFactory.java new file mode 100644 index 000000000..7dfae042a --- /dev/null +++ b/tools/archetype/binding/src/main/resources/archetype-resources/src/main/java/internal/__bindingIdCamelCase__HandlerFactory.java @@ -0,0 +1,60 @@ +#set( $dt = $package.getClass().forName("java.util.Date").newInstance() ) +#set( $year = $dt.getYear() + 1900 ) +#set( $copyright = "Contributors to the ${vendorName} project" ) +/** + * Copyright (c) ${startYear},${year} ${copyright} + * + * See the NOTICE file(s) distributed with this work for additional + * information regarding copyright ownership. + * + * This program and the accompanying materials are made available under the + * terms of the Eclipse Public License 2.0 which is available at + * http://www.eclipse.org/legal/epl-2.0 + * + * SPDX-License-Identifier: EPL-2.0 + */ +package ${package}.internal; + +import static ${package}.internal.${bindingIdCamelCase}BindingConstants.*; + +import java.util.Collections; +import java.util.Set; + +import org.eclipse.jdt.annotation.NonNullByDefault; +import org.eclipse.jdt.annotation.Nullable; +import ${package}.internal.${bindingIdCamelCase}Handler; +import org.eclipse.smarthome.core.thing.Thing; +import org.eclipse.smarthome.core.thing.ThingTypeUID; +import org.eclipse.smarthome.core.thing.binding.BaseThingHandlerFactory; +import org.eclipse.smarthome.core.thing.binding.ThingHandler; +import org.eclipse.smarthome.core.thing.binding.ThingHandlerFactory; +import org.osgi.service.component.annotations.Component; + +/** + * The {@link ${bindingIdCamelCase}HandlerFactory} is responsible for creating things and thing + * handlers. + * + * @author ${author} - Initial contribution + */ +@NonNullByDefault +@Component(configurationPid = "binding.${bindingId}", service = ThingHandlerFactory.class) +public class ${bindingIdCamelCase}HandlerFactory extends BaseThingHandlerFactory { + + private static final Set SUPPORTED_THING_TYPES_UIDS = Collections.singleton(THING_TYPE_SAMPLE); + + @Override + public boolean supportsThingType(ThingTypeUID thingTypeUID) { + return SUPPORTED_THING_TYPES_UIDS.contains(thingTypeUID); + } + + @Override + protected @Nullable ThingHandler createHandler(Thing thing) { + ThingTypeUID thingTypeUID = thing.getThingTypeUID(); + + if (THING_TYPE_SAMPLE.equals(thingTypeUID)) { + return new ${bindingIdCamelCase}Handler(thing); + } + + return null; + } +} diff --git a/tools/archetype/binding/src/main/resources/archetype-resources/src/main/resources/ESH-INF/binding/binding.xml b/tools/archetype/binding/src/main/resources/archetype-resources/src/main/resources/ESH-INF/binding/binding.xml new file mode 100644 index 000000000..6c156887a --- /dev/null +++ b/tools/archetype/binding/src/main/resources/archetype-resources/src/main/resources/ESH-INF/binding/binding.xml @@ -0,0 +1,10 @@ + + + + ${bindingIdCamelCase} Binding + This is the binding for ${bindingIdCamelCase}. + ${author} + + diff --git a/tools/archetype/binding/src/main/resources/archetype-resources/src/main/resources/ESH-INF/i18n/__bindingId___xx_XX.properties b/tools/archetype/binding/src/main/resources/archetype-resources/src/main/resources/ESH-INF/i18n/__bindingId___xx_XX.properties new file mode 100644 index 000000000..8c52d22a2 --- /dev/null +++ b/tools/archetype/binding/src/main/resources/archetype-resources/src/main/resources/ESH-INF/i18n/__bindingId___xx_XX.properties @@ -0,0 +1,13 @@ +# FIXME: please substitute the xx_XX with a proper locale, ie. de_DE +# FIXME: please do not add the file to the repo if you add or change no content +# binding +binding.${bindingId}.name = +binding.${bindingId}.description = + +# thing types +thing-type.${bindingId}.sample.label = +thing-type.${bindingId}.sample.description = + +# channel types +channel-type.${bindingId}.sample-channel.label = +channel-type.${bindingId}.sample-channel.description = diff --git a/tools/archetype/binding/src/main/resources/archetype-resources/src/main/resources/ESH-INF/thing/thing-types.xml b/tools/archetype/binding/src/main/resources/archetype-resources/src/main/resources/ESH-INF/thing/thing-types.xml new file mode 100644 index 000000000..9c590f48c --- /dev/null +++ b/tools/archetype/binding/src/main/resources/archetype-resources/src/main/resources/ESH-INF/thing/thing-types.xml @@ -0,0 +1,32 @@ + + + + + + + Sample thing for ${bindingIdCamelCase} Binding + + + + + + + + + This is a sample text configuration parameter. + + + + + + + + ${bindingId}Item + + Sample channel for ${bindingIdCamelCase} Binding + + + diff --git a/tools/archetype/pom.xml b/tools/archetype/pom.xml new file mode 100644 index 000000000..117a3e5af --- /dev/null +++ b/tools/archetype/pom.xml @@ -0,0 +1,45 @@ + + + + 4.0.0 + + + org.openhab.core + org.openhab.core.tools + 2.5.0-SNAPSHOT + + + org.openhab.core.tools.archetypes + pom + + openHAB Core :: Tools :: Archetypes + + + binding + + + + + + com.mycila + license-maven-plugin + + true + + + + + org.openhab.tools.sat + sat-plugin + + + sat-all + none + + + + + + + + diff --git a/tools/pom.xml b/tools/pom.xml new file mode 100644 index 000000000..0c4412853 --- /dev/null +++ b/tools/pom.xml @@ -0,0 +1,21 @@ + + + + 4.0.0 + + + org.openhab.core + org.openhab.core.reactor + 2.5.0-SNAPSHOT + + + org.openhab.core.tools + pom + + openHAB Core :: Tools + + + archetype + + +