diff --git a/.github/workflows/actions/app-build/Set-Version.ps1 b/.github/workflows/actions/app-build/Set-Version.ps1
index d72409e2..c3a8f4af 100644
--- a/.github/workflows/actions/app-build/Set-Version.ps1
+++ b/.github/workflows/actions/app-build/Set-Version.ps1
@@ -1,3 +1,17 @@
+<#
+.Synopsis
+ Sets the assembly version of all assemblies in the source directory.
+.DESCRIPTION
+ A build script that can be included in TFS 2015 or Visual Studio Online (VSO) vNevt builds that update the version of all assemblies in a workspace.
+ It uses the name of the build to extract the version number and updates all AssemblyInfo.cs files to use the new version.
+.EXAMPLE
+ Set-AssemblyVersion
+.EXAMPLE
+ Set-AssemblyVersion -SourceDirectory $Env:BUILD_SOURCESDIRECTORY -BuildNumber $Env:BUILD_BUILDNUMBER
+.EXAMPLE
+ Set-AssemblyVersion -SourceDirectory ".\SourceDir" -BuildNumber "Dev_1.0.20150922.01" -VersionFormat "\d+\.\d+\.\d+\.\d+"
+#>
+
[CmdletBinding(SupportsShouldProcess=$true, ConfirmImpact='Medium')]
[Alias()]
[OutputType([int])]
@@ -32,6 +46,19 @@ Param
[string]$VersionFormat = "\d+\.\d+\.\d+\.\d+"
)
+<#
+.Synopsis
+ Sets the assembly version of all assemblies in the source directory.
+.DESCRIPTION
+ A build script that can be included in TFS 2015 or Visual Studio Online (VSO) vNevt builds that update the version of all assemblies in a workspace.
+ It uses the name of the build to extract the version number and updates all AssemblyInfo.cs files to use the new version.
+.EXAMPLE
+ Set-AssemblyVersion
+.EXAMPLE
+ Set-AssemblyVersion -SourceDirectory $Env:BUILD_SOURCESDIRECTORY -BuildNumber $Env:BUILD_BUILDNUMBER
+.EXAMPLE
+ Set-AssemblyVersion -SourceDirectory ".\SourceDir" -BuildNumber "Dev_1.0.20150922.01" -VersionFormat "\d+\.\d+\.\d+\.\d+"
+#>
function Set-AssemblyVersion
{
[CmdletBinding(SupportsShouldProcess=$true, ConfirmImpact='Medium')]
@@ -92,12 +119,18 @@ function Set-AssemblyVersion
}
Write-Host "Update BUILD_BUILDNUMBER to $($UpdatedVersion.ToString())"
- Write-Host "BUILD_NUMBER=$($UpdatedVersion.ToString())" >> $GITHUB_ENV
+ echo "BUILD_NUMBER=$($UpdatedVersion.ToString())" >> $GITHUB_ENV
- if($SetVersion.IsPresent){
+ if(-not $SetVersion.IsPresent){
+ Write-Host "Not able to parse version number."
+ return
+ }
+
+ if($files -and $files.Length -lt 0){
Set-FileContent -Files $files -Version $UpdatedVersion -VersionFormat $VersionFormat
- Set-AppManifest -Files $appFiles -Version $UpdatedVersion
- }
+ }
+
+ Set-AppManifest -Files $appFiles -Version $UpdatedVersion
}
function Create-NewVersionNumber{
diff --git a/.github/workflows/actions/app-build/action.yml b/.github/workflows/actions/app-build/action.yml
index 409c3704..7ca73cb5 100644
--- a/.github/workflows/actions/app-build/action.yml
+++ b/.github/workflows/actions/app-build/action.yml
@@ -52,4 +52,4 @@ runs:
SONAR_TOKEN: ${{inputs.SONAR_TOKEN}}
run: |
Write-Host "==== Build app package ====" -ForegroundColor Green
- msbuild.exe ${{github.workspace}}\repo\OpenHAB.Windows.sln /p:Platform="x86" /p:AppxBundlePlatforms="${{inputs. bundle_Platforms}}" /p:AppxPackageDir="${{inputs.output_directory}}" /p:AppxBundle=Always /p:UapAppxPackageBuildMode=StoreUpload /p:configuration="${{inputs.build_configuration}}" /t:rebuild
\ No newline at end of file
+ msbuild.exe ${{github.workspace}}\repo\OpenHAB.Windows.sln /p:Platform="x86" /p:AppxBundlePlatforms="${{inputs.bundle_Platforms}}" /p:AppxPackageDir="${{inputs.output_directory}}" /p:AppxBundle=Always /p:UapAppxPackageBuildMode=StoreUpload /p:configuration="${{inputs.build_configuration}}" /t:rebuild
\ No newline at end of file
diff --git a/.github/workflows/app-release.yml b/.github/workflows/app-release.yml
deleted file mode 100644
index ea244077..00000000
--- a/.github/workflows/app-release.yml
+++ /dev/null
@@ -1,97 +0,0 @@
-name: App Release
-
-env:
- BUILD_NUMBER: '1970.1.1'
- BuildDirectory: '${{github.workspace}}\build'
- ReleaseName: 'N/A'
- IsBetaRelease: ${{ contains(github.event.inputs.BetaRelease, 'true') }}
-
-on:
- workflow_dispatch:
- inputs:
- BetaRelease:
- description: 'Specifices if a beta release should be created.'
- default: 'false'
- required: false
- BuildConfiguration:
- description: 'Specifices if a release or debug package should be created.'
- default: 'release'
- required: false
-
-jobs:
- build:
- name: 'Build openHAB Windows App'
- runs-on: windows-latest
-
- steps:
- - name: Checkout main code
- uses: actions/checkout@v2
- with:
- path: repo
- clean: true
-
- - name: Setup NuGet.exe for use with actions
- uses: NuGet/setup-nuget@v1.0.5
- with:
- nuget-version: 'latest'
-
- - name: setup-msbuild
- uses: microsoft/setup-msbuild@v1
-
- - name: Build App
- id: create_app_package
- uses: ./repo/.github/workflows/actions/app-build
- with:
- build_configuration: ${{github.event.inputs.BuildConfiguration}}
- output_directory: '${{env.BuildDirectory}}'
-
- - name: Upload build assets
- id: app_package_upload
- uses: actions/upload-artifact@v2.2.2
- with:
- name: app
- path: '${{env.BuildDirectory}}'
-
- release:
- name: 'Creates an app release'
- runs-on: ubuntu-latest
- needs: build
- if: github.ref == 'refs/heads/main' || github.ref == 'refs/heads/releases/beta'
- steps:
- - name: Set build number and release name
- id: set-buildnumbe
- run: |
- CURRENTDATE=`date +"%Y.%m.%d"`
- echo "BUILD_NUMBER=${CURRENTDATE}.${{github.run_number}}" >> $GITHUB_ENV
-
- IS_BETA_RELEASE= ${{ env.IsBetaRelease }}
- if[$IS_BETA_RELEASE]; then
- echo "ReleaseName=Beta:${CURRENTDATE}.${{github.run_number}}" >> $GITHUB_ENV
- else:
- echo "ReleaseName=${CURRENTDATE}.${{github.run_number}}" >> $GITHUB_ENV
- fi
-
- - name: Create a Release
- id: create_release
- uses: actions/create-release@v1.1.4
- env:
- GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- with:
- tag_name: ${{env.BUILD_NUMBER}}
- release_name: ${{env.ReleaseName}}
-
- - name: Download a App Package from Build Artifacts
- uses: actions/download-artifact@v2.0.8
- with:
- name: app
- path: '${{env.BuildDirectory}}'
-
- - name: Upload Release App Package
- id: upload-release-package
- uses: actions/upload-release-asset@v1.0.2
- env:
- GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- with:
- upload_url: ${{steps.create_release.outputs.upload_url}}
- asset_path: '${{env.BuildDirectory}}'
- asset_name: OpenHab UWP App
diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml
new file mode 100644
index 00000000..58960bf2
--- /dev/null
+++ b/.github/workflows/build.yml
@@ -0,0 +1,125 @@
+name: 'Build App Package'
+
+on:
+ workflow_call:
+ inputs:
+ build_configuration:
+ description: 'The build configuration to use'
+ type: string
+ required: true
+ default: 'Release'
+ bundle_Platforms:
+ type: string
+ description: 'Defines the platforms for the app package.'
+ required: false
+ default: ' x86|x64|arm64'
+ build_number:
+ type: string
+ description: 'The build number to use'
+ required: true
+
+jobs:
+ build:
+ name: 'Build App Package'
+ runs-on: windows-latest
+ env:
+ output_directory: ${{github.workspace}}\build
+ steps:
+ - name: Checkout main code
+ uses: actions/checkout@v2
+ with:
+ path: repo
+ clean: true
+
+ - name: Update Version Number in app files
+ id: update-packageverion
+ shell: pwsh
+ run: |
+ $version = [System.Version]::Parse('${{inputs.build_number}}')
+ ${{github.workspace}}\repo\.github\workflows\scripts\Set-Version.ps1 -SourceDirectory '${{github.workspace}}/repo/src/' -Major $version.Major -Minor $version.Minor -Build $version.Build -Revision 0 -SetVersion
+
+ - name: Setup NuGet.exe for use with actions
+ uses: NuGet/setup-nuget@v1.0.5
+ with:
+ nuget-version: 'latest'
+
+ - name: setup-msbuild
+ uses: microsoft/setup-msbuild@v2
+
+ - name: Setup dotnet
+ uses: actions/setup-dotnet@v3
+ with:
+ dotnet-version: '8.x.x'
+
+ - name: Set up JDK 17
+ uses: actions/setup-java@v3
+ with:
+ java-version: 17
+ distribution: 'zulu'
+
+ - name: Cache SonarQube Cloud packages
+ uses: actions/cache@v4
+ with:
+ path: ~\sonar\cache
+ key: ${{ runner.os }}-sonar
+ restore-keys: ${{ runner.os }}-sonar
+
+ - name: Cache SonarCloud scanner
+ id: cache-sonar-scanner
+ uses: actions/cache@v3
+ with:
+ path: .\.sonar\scanner
+ key: ${{ runner.os }}-sonar-scanner
+ restore-keys: ${{ runner.os }}-sonar-scanner
+
+ - name: Install SonarQube Cloud scanner
+ if: steps.cache-sonar-scanner.outputs.cache-hit != 'true'
+ shell: powershell
+ run: |
+ New-Item -Path .\.sonar\scanner -ItemType Directory
+ dotnet tool update dotnet-sonarscanner --tool-path .\.sonar\scanner
+
+ - name: Begin SonarQube analyze
+ env:
+ GITHUB_TOKEN: ${{secrets.GITHUB_TOKEN}}
+ SONAR_TOKEN: ${{secrets.SONAR_TOKEN}}
+ shell: pwsh
+ run: |
+ .\.sonar\scanner\dotnet-sonarscanner begin /k:"openhab_openhab-windows" /o:"openhab" /d:sonar.token="${{ secrets.SONAR_TOKEN }}" /d:sonar.host.url="https://sonarcloud.io"
+
+ - name: Restore nuget packages
+ shell: pwsh
+ run: |
+ dotnet restore ${{github.workspace}}\repo\OpenHAB.Windows.sln --force --no-cache
+
+ - name: Build OpenHab Windows App
+ shell: pwsh
+ run: |
+ msbuild.exe ${{github.workspace}}\repo\OpenHAB.Windows.sln `
+ /p:Platform="x86" `
+ /p:AppxBundlePlatforms="${{inputs.bundle_Platforms}}" `
+ /p:AppxPackageDir="${{env.output_directory}}" `
+ /p:AppxBundle=Always `
+ /p:UapAppxPackageBuildMode=StoreUpload `
+ /p:Configuration="${{inputs.build_configuration}}" `
+ /t:Rebuild
+
+ - name: End SonarQube analyze
+ env:
+ GITHUB_TOKEN: ${{secrets.GITHUB_TOKEN}}
+ SONAR_TOKEN: ${{secrets.SONAR_TOKEN}}
+ shell: pwsh
+ run: |
+ .\.sonar\scanner\dotnet-sonarscanner end /d:sonar.token="${{ secrets.SONAR_TOKEN }}"
+
+ - name: List files in output directory
+ shell: pwsh
+ working-directory: ${{env.output_directory}}
+ run: |
+ Get-ChildItem -Path ${{env.output_directory}}
+
+ - name: Upload App Package
+ uses: actions/upload-artifact@v4
+ with:
+ name: app
+ path: ${{env.output_directory}}
diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml
index 2316b11c..cfe5e4ae 100644
--- a/.github/workflows/ci.yml
+++ b/.github/workflows/ci.yml
@@ -1,85 +1,65 @@
-name: 'CI Build'
+name: 'openHAB Build CI Build'
+run-name: app-ci-${{github.run_id }}
env:
- BUILD_NUMBER: '1970.1.1'
BuildDirectory: '${{github.workspace}}\build'
- ACTIONS_RUNNER_DEBUG: true
-on: [push, pull_request]
+on:
+ pull_request:
+ branches:
+ - main
jobs:
- build:
- name: 'Build openHAB Windows App'
- runs-on: windows-latest
-
+ configure:
+ name: Configure Build
+ runs-on: ubuntu-latest
+ outputs:
+ buildConfiguration: ${{ steps.configuration.outputs.BuildConfiguration }}
+ bundlePlatforms: ${{ steps.configuration.outputs.BundlePlatforms }}
+ buildNumber: ${{ steps.buildnumber.outputs.BUILD_NUMBER }}
+ releaseName: ${{ steps.buildnumber.outputs.RELEASE_NAME }}
steps:
- - name: Checkout main code
- uses: actions/checkout@v2
- with:
- path: repo
- clean: true
-
- - name: Setup NuGet.exe for use with actions
- uses: NuGet/setup-nuget@v1.0.5
- with:
- nuget-version: 'latest'
-
- - name: setup-msbuild
- uses: microsoft/setup-msbuild@v1
+ - name: Checkout repository
+ uses: actions/checkout@v2
- - name: Set up JDK 11
- uses: actions/setup-java@v1
- with:
- java-version: 1.11
+ - name: Detect Build Configuration
+ id: configuration
+ shell: pwsh
+ run: |
+ if ($env:github.ref -eq 'refs/heads/main') {
+ Write-Host "Set build configuration to release"
- - name: Cache SonarCloud packages
- uses: actions/cache@v1
- with:
- path: ~\sonar\cache
- key: ${{runner.os}}-sonar
- restore-keys: ${{runner.os}}-sonar
+ Write-Output "BuildConfiguration=release" | Out-File -FilePath $Env:GITHUB_OUTPUT -Encoding utf8 -Append
+ Write-Output "BundlePlatforms=x86|x64|arm64" | Out-File -FilePath $Env:GITHUB_OUTPUT -Encoding utf8 -Append
+ } else {
+ Write-Host "Set build configuration to debug"
- - name: Cache SonarCloud scanner
- id: cache-sonar-scanner
- uses: actions/cache@v1
- with:
- path: .\.sonar\scanner
- key: ${{runner.os}}-sonar-scanner-msbuild
- restore-keys: ${{runner.os}}-sonar-scanner-msbuild
+ Write-Output "BuildConfiguration=debug" | Out-File -FilePath $Env:GITHUB_OUTPUT -Encoding utf8 -Append
+ Write-Output "BundlePlatforms=x86|x64|arm64" | Out-File -FilePath $Env:GITHUB_OUTPUT -Encoding utf8 -Append
+ }
- - name: Install SonarCloud scanner
- if: steps.cache-sonar-scanner.outputs.cache-hit != 'true'
- shell: pwsh
- run: |
- $directory = New-Item -Path .\.sonar\scanner -ItemType Directory
- # dotnet tool update dotnet-sonarscanner --tool-path .\.sonar\scanner
+ - name: Set build number and release name
+ id: buildnumber
+ shell: pwsh
+ run: |
+ $CURRENTDATE = Get-Date -Format "yyyy.MM.dd"
+ Write-Output "BUILD_NUMBER=$CURRENTDATE" | Out-File -FilePath $Env:GITHUB_OUTPUT -Encoding utf8 -Append
- $file = Join-Path $directory.FullName "sonar-scanner.zip"
- Invoke-WebRequest -Uri "https://github.com/SonarSource/sonar-scanner-msbuild/releases/download/5.2.1.31210/sonar-scanner-msbuild-5.2.1.31210-net46.zip" -OutFile $file
- Expand-Archive -LiteralPath $file -DestinationPath "$($directory.FullName)"
+ $IS_BETA_RELEASE = '${{ inputs.IsBetaRelease }}'
+ if ($IS_BETA_RELEASE -eq 'true') {
+ Write-Host "Set release name to Beta:$CURRENTDATE.${{github.run_number}}"
+ Write-Output "RELEASE_NAME=Beta:$CURRENTDATE.${{github.run_number}}" | Out-File -FilePath $Env:GITHUB_OUTPUT -Encoding utf8 -Append
+ } else {
+ Write-Host "Set release name to $CURRENTDATE"
+ Write-Output "RELEASE_NAME=$CURRENTDATE" | Out-File -FilePath $Env:GITHUB_OUTPUT -Encoding utf8 -Append
+ }
- - name: Begin SonarQube analyze
- env:
- GITHUB_TOKEN: ${{secrets.GITHUB_TOKEN}}
- SONAR_TOKEN: ${{secrets.SONAR_TOKE }}
- shell: pwsh
- run: |
- .\.sonar\scanner\SonarScanner.MSBuild.exe begin /k:"openhab_openhab-windows" /o:"openhab" /d:sonar.login="${{secrets.SONAR_TOKEN}}" /d:sonar.host.url="https://sonarcloud.io" /d:sonar.projectBaseDir="${{github.workspace}}/repo/src/" /d:sonar.verbose="true"
-
- - name: Build App
- id: create_app_package
- uses: ./repo/.github/workflows/actions/app-build
- with:
- build_configuration: 'debug'
- output_directory: '${{env.BuildDirectory}}'
- bundle_Platforms: 'x86'
- GITHUB_TOKEN: ${{secrets.GITHUB_TOKEN}}
- SONAR_TOKEN: ${{secrets.SONAR_TOKEN}}
-
- - name: End SonarQube analyze
- env:
- GITHUB_TOKEN: ${{secrets.GITHUB_TOKEN}}
- SONAR_TOKEN: ${{secrets.SONAR_TOKEN}}
- shell: pwsh
- run: |
- .\.sonar\scanner\SonarScanner.MSBuild.exe end /d:sonar.login="${{secrets.SONAR_TOKEN}}"
\ No newline at end of file
+ build:
+ uses: ./.github/workflows/build.yml
+ name: Build
+ needs: configure
+ with:
+ build_configuration: ${{needs.configure.outputs.buildConfiguration}}
+ bundle_Platforms: ${{ needs.configure.outputs.bundlePlatforms}}
+ build_number: ${{ needs.configure.outputs.buildNumber}}
+ secrets: inherit
diff --git a/.github/workflows/openhab.yml b/.github/workflows/openhab.yml
new file mode 100644
index 00000000..f97a1d2b
--- /dev/null
+++ b/.github/workflows/openhab.yml
@@ -0,0 +1,117 @@
+name: "openHAB Build and Release app"
+run-name: run-${{github.head_ref || github.ref_name}}-${{github.run_number}}
+
+env:
+ BuildDirectory: '${{github.workspace}}\build'
+ ACTIONS_RUNNER_DEBUG: true
+
+on:
+ push:
+ branches:
+ - main
+ workflow_dispatch:
+ inputs:
+ BuildConfiguration:
+ description: "Specifies if a release or debug package should be created."
+ type: choice
+ options: ["release", "debug"]
+ default: "release"
+ IsBetaRelease:
+ description: "Create store beta release."
+ type: "boolean"
+ default: false
+ create_release:
+ description: "Create release for non-main branch."
+ type: "boolean"
+ default: false
+ releaseName:
+ description: "The release name to use."
+ type: "string"
+ default: ""
+
+jobs:
+ configure:
+ name: Configure Build
+ runs-on: ubuntu-latest
+ outputs:
+ buildConfiguration: ${{ steps.configuration.outputs.BuildConfiguration }}
+ bundlePlatforms: ${{ steps.configuration.outputs.BundlePlatforms }}
+ buildNumber: ${{ steps.buildnumber.outputs.BUILD_NUMBER }}
+ releaseName: ${{ steps.buildnumber.outputs.RELEASE_NAME }}
+ steps:
+ - name: Checkout repository
+ uses: actions/checkout@v2
+
+ - name: Detect Build Configuration
+ id: configuration
+ shell: pwsh
+ run: |
+ if ($env:github.ref -eq 'refs/heads/main') {
+ Write-Host "Set build configuration to release"
+
+ #Write-Output "BuildConfiguration=release" | Out-File -FilePath $Env:GITHUB_OUTPUT -Encoding utf8 -Append
+ Write-Output "BundlePlatforms=x86|x64|arm64" | Out-File -FilePath $Env:GITHUB_OUTPUT -Encoding utf8 -Append
+ } else {
+ Write-Host "Set build configuration to debug"
+
+ #Write-Output "BuildConfiguration=debug" | Out-File -FilePath $Env:GITHUB_OUTPUT -Encoding utf8 -Append
+ Write-Output "BundlePlatforms=x86|x64|arm64" | Out-File -FilePath $Env:GITHUB_OUTPUT -Encoding utf8 -Append
+ }
+
+ - name: Set build number and release name
+ id: buildnumber
+ shell: pwsh
+ run: |
+ $CURRENTDATE = Get-Date -Format "yyyy.MM.dd"
+ Write-Output "BUILD_NUMBER=$CURRENTDATE" | Out-File -FilePath $Env:GITHUB_OUTPUT -Encoding utf8 -Append
+
+ $IS_BETA_RELEASE = '${{ inputs.IsBetaRelease }}'
+ if ($IS_BETA_RELEASE -eq 'true') {
+ Write-Host "Set release name to Beta:$CURRENTDATE.${{github.run_number}}"
+ Write-Output "RELEASE_NAME=Beta:$CURRENTDATE.${{github.run_number}}" | Out-File -FilePath $Env:GITHUB_OUTPUT -Encoding utf8 -Append
+ } else {
+ Write-Host "Set release name to $CURRENTDATE"
+ Write-Output "RELEASE_NAME=$CURRENTDATE" | Out-File -FilePath $Env:GITHUB_OUTPUT -Encoding utf8 -Append
+ }
+
+ build:
+ uses: ./.github/workflows/build.yml
+ name: Build
+ needs: configure
+ with:
+ build_configuration: ${{ inputs.BuildConfiguration }} #${{needs.configure.outputs.buildConfiguration}}
+ bundle_Platforms: ${{ needs.configure.outputs.bundlePlatforms}}
+ build_number: ${{ needs.configure.outputs.buildNumber}}
+ secrets: inherit
+
+ create_release:
+ name: Create Release
+ uses: ./.github/workflows/release.yml
+ needs:
+ - build
+ - configure
+ with:
+ force_release: ${{ inputs.create_release }}
+ beta_release: ${{ inputs.IsBetaRelease }}
+ build_number: ${{ needs.configure.outputs.buildNumber }}
+ releaseName: ${{ inputs.releaseName }}
+
+ # publish_beta:
+ # uses: ./.github/workflows/publish.yml
+ # needs:
+ # - build
+ # - configure
+ # with:
+ # environment: BETA
+ # package_name: "openHAB.Windows_${{needs.configure.outputs.buildNumber}}_x86_x64_arm_bundle"
+ # secrets: inherit
+
+ # publish_prod:
+ # uses: ./.github/workflows/publish.yml
+ # needs:
+ # - publish_beta
+ # - configure
+ # with:
+ # environment: PROD
+ # package_name: "openHAB.Windows_${{needs.configure.outputs.buildNumber}}_x86_x64_arm_bundle"
+ # secrets: inherit
diff --git a/.github/workflows/publish.yml b/.github/workflows/publish.yml
new file mode 100644
index 00000000..a6407fdc
--- /dev/null
+++ b/.github/workflows/publish.yml
@@ -0,0 +1,46 @@
+name: 'Deploy App Package'
+run-name: 'Deploy App Package: ${{ github.event.inputs.environment }}'
+
+env:
+ BuildDirectory: '${{github.workspace}}\build'
+
+on:
+ workflow_call:
+ inputs:
+ environment:
+ type: string
+ description: 'Defines the environment for the app package'
+ required: true
+ package_name:
+ type: string
+ description: 'The name of the app package'
+ required: true
+ artifact_name:
+ type: string
+ description: 'The name of the artifact to download'
+ default: 'app'
+ artifact_directory:
+ type: string
+ description: 'Defines the output directory for the app package'
+ default: '${{github.workspace}}/packages/'
+
+jobs:
+ deploy:
+ name: 'Deploy App Package to ${{ github.event.inputs.environment }} channel'
+ runs-on: ubuntu-latest
+ environment: ${{ github.event.inputs.environment }}
+ steps:
+ - name: Download a App Package from Build Artifacts
+ uses: actions/download-artifact@v2.0.8
+ with:
+ name: ${{inputs.artifact_name}}
+ path: '${{env.BuildDirectory}}/${{inputs.artifact_directory}}/'
+
+ - uses: isaacrlevin/windows-store-action
+ name: Publish to Store
+ with:
+ tenant-id: ${{ secrets.AZURE_AD_TENANT_ID }}
+ client-id: ${{ secrets.AZURE_AD_APPLICATION_CLIENT_ID }}
+ client-secret: ${{ secrets.AZURE_AD_APPLICATION_SECRET }}
+ app-id: ${{ secrets.STORE_APP_ID }}
+ package-path: "${{ github.workspace }}/${{inputs.artifact_directory}}/${{inputs.package_name}}.msixupload"
diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml
new file mode 100644
index 00000000..ec8e1125
--- /dev/null
+++ b/.github/workflows/release.yml
@@ -0,0 +1,80 @@
+name: App Release
+
+env:
+ BuildDirectory: '${{github.workspace}}/build'
+
+on:
+ workflow_call:
+ inputs:
+ force_release:
+ description: 'Specifies if a release should be created even if the branch is not main.'
+ type: boolean
+ default: false
+ required: false
+ beta_release:
+ description: 'Specifies if a beta release should be created.'
+ type: boolean
+ default: false
+ required: false
+ build_number:
+ type: string
+ description: 'The build number to use'
+ required: true
+ releaseName:
+ type: string
+ description: 'The release name to use'
+ required: true
+
+permissions:
+ id-token: "write"
+ contents: "write"
+ packages: "write"
+ pull-requests: "read"
+
+jobs:
+ release:
+ name: 'App release creation for ${{inputs.build_number}}'
+ runs-on: ubuntu-latest
+ if: github.ref == 'refs/heads/main' || github.ref == 'refs/heads/releases/beta' || inputs.force_release == true
+ steps:
+ - name: Download a App Package from Build Artifacts
+ uses: actions/download-artifact@v4
+ with:
+ name: app
+ path: '${{env.BuildDirectory}}'
+
+ - name: Display structure of downloaded files
+ run: ls -la
+ working-directory: '${{env.BuildDirectory}}'
+
+ - name: Set release name
+ run: |
+ if [ -z "${releaseName}" ]; then
+ echo "No release name provided, using build number"
+ release_name="${{ inputs.build_number }}"
+ else
+ echo "Using provided release name"
+ release_name="${releaseName}"
+ fi
+
+ if [ "${beta_release}" == "true" ]; then
+ echo "Beta release requested"
+ release_name="Beta: ${release_name}"
+ fi
+
+ echo "releaseName=${release_name}" >> $GITHUB_ENV
+ env:
+ releaseName: ${{ inputs.releaseName }}
+ beta_release: ${{ inputs.beta_release }}
+
+ - name: Create a Release
+ id: create_release
+ uses: marvinpinto/action-automatic-releases@latest
+ with:
+ repo_token: "${{ secrets.GITHUB_TOKEN }}"
+ prerelease: ${{inputs.beta_release}}
+ automatic_release_tag: ${{inputs.build_number}}
+ title: ${{env.releaseName}}
+ files: |
+ ${{env.BuildDirectory}}/**/*.msixbundle
+ ${{env.BuildDirectory}}/**/*.msixupload
diff --git a/.github/workflows/scripts/Set-Version.ps1 b/.github/workflows/scripts/Set-Version.ps1
index 08225aff..c3a8f4af 100644
--- a/.github/workflows/scripts/Set-Version.ps1
+++ b/.github/workflows/scripts/Set-Version.ps1
@@ -121,10 +121,16 @@ function Set-AssemblyVersion
Write-Host "Update BUILD_BUILDNUMBER to $($UpdatedVersion.ToString())"
echo "BUILD_NUMBER=$($UpdatedVersion.ToString())" >> $GITHUB_ENV
- if($SetVersion.IsPresent){
+ if(-not $SetVersion.IsPresent){
+ Write-Host "Not able to parse version number."
+ return
+ }
+
+ if($files -and $files.Length -lt 0){
Set-FileContent -Files $files -Version $UpdatedVersion -VersionFormat $VersionFormat
- Set-AppManifest -Files $appFiles -Version $UpdatedVersion
- }
+ }
+
+ Set-AppManifest -Files $appFiles -Version $UpdatedVersion
}
function Create-NewVersionNumber{
diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml
new file mode 100644
index 00000000..a99bcac8
--- /dev/null
+++ b/.pre-commit-config.yaml
@@ -0,0 +1,19 @@
+# See https://pre-commit.com for more information
+# See https://pre-commit.com/hooks.html for more hooks
+default_install_hook_types:
+ - pre-commit
+ - commit-msg
+ - pre-push
+repos:
+ - repo: https://github.com/pre-commit/pre-commit-hooks
+ rev: v5.0.0
+ hooks:
+ - id: trailing-whitespace
+ - id: end-of-file-fixer
+ - id: check-yaml
+ - id: check-added-large-files
+ - repo: https://github.com/openhab/openhab-windows
+ rev: 98df98f04814a30ba4df438744d5f68ebcf5d815
+ hooks:
+ - id: sign-off
+ stages: [commit-msg]
diff --git a/.pre-commit-hooks.yaml b/.pre-commit-hooks.yaml
new file mode 100644
index 00000000..a7f3e6d3
--- /dev/null
+++ b/.pre-commit-hooks.yaml
@@ -0,0 +1,5 @@
+- id: sign-off
+ name: Sign-off commits
+ entry: "pwsh -c 'git interpret-trailers --in-place --trailer \"Signed-off-by: $(git config user.name) <$(git config user.email)>\" .git/COMMIT_EDITMSG'"
+ language: system
+ stages: [commit-msg]
diff --git a/.sonarlint/OpenHAB.Windows.json b/.sonarlint/OpenHAB.Windows.json
new file mode 100644
index 00000000..53391710
--- /dev/null
+++ b/.sonarlint/OpenHAB.Windows.json
@@ -0,0 +1,4 @@
+{
+ "SonarCloudOrganization": "openhab",
+ "ProjectKey": "openhab_openhab-windows"
+}
\ No newline at end of file
diff --git a/.sonarlint/OpenHAB.Windows.slconfig b/.sonarlint/OpenHAB.Windows.slconfig
deleted file mode 100644
index 704efb31..00000000
--- a/.sonarlint/OpenHAB.Windows.slconfig
+++ /dev/null
@@ -1,15 +0,0 @@
-{
- "ServerUri": "https://sonarcloud.io/",
- "Organization": {
- "Key": "openhab",
- "Name": "openHAB"
- },
- "ProjectKey": "openhab_openhab-windows",
- "ProjectName": "openhab-windows",
- "Profiles": {
- "CSharp": {
- "ProfileKey": "AXflIL33YGfeNt47qUY1",
- "ProfileTimestamp": "2021-11-22T10:44:23Z"
- }
- }
-}
\ No newline at end of file
diff --git a/.sonarlint/openhab_openhab-windows/CSharp/SonarLint.xml b/.sonarlint/openhab_openhab-windows/CSharp/SonarLint.xml
deleted file mode 100644
index 90bc98df..00000000
--- a/.sonarlint/openhab_openhab-windows/CSharp/SonarLint.xml
+++ /dev/null
@@ -1,89 +0,0 @@
-
-
-
-
- sonar.cs.analyzeGeneratedCode
- false
-
-
- sonar.cs.file.suffixes
- .cs
-
-
- sonar.cs.ignoreHeaderComments
- true
-
-
- sonar.cs.roslyn.ignoreIssues
- false
-
-
-
-
- S107
-
-
- max
- 7
-
-
-
-
- S110
-
-
- max
- 5
-
-
-
-
- S1479
-
-
- maximum
- 30
-
-
-
-
- S2342
-
-
- flagsAttributeFormat
- ^([A-Z]{1,3}[a-z0-9]+)*([A-Z]{2})?s$
-
-
- format
- ^([A-Z]{1,3}[a-z0-9]+)*([A-Z]{2})?$
-
-
-
-
- S2436
-
-
- max
- 2
-
-
- maxMethod
- 3
-
-
-
-
- S3776
-
-
- propertyThreshold
- 3
-
-
- threshold
- 15
-
-
-
-
-
\ No newline at end of file
diff --git a/.sonarlint/openhab_openhab-windowscsharp.ruleset b/.sonarlint/openhab_openhab-windowscsharp.ruleset
deleted file mode 100644
index 79df8173..00000000
--- a/.sonarlint/openhab_openhab-windowscsharp.ruleset
+++ /dev/null
@@ -1,370 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/.vscode/launch.json b/.vscode/launch.json
new file mode 100644
index 00000000..9751e827
--- /dev/null
+++ b/.vscode/launch.json
@@ -0,0 +1,38 @@
+{
+ // Use IntelliSense to learn about possible attributes.
+ // Hover to view descriptions of existing attributes.
+ // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387
+ "version": "0.2.0",
+ "configurations": [
+ {
+ "name": "PowerShell Launch Current File",
+ "type": "PowerShell",
+ "request": "launch",
+ "script": "${file}",
+ "cwd": "${file}",
+ "args": [
+ "-SourceDirectory", "${workspaceFolder}/src",
+ "-Major", "2022",
+ "-Minor","9",
+ "-Build","12",
+ "-Revision", "0",
+ "-SetVersion"
+ ]
+ },
+ {
+ "name": "Build: Launch Version Script",
+ "type": "PowerShell",
+ "request": "launch",
+ "script": "./Set-Version.ps1",
+ "cwd": "${workspaceFolder}/.github/workflows/scripts/",
+ "args": [
+ "-SourceDirectory", "${workspaceFolder}/src",
+ "-Major", "2022",
+ "-Minor","9",
+ "-Build","12",
+ "-Revision", "0",
+ "-SetVersion"
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/OpenHAB.Windows.sln b/OpenHAB.Windows.sln
index 7824d181..d8f8265b 100644
--- a/OpenHAB.Windows.sln
+++ b/OpenHAB.Windows.sln
@@ -1,7 +1,7 @@
Microsoft Visual Studio Solution File, Format Version 12.00
-# Visual Studio Version 16
-VisualStudioVersion = 16.0.29409.12
+# Visual Studio Version 17
+VisualStudioVersion = 17.3.32825.248
MinimumVisualStudioVersion = 10.0.40219.1
Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "libaries", "libaries", "{6D9E45E3-F3C1-4A9D-A62D-72DDBA11C31B}"
ProjectSection(SolutionItems) = preProject
@@ -13,50 +13,118 @@ Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Solution Items", "Solution
.editorconfig = .editorconfig
EndProjectSection
EndProject
-Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Openhab.Core", "src\openHAB.Core\Openhab.Core.csproj", "{2A8FD10E-4EE5-4E25-B47C-2296E071F482}"
+Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "openHAB.Core", "src\openHAB.Core\openHAB.Core.csproj", "{2A8FD10E-4EE5-4E25-B47C-2296E071F482}"
EndProject
-Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "openHAB.Windows", "src\openHAB.Windows\openHAB.Windows.csproj", "{D65E41CE-1AE7-403A-B178-D69E8DAFB08B}"
+Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "openHAB.Windows", "src\openHAB.Windows\openHAB.Windows.csproj", "{D65E41CE-1AE7-403A-B178-D69E8DAFB08B}"
+EndProject
+Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "openHAB.Core.Client", "src\openHAB.Core.Client\openHAB.Core.Client.csproj", "{3B8F31DD-1AF2-47CF-B7DB-3B732FE4EC5A}"
+EndProject
+Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "openHAB.Common", "src\openHAB.Common\openHAB.Common.csproj", "{E53B599D-4BDB-40B1-86E4-47FB90420138}"
+EndProject
+Project("{C7167F0D-BC9F-4E6E-AFE1-012C56B48DB5}") = "openHAB.Windows.Package", "src\openHAB.Windows.Package\openHAB.Windows.Package.wapproj", "{4E463E63-604D-4C3D-8A13-273B787C99B2}"
+EndProject
+Project("{C7167F0D-BC9F-4E6E-AFE1-012C56B48DB5}") = "openHAB.Windows.Package.Beta", "src\openHAB.Windows.Package.Beta\openHAB.Windows.Package.Beta.wapproj", "{DC801784-7226-423E-AB0D-C34DFC8AB938}"
EndProject
Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution
- Debug|ARM = Debug|ARM
+ Debug|arm64 = Debug|arm64
Debug|x64 = Debug|x64
Debug|x86 = Debug|x86
- Release|ARM = Release|ARM
+ Release|arm64 = Release|arm64
Release|x64 = Release|x64
Release|x86 = Release|x86
EndGlobalSection
GlobalSection(ProjectConfigurationPlatforms) = postSolution
- {2A8FD10E-4EE5-4E25-B47C-2296E071F482}.Debug|ARM.ActiveCfg = Debug|ARM
- {2A8FD10E-4EE5-4E25-B47C-2296E071F482}.Debug|ARM.Build.0 = Debug|ARM
+ {2A8FD10E-4EE5-4E25-B47C-2296E071F482}.Debug|arm64.ActiveCfg = Debug|arm64
+ {2A8FD10E-4EE5-4E25-B47C-2296E071F482}.Debug|arm64.Build.0 = Debug|arm64
{2A8FD10E-4EE5-4E25-B47C-2296E071F482}.Debug|x64.ActiveCfg = Debug|x64
{2A8FD10E-4EE5-4E25-B47C-2296E071F482}.Debug|x64.Build.0 = Debug|x64
{2A8FD10E-4EE5-4E25-B47C-2296E071F482}.Debug|x86.ActiveCfg = Debug|x86
{2A8FD10E-4EE5-4E25-B47C-2296E071F482}.Debug|x86.Build.0 = Debug|x86
- {2A8FD10E-4EE5-4E25-B47C-2296E071F482}.Release|ARM.ActiveCfg = Release|ARM
- {2A8FD10E-4EE5-4E25-B47C-2296E071F482}.Release|ARM.Build.0 = Release|ARM
+ {2A8FD10E-4EE5-4E25-B47C-2296E071F482}.Release|arm64.ActiveCfg = Release|arm64
+ {2A8FD10E-4EE5-4E25-B47C-2296E071F482}.Release|arm64.Build.0 = Release|arm64
{2A8FD10E-4EE5-4E25-B47C-2296E071F482}.Release|x64.ActiveCfg = Release|x64
{2A8FD10E-4EE5-4E25-B47C-2296E071F482}.Release|x64.Build.0 = Release|x64
{2A8FD10E-4EE5-4E25-B47C-2296E071F482}.Release|x86.ActiveCfg = Release|x86
{2A8FD10E-4EE5-4E25-B47C-2296E071F482}.Release|x86.Build.0 = Release|x86
- {D65E41CE-1AE7-403A-B178-D69E8DAFB08B}.Debug|ARM.ActiveCfg = Debug|ARM
- {D65E41CE-1AE7-403A-B178-D69E8DAFB08B}.Debug|ARM.Build.0 = Debug|ARM
- {D65E41CE-1AE7-403A-B178-D69E8DAFB08B}.Debug|ARM.Deploy.0 = Debug|ARM
+ {D65E41CE-1AE7-403A-B178-D69E8DAFB08B}.Debug|arm64.ActiveCfg = Debug|arm64
+ {D65E41CE-1AE7-403A-B178-D69E8DAFB08B}.Debug|arm64.Build.0 = Debug|arm64
+ {D65E41CE-1AE7-403A-B178-D69E8DAFB08B}.Debug|arm64.Deploy.0 = Debug|arm64
{D65E41CE-1AE7-403A-B178-D69E8DAFB08B}.Debug|x64.ActiveCfg = Debug|x64
{D65E41CE-1AE7-403A-B178-D69E8DAFB08B}.Debug|x64.Build.0 = Debug|x64
{D65E41CE-1AE7-403A-B178-D69E8DAFB08B}.Debug|x64.Deploy.0 = Debug|x64
{D65E41CE-1AE7-403A-B178-D69E8DAFB08B}.Debug|x86.ActiveCfg = Debug|x86
{D65E41CE-1AE7-403A-B178-D69E8DAFB08B}.Debug|x86.Build.0 = Debug|x86
{D65E41CE-1AE7-403A-B178-D69E8DAFB08B}.Debug|x86.Deploy.0 = Debug|x86
- {D65E41CE-1AE7-403A-B178-D69E8DAFB08B}.Release|ARM.ActiveCfg = Release|ARM
- {D65E41CE-1AE7-403A-B178-D69E8DAFB08B}.Release|ARM.Build.0 = Release|ARM
- {D65E41CE-1AE7-403A-B178-D69E8DAFB08B}.Release|ARM.Deploy.0 = Release|ARM
+ {D65E41CE-1AE7-403A-B178-D69E8DAFB08B}.Release|arm64.ActiveCfg = Release|arm64
+ {D65E41CE-1AE7-403A-B178-D69E8DAFB08B}.Release|arm64.Build.0 = Release|arm64
+ {D65E41CE-1AE7-403A-B178-D69E8DAFB08B}.Release|arm64.Deploy.0 = Release|arm64
{D65E41CE-1AE7-403A-B178-D69E8DAFB08B}.Release|x64.ActiveCfg = Release|x64
{D65E41CE-1AE7-403A-B178-D69E8DAFB08B}.Release|x64.Build.0 = Release|x64
{D65E41CE-1AE7-403A-B178-D69E8DAFB08B}.Release|x64.Deploy.0 = Release|x64
{D65E41CE-1AE7-403A-B178-D69E8DAFB08B}.Release|x86.ActiveCfg = Release|x86
{D65E41CE-1AE7-403A-B178-D69E8DAFB08B}.Release|x86.Build.0 = Release|x86
{D65E41CE-1AE7-403A-B178-D69E8DAFB08B}.Release|x86.Deploy.0 = Release|x86
+ {3B8F31DD-1AF2-47CF-B7DB-3B732FE4EC5A}.Debug|arm64.ActiveCfg = Debug|arm64
+ {3B8F31DD-1AF2-47CF-B7DB-3B732FE4EC5A}.Debug|arm64.Build.0 = Debug|arm64
+ {3B8F31DD-1AF2-47CF-B7DB-3B732FE4EC5A}.Debug|x64.ActiveCfg = Debug|x64
+ {3B8F31DD-1AF2-47CF-B7DB-3B732FE4EC5A}.Debug|x64.Build.0 = Debug|x64
+ {3B8F31DD-1AF2-47CF-B7DB-3B732FE4EC5A}.Debug|x86.ActiveCfg = Debug|x86
+ {3B8F31DD-1AF2-47CF-B7DB-3B732FE4EC5A}.Debug|x86.Build.0 = Debug|x86
+ {3B8F31DD-1AF2-47CF-B7DB-3B732FE4EC5A}.Release|arm64.ActiveCfg = Release|arm64
+ {3B8F31DD-1AF2-47CF-B7DB-3B732FE4EC5A}.Release|arm64.Build.0 = Release|arm64
+ {3B8F31DD-1AF2-47CF-B7DB-3B732FE4EC5A}.Release|x64.ActiveCfg = Release|x64
+ {3B8F31DD-1AF2-47CF-B7DB-3B732FE4EC5A}.Release|x64.Build.0 = Release|x64
+ {3B8F31DD-1AF2-47CF-B7DB-3B732FE4EC5A}.Release|x86.ActiveCfg = Release|x86
+ {3B8F31DD-1AF2-47CF-B7DB-3B732FE4EC5A}.Release|x86.Build.0 = Release|x86
+ {E53B599D-4BDB-40B1-86E4-47FB90420138}.Debug|arm64.ActiveCfg = Debug|arm64
+ {E53B599D-4BDB-40B1-86E4-47FB90420138}.Debug|arm64.Build.0 = Debug|arm64
+ {E53B599D-4BDB-40B1-86E4-47FB90420138}.Debug|x64.ActiveCfg = Debug|x64
+ {E53B599D-4BDB-40B1-86E4-47FB90420138}.Debug|x64.Build.0 = Debug|x64
+ {E53B599D-4BDB-40B1-86E4-47FB90420138}.Debug|x86.ActiveCfg = Debug|x86
+ {E53B599D-4BDB-40B1-86E4-47FB90420138}.Debug|x86.Build.0 = Debug|x86
+ {E53B599D-4BDB-40B1-86E4-47FB90420138}.Release|arm64.ActiveCfg = Release|arm64
+ {E53B599D-4BDB-40B1-86E4-47FB90420138}.Release|arm64.Build.0 = Release|arm64
+ {E53B599D-4BDB-40B1-86E4-47FB90420138}.Release|x64.ActiveCfg = Release|x64
+ {E53B599D-4BDB-40B1-86E4-47FB90420138}.Release|x64.Build.0 = Release|x64
+ {E53B599D-4BDB-40B1-86E4-47FB90420138}.Release|x86.ActiveCfg = Release|x86
+ {E53B599D-4BDB-40B1-86E4-47FB90420138}.Release|x86.Build.0 = Release|x86
+ {4E463E63-604D-4C3D-8A13-273B787C99B2}.Debug|arm64.ActiveCfg = Debug|arm64
+ {4E463E63-604D-4C3D-8A13-273B787C99B2}.Debug|arm64.Build.0 = Debug|arm64
+ {4E463E63-604D-4C3D-8A13-273B787C99B2}.Debug|arm64.Deploy.0 = Debug|arm64
+ {4E463E63-604D-4C3D-8A13-273B787C99B2}.Debug|x64.ActiveCfg = Debug|x64
+ {4E463E63-604D-4C3D-8A13-273B787C99B2}.Debug|x64.Build.0 = Debug|x64
+ {4E463E63-604D-4C3D-8A13-273B787C99B2}.Debug|x64.Deploy.0 = Debug|x64
+ {4E463E63-604D-4C3D-8A13-273B787C99B2}.Debug|x86.ActiveCfg = Debug|x86
+ {4E463E63-604D-4C3D-8A13-273B787C99B2}.Debug|x86.Build.0 = Debug|x86
+ {4E463E63-604D-4C3D-8A13-273B787C99B2}.Debug|x86.Deploy.0 = Debug|x86
+ {4E463E63-604D-4C3D-8A13-273B787C99B2}.Release|arm64.ActiveCfg = Release|arm64
+ {4E463E63-604D-4C3D-8A13-273B787C99B2}.Release|arm64.Build.0 = Release|arm64
+ {4E463E63-604D-4C3D-8A13-273B787C99B2}.Release|arm64.Deploy.0 = Release|arm64
+ {4E463E63-604D-4C3D-8A13-273B787C99B2}.Release|x64.ActiveCfg = Release|x64
+ {4E463E63-604D-4C3D-8A13-273B787C99B2}.Release|x64.Build.0 = Release|x64
+ {4E463E63-604D-4C3D-8A13-273B787C99B2}.Release|x64.Deploy.0 = Release|x64
+ {4E463E63-604D-4C3D-8A13-273B787C99B2}.Release|x86.ActiveCfg = Release|x86
+ {4E463E63-604D-4C3D-8A13-273B787C99B2}.Release|x86.Build.0 = Release|x86
+ {4E463E63-604D-4C3D-8A13-273B787C99B2}.Release|x86.Deploy.0 = Release|x86
+ {DC801784-7226-423E-AB0D-C34DFC8AB938}.Debug|arm64.ActiveCfg = Debug|ARM64
+ {DC801784-7226-423E-AB0D-C34DFC8AB938}.Debug|arm64.Build.0 = Debug|ARM64
+ {DC801784-7226-423E-AB0D-C34DFC8AB938}.Debug|arm64.Deploy.0 = Debug|ARM64
+ {DC801784-7226-423E-AB0D-C34DFC8AB938}.Debug|x64.ActiveCfg = Debug|x64
+ {DC801784-7226-423E-AB0D-C34DFC8AB938}.Debug|x64.Build.0 = Debug|x64
+ {DC801784-7226-423E-AB0D-C34DFC8AB938}.Debug|x64.Deploy.0 = Debug|x64
+ {DC801784-7226-423E-AB0D-C34DFC8AB938}.Debug|x86.ActiveCfg = Debug|x86
+ {DC801784-7226-423E-AB0D-C34DFC8AB938}.Debug|x86.Build.0 = Debug|x86
+ {DC801784-7226-423E-AB0D-C34DFC8AB938}.Debug|x86.Deploy.0 = Debug|x86
+ {DC801784-7226-423E-AB0D-C34DFC8AB938}.Release|arm64.ActiveCfg = Release|ARM64
+ {DC801784-7226-423E-AB0D-C34DFC8AB938}.Release|arm64.Build.0 = Release|ARM64
+ {DC801784-7226-423E-AB0D-C34DFC8AB938}.Release|arm64.Deploy.0 = Release|ARM64
+ {DC801784-7226-423E-AB0D-C34DFC8AB938}.Release|x64.ActiveCfg = Release|x64
+ {DC801784-7226-423E-AB0D-C34DFC8AB938}.Release|x64.Build.0 = Release|x64
+ {DC801784-7226-423E-AB0D-C34DFC8AB938}.Release|x64.Deploy.0 = Release|x64
+ {DC801784-7226-423E-AB0D-C34DFC8AB938}.Release|x86.ActiveCfg = Release|x86
+ {DC801784-7226-423E-AB0D-C34DFC8AB938}.Release|x86.Build.0 = Release|x86
+ {DC801784-7226-423E-AB0D-C34DFC8AB938}.Release|x86.Deploy.0 = Release|x86
EndGlobalSection
GlobalSection(SolutionProperties) = preSolution
HideSolutionNode = FALSE
diff --git a/README.md b/README.md
index ba1ec8a1..ee721452 100644
--- a/README.md
+++ b/README.md
@@ -1,41 +1,59 @@
## Introduction
-openHAB Windows application is a native client for openHAB 2 & 3. It uses REST API of openHAB to render
-sitemaps of your openHAB.
+The openHAB Windows application is a native client for openHAB 3 & 4, leveraging the REST API to render sitemaps and provide a seamless interface for managing your smart home devices.
+
+openHAB (open Home Automation Bus) is an open-source, technology-agnostic home automation platform that integrates various smart home systems and technologies into one solution. It is designed to be flexible and scalable, allowing users to automate their homes with ease. openHAB supports a wide range of devices and protocols, making it a versatile choice for home automation enthusiasts.
+
+### Key Features
+- **Extensibility**: With a modular architecture, openHAB can be extended with add-ons to support new devices and technologies.
+- **Community-Driven**: Maintained by a vibrant community of developers and users who contribute to its continuous improvement.
+- **Cross-Platform**: Runs on various operating systems, including Windows, macOS, Linux, and Raspberry Pi.
+- **User-Friendly Interfaces**: Offers multiple user interfaces, such as web-based UIs, mobile apps, and voice control, to manage and monitor your smart home.
+
+For more information, visit the [official openHAB website](https://www.openhab.org/).
## Builds
+[data:image/s3,"s3://crabby-images/547ec/547ec3b4ff9ee8642fcd1e5547fb51b63078e1ff" alt="openHAB Build and Release app"](https://github.com/openhab/openhab-windows/actions/workflows/openhab.yml)
+
+## Microsoft App Store
+
+### Beta App
+The beta app offers early access to upcoming features and fixes, allowing users to test and provide feedback before these updates are officially released in the main application. This helps ensure a stable and polished experience for all users.
+
+[data:image/s3,"s3://crabby-images/5c5dd/5c5ddb6db03c5dd3d48d6181e7ab23585542ca31" alt="Link to Windows Store"](https://www.microsoft.com/store/apps/9N140MD0NJ6T)
+
+### Production App
+The production app is the stable version of the openHAB Windows application, providing a reliable and tested experience for managing your smart home devices. It includes all the latest features and improvements that have been thoroughly vetted by the community and developers.
-[data:image/s3,"s3://crabby-images/44a98/44a9817a9cb9acb71a29456a8036db1e25355b24" alt="CI Build"](https://github.com/openhab/openhab-windows/actions/workflows/ci.yml)
-[data:image/s3,"s3://crabby-images/be128/be12826bcd62be3d4628c1ed428567a72ba59357" alt="Latest App Release Build"](https://github.com/openhab/openhab-windows/actions/workflows/app-release.yml)
+[data:image/s3,"s3://crabby-images/5c5dd/5c5ddb6db03c5dd3d48d6181e7ab23585542ca31" alt="Link to Windows Store"](https://www.microsoft.com/store/apps/9NMQ39CTWXGT)
## Code Analysis
-The app project is using SonarQube hosted by SonarCloud to analyse the code for issues and code quality.
+The project utilizes SonarQube, hosted by SonarCloud, to analyze the code for potential issues and ensure high code quality.
[data:image/s3,"s3://crabby-images/9ae1b/9ae1b96884ce83d20dee713e7adccc38a71bd831" alt="SonarCloud"](https://sonarcloud.io/dashboard?id=openhab_openhab-windows)
### Quality Status
-| Branch | Quality Gate Status | Bugs |Code Smells
-|--------|---------------------|------ |------------|
-| beta ||||
-| main | [data:image/s3,"s3://crabby-images/b8962/b8962c28155ea9a703b7bdc25a0bbd7e293d6893" alt="Quality Gate Status"](https://sonarcloud.io/dashboard?id=openhab_openhab-windows)| [data:image/s3,"s3://crabby-images/ceb89/ceb8910cbdf6c55d5bfcf61d8a03787defe7a5aa" alt="Bugs"](https://sonarcloud.io/dashboard?id=openhab_openhab-windows)|[data:image/s3,"s3://crabby-images/8e442/8e44223a0c4b712c542f7f990a0248b3bc87b04f" alt="Code Smells"](https://sonarcloud.io/dashboard?id=openhab_openhab-windows)|
+| Branch | Quality Gate Status | Bugs | Code Smells |
+|--------|---------------------|------|-------------|
+| beta | | | |
+| main | [data:image/s3,"s3://crabby-images/b8962/b8962c28155ea9a703b7bdc25a0bbd7e293d6893" alt="Quality Gate Status"](https://sonarcloud.io/dashboard?id=openhab_openhab-windows) | [data:image/s3,"s3://crabby-images/ceb89/ceb8910cbdf6c55d5bfcf61d8a03787defe7a5aa" alt="Bugs"](https://sonarcloud.io/dashboard?id=openhab_openhab-windows) | [data:image/s3,"s3://crabby-images/8e442/8e44223a0c4b712c542f7f990a0248b3bc87b04f" alt="Code Smells"](https://sonarcloud.io/dashboard?id=openhab_openhab-windows) |
-## Setting up development environment
+## Setting up the Development Environment
-If you want to contribute to the Windows application we are here to help you to set up
-development environment. openHAB Windows app is developed using Visual Studio 2019 and later.
+If you want to contribute to the Windows application, we are here to help you set up your development environment. The openHAB Windows app is developed using Visual Studio 2019 and later versions.
-- Download and install [Visual Studio Community Edition](https://www.visualstudio.com/downloads/)
-- During install, make sure to select UWP SDK 17763 and SDK 19041
-- Check out the latest code from github
-- Open the project in Visual Studio (File -> Open, Project/Solution)
-- Rebuild the solution to fetch all missing NuGet packages
+### Steps to Set Up:
+1. Download and install [Visual Studio Community Edition](https://www.visualstudio.com/downloads/).
+2. During installation, ensure to select Windows 10 SDK 10.0.20348.0 and Windows 11 SDK 10.0.26100.0.
+3. Check out the latest code from GitHub.
+4. Install pre-commit hook tooling by executing `setup_pre-commit.ps1`
+4. Open the project in Visual Studio (File -> Open -> Project/Solution).
+5. Rebuild the solution to fetch all missing NuGet packages.
-You are ready to contribute!
+You are now ready to contribute!
-Before producing any amount of code please have a look at [contribution guidelines](https://github.com/openhab/openhab.windows/blob/master/CONTRIBUTING.md)
+Before writing any code, please review our [contribution guidelines](https://github.com/openhab/openhab.windows/blob/master/CONTRIBUTING.md).
## Trademark Disclaimer
-Product names, logos, brands and other trademarks referred to within the openHAB website are the
-property of their respective trademark holders. These trademark holders are not affiliated with
-openHAB or our website. They do not sponsor or endorse our materials.
+Product names, logos, brands, and other trademarks referred to within the openHAB website are the property of their respective trademark holders. These trademark holders are not affiliated with openHAB or our website. They do not sponsor or endorse our materials.
diff --git a/docs/get_microsoft_store.png b/docs/get_microsoft_store.png
new file mode 100644
index 00000000..a5f827bf
Binary files /dev/null and b/docs/get_microsoft_store.png differ
diff --git a/docs/screenshots/screenshot1.png b/docs/screenshots/screenshot1.png
deleted file mode 100644
index 24144484..00000000
Binary files a/docs/screenshots/screenshot1.png and /dev/null differ
diff --git a/docs/screenshots/screenshot2.png b/docs/screenshots/screenshot2.png
deleted file mode 100644
index 3bc8a1a3..00000000
Binary files a/docs/screenshots/screenshot2.png and /dev/null differ
diff --git a/docs/screenshots/screenshot3.png b/docs/screenshots/screenshot3.png
deleted file mode 100644
index 0b7cf09d..00000000
Binary files a/docs/screenshots/screenshot3.png and /dev/null differ
diff --git a/docs/screenshots/screenshot4.png b/docs/screenshots/screenshot4.png
deleted file mode 100644
index 33de7dee..00000000
Binary files a/docs/screenshots/screenshot4.png and /dev/null differ
diff --git a/setup_pre-commit.ps1 b/setup_pre-commit.ps1
new file mode 100644
index 00000000..afd9ee63
--- /dev/null
+++ b/setup_pre-commit.ps1
@@ -0,0 +1,18 @@
+# setup_pre-commit.ps
+# This script initializes pre-commit hooks for the repository
+
+# Ensure pre-commit is installed
+if (-not (Get-Command pre-commit -ErrorAction SilentlyContinue)) {
+ Write-Host "pre-commit is not installed. Installing..."
+ pip install pre-commit
+}
+
+# Navigate to the repository root
+$repoRoot = Split-Path -Parent $MyInvocation.MyCommand.Path
+Set-Location $repoRoot
+
+# Install pre-commit hooks
+Write-Host "Installing pre-commit hooks..."
+pre-commit install --hook-type pre-commit --hook-type pre-push --hook-type commit-msg
+
+Write-Host "Pre-commit hooks installed successfully."
diff --git a/src/openHAB.Common/AppResources.cs b/src/openHAB.Common/AppResources.cs
new file mode 100644
index 00000000..6ba1874e
--- /dev/null
+++ b/src/openHAB.Common/AppResources.cs
@@ -0,0 +1,44 @@
+using Microsoft.Windows.ApplicationModel.Resources;
+
+namespace openHAB.Common;
+
+///
+/// Resources.
+///
+public static class AppResources
+{
+ private static ResourceLoader _resourceLoader;
+ private static ResourceLoader _errorResourceLoader;
+
+ ///
+ /// Gets the localized UI values.
+ ///
+ public static ResourceLoader Values
+ {
+ get
+ {
+ if (_resourceLoader == null)
+ {
+ _resourceLoader = new ResourceLoader(ResourceLoader.GetDefaultResourceFilePath());
+ }
+
+ return _resourceLoader;
+ }
+ }
+
+ ///
+ /// Gets the localized error strings.
+ ///
+ public static ResourceLoader Errors
+ {
+ get
+ {
+ if (_errorResourceLoader == null)
+ {
+ _errorResourceLoader = new ResourceLoader(ResourceLoader.GetDefaultResourceFilePath());
+ }
+
+ return _errorResourceLoader;
+ }
+ }
+}
diff --git a/src/openHAB.Common/openHAB.Common.csproj b/src/openHAB.Common/openHAB.Common.csproj
new file mode 100644
index 00000000..1abdd938
--- /dev/null
+++ b/src/openHAB.Common/openHAB.Common.csproj
@@ -0,0 +1,15 @@
+
+
+ net8.0-windows10.0.26100.0
+ 10.0.17763.0
+ openHAB.Common
+ win-x86;win-x64;win-arm64
+ true
+ 10.0.20348.0
+ x86;x64;arm64
+
+
+
+
+
+
diff --git a/src/openHAB.Core.Client/AutoNumberToStringConverter.cs b/src/openHAB.Core.Client/AutoNumberToStringConverter.cs
new file mode 100644
index 00000000..c7b05ac8
--- /dev/null
+++ b/src/openHAB.Core.Client/AutoNumberToStringConverter.cs
@@ -0,0 +1,38 @@
+using System;
+using System.Text.Json;
+using System.Text.Json.Serialization;
+
+namespace openHAB.Core.Client;
+
+public class AutoNumberToStringConverter : JsonConverter