Compare commits

24 Commits

Author SHA1 Message Date
Simon Diesenreiter
5510832538 release: version 0.1.17 🚀
Some checks failed
CI / tests_linux (9.0.X, ubuntu-latest) (push) Has been cancelled
CI / linter (9.0.X, ubuntu-latest) (push) Has been cancelled
SonarQube Scan / SonarQube Trigger (push) Has been cancelled
Build Docker image / Create Release (push) Successful in 17s
Build Docker image / deploy (push) Failing after 1m18s
2025-04-15 15:07:10 +02:00
Simon Diesenreiter
604e8dfe70 fix: remove uinnecessary NuGet login refs NOISSUE 2025-04-15 15:07:03 +02:00
Simon Diesenreiter
2c2a58975e release: version 0.1.16 🚀
Some checks failed
CI / tests_linux (9.0.X, ubuntu-latest) (push) Blocked by required conditions
Build Docker image / Create Release (push) Successful in 20s
CI / linter (9.0.X, ubuntu-latest) (push) Has been cancelled
SonarQube Scan / SonarQube Trigger (push) Has been cancelled
Build Docker image / deploy (push) Has been cancelled
2025-04-15 15:06:32 +02:00
Simon Diesenreiter
7572a66ae2 fix: add direct CronTimer reference refs NOISSUE 2025-04-15 15:06:29 +02:00
Simon Diesenreiter
3ed6c4c54f release: version 0.1.15 🚀
Some checks failed
CI / tests_linux (9.0.X, ubuntu-latest) (push) Has been cancelled
CI / linter (9.0.X, ubuntu-latest) (push) Has been cancelled
SonarQube Scan / SonarQube Trigger (push) Has been cancelled
Build Docker image / Create Release (push) Successful in 10s
Build Docker image / deploy (push) Failing after 52s
2025-04-15 14:56:01 +02:00
Simon Diesenreiter
f2472a3ea2 fix: login to NuGet feed at build refs NOISSUE 2025-04-15 14:55:56 +02:00
Simon Diesenreiter
4d657cf887 release: version 0.1.14 🚀
Some checks failed
CI / tests_linux (9.0.X, ubuntu-latest) (push) Has been cancelled
CI / linter (9.0.X, ubuntu-latest) (push) Has been cancelled
SonarQube Scan / SonarQube Trigger (push) Has been cancelled
Build Docker image / Create Release (push) Successful in 12s
Build Docker image / deploy (push) Failing after 1m13s
2025-04-15 14:38:19 +02:00
Simon Diesenreiter
1388ce80db fix: fix typo refs NOISSUE 2025-04-15 14:38:16 +02:00
Simon Diesenreiter
d335ddfd0d release: version 0.1.13 🚀
Some checks failed
Build Docker image / Create Release (push) Successful in 21s
CI / linter (9.0.X, ubuntu-latest) (push) Failing after 1m2s
CI / tests_linux (9.0.X, ubuntu-latest) (push) Has been cancelled
SonarQube Scan / SonarQube Trigger (push) Has been cancelled
Build Docker image / deploy (push) Failing after 1m57s
2025-04-15 14:34:56 +02:00
Simon Diesenreiter
68caf0a329 fix: really fix Crontab dependency refs NOISSUE 2025-04-15 14:34:51 +02:00
Simon Diesenreiter
2889661f24 release: version 0.1.12 🚀
Some checks failed
Build Docker image / Create Release (push) Successful in 1m17s
CI / linter (9.0.X, ubuntu-latest) (push) Failing after 1m37s
CI / tests_linux (9.0.X, ubuntu-latest) (push) Has been skipped
Build Docker image / deploy (push) Successful in 2m46s
SonarQube Scan / SonarQube Trigger (push) Failing after 4m56s
2025-04-15 13:58:19 +02:00
Simon Diesenreiter
513589a6fc fix: hotfixed CronTab dependencyrefs NOISSUE 2025-04-15 13:58:12 +02:00
Simon Diesenreiter
28616252aa release: version 0.1.11 🚀
Some checks failed
CI / tests_linux (9.0.X, ubuntu-latest) (push) Blocked by required conditions
CI / linter (9.0.X, ubuntu-latest) (push) Has been cancelled
SonarQube Scan / SonarQube Trigger (push) Has been cancelled
Upload Python Package / Create Release (push) Successful in 8s
Upload Python Package / deploy (push) Successful in 1m54s
2025-04-15 13:07:36 +02:00
Simon Diesenreiter
09acbbefea fix: more debug outputs refs NOISSUE 2025-04-15 13:06:39 +02:00
Simon Diesenreiter
9598965a4a release: version 0.1.10 🚀
Some checks failed
CI / tests_linux (9.0.X, ubuntu-latest) (push) Has been cancelled
CI / linter (9.0.X, ubuntu-latest) (push) Has been cancelled
SonarQube Scan / SonarQube Trigger (push) Has been cancelled
Upload Python Package / Create Release (push) Successful in 46s
Upload Python Package / deploy (push) Successful in 2m26s
2025-04-15 12:37:15 +02:00
Simon Diesenreiter
2111eb21e3 fix: release version jumbled up refs NOISSUE 2025-04-15 12:37:06 +02:00
Simon Diesenreiter
49ec368b2f release: version 0.1.8 🚀
Some checks failed
CI / tests_linux (9.0.X, ubuntu-latest) (push) Blocked by required conditions
CI / linter (9.0.X, ubuntu-latest) (push) Has been cancelled
SonarQube Scan / SonarQube Trigger (push) Has been cancelled
Upload Python Package / deploy (push) Has been cancelled
Upload Python Package / Create Release (push) Has been cancelled
2025-04-15 12:35:39 +02:00
Simon Diesenreiter
a473eccfda release: version 0.1.8 🚀 2025-04-15 12:35:32 +02:00
Simon Diesenreiter
ce82717d62 fix: additional debug outputs refs NOISSUE 2025-04-15 12:28:34 +02:00
Simon Diesenreiter
3bb39ab17c release: version 0.1.7 🚀
Some checks failed
SonarQube Scan / SonarQube Trigger (push) Has been cancelled
CI / tests_linux (9.0.X, ubuntu-latest) (push) Has been cancelled
CI / linter (9.0.X, ubuntu-latest) (push) Has been cancelled
Upload Python Package / Create Release (push) Successful in 22s
Upload Python Package / deploy (push) Successful in 3m28s
2025-04-15 11:59:51 +02:00
Simon Diesenreiter
a66615c6fc fix: more fixes in release logic refs NOISSUE 2025-04-15 11:59:47 +02:00
Simon Diesenreiter
b054389b16 release: version 0.1.6 🚀
Some checks failed
CI / tests_linux (9.0.X, ubuntu-latest) (push) Has been cancelled
CI / linter (9.0.X, ubuntu-latest) (push) Has been cancelled
SonarQube Scan / SonarQube Trigger (push) Has been cancelled
Upload Python Package / deploy (push) Has been cancelled
Upload Python Package / Create Release (push) Has been cancelled
2025-04-15 11:58:09 +02:00
Simon Diesenreiter
71fb945de2 fix: makefile issues on sh refs NOISSUE 2025-04-15 11:57:59 +02:00
b4fab0deee fix: messed up release refs NOISSUE
Some checks failed
CI / tests_linux (9.0.X, ubuntu-latest) (push) Has been cancelled
CI / linter (9.0.X, ubuntu-latest) (push) Has been cancelled
SonarQube Scan / SonarQube Trigger (push) Has been cancelled
Upload Python Package / Create Release (push) Successful in 20s
Upload Python Package / deploy (push) Failing after 1m31s
2025-04-14 22:54:14 +02:00
12 changed files with 321 additions and 10 deletions

View File

@@ -86,8 +86,9 @@ start() {
echo "New version: $new_version"
gitchangelog | grep -v "[rR]elease:" > HISTORY.md
git add song_of_the_day/VERSION HISTORY.md
git add HISTORY.md
echo $new_version > song_of_the_day/VERSION
git add song_of_the_day/VERSION
git commit -m "release: version $new_version 🚀"
echo "creating git tag : $new_version"
git tag $new_version

View File

@@ -1,4 +1,4 @@
name: Upload Python Package
name: Build Docker image
permissions:
contents: write

View File

@@ -0,0 +1,6 @@
using System;
public class CronTimerEventArgs : EventArgs
{
public DateTime At { get; set; }
}

78
CronTimer/CronTimer.cs Normal file
View File

@@ -0,0 +1,78 @@
using System;
using System.Threading;
using NCrontab;
public class CronTimer
{
public const string UTC = "Etc/UTC";
static readonly TimeSpan InfiniteTimeSpan = TimeSpan.FromMilliseconds(Timeout.Infinite); // net 3.5
readonly CrontabSchedule schedule;
readonly TimeZoneInfo tzi;
readonly string id;
readonly Timer t;
public string tz { get; }
public string Expression { get; }
public event EventHandler<CronTimerEventArgs> OnOccurence;
public DateTime Next { get; private set; }
public CronTimer(string expression, string tz = UTC, bool includingSeconds = false)
{
Expression = expression;
this.tz = tz;
id = TimeZoneConverter.TZConvert.IanaToWindows(tz);
tzi = TimeZoneInfo.FindSystemTimeZoneById(id);
schedule = CrontabSchedule.Parse(expression, new CrontabSchedule.ParseOptions { IncludingSeconds = includingSeconds });
Next = TimeZoneInfo.ConvertTimeFromUtc(DateTime.UtcNow, tzi);
OnOccurence += OnOccurenceScheduleNext;
t = new Timer(s =>
{
var ea = new CronTimerEventArgs
{
At = Next
};
OnOccurence(this, ea);
}, null, InfiniteTimeSpan, InfiniteTimeSpan);
}
void OnOccurenceScheduleNext(object sender, EventArgs e)
{
var delay = CalculateDelay();
//Console.WriteLine($"Next for [{tz} {expression}] in {delay}.");
t.Change(delay, InfiniteTimeSpan);
}
public void Start()
{
var delay = CalculateDelay();
//Console.WriteLine($"Next for [{tz} {expression}] in {delay}.");
t.Change(delay, InfiniteTimeSpan);
}
TimeSpan CalculateDelay()
{
var nowUtc = DateTime.UtcNow;
Next = schedule.GetNextOccurrence(Next);
TimeSpan delay;
if (tz != UTC)
{
var nextUtc = TimeZoneInfo.ConvertTimeToUtc(Next, tzi);
delay = nextUtc - nowUtc;
}
else
{
delay = Next - nowUtc;
}
//Console.WriteLine($"Now: {nowUtc} [utc] {now} [{tz}], Next: {next} [{tz}] {nextUtc} [utc], Delay: {delay}");
if (delay < TimeSpan.Zero) delay = TimeSpan.Zero;
return delay;
}
public void Stop()
{
t.Change(InfiniteTimeSpan, InfiniteTimeSpan);
}
}

View File

@@ -0,0 +1,49 @@
<Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup>
<LangVersion>latest</LangVersion>
<TargetFrameworks>net461;netstandard2.1</TargetFrameworks>
<PlatformTarget>AnyCPU</PlatformTarget>
</PropertyGroup>
<PropertyGroup>
<!-- AssemblyFileVersionAttribute -->
<FileVersion>2.0.1</FileVersion>
<!-- AssemblyInformationalVersionAttribute -->
<Version>$(FileVersion)</Version>
<!-- AssemblyVersionAttribute -->
<AssemblyVersion>2.0.0.0</AssemblyVersion>
<!-- Nuget -->
<PackageVersion>$(Version)</PackageVersion>
<PackageId>CronTimer</PackageId>
<Company>https://github.com/ramonsmits</Company>
<Authors>ramonsmits</Authors>
<Description>Simple .net Timer that is based on cron expressions with second accuracy to fire timer events to a very specific schedule.</Description>
<PackageRequireLicenseAcceptance>false</PackageRequireLicenseAcceptance>
<PackageReleaseNotes></PackageReleaseNotes>
<PackageProjectUrl>https://github.com/ramonsmits/CronTimer/tree/$(PackageVersion)</PackageProjectUrl>
<PackageLicenseExpression>MIT</PackageLicenseExpression>
<IncludeSymbols>True</IncludeSymbols>
<SymbolPackageFormat>snupkg</SymbolPackageFormat>
<IncludeSource>True</IncludeSource>
<RepositoryUrl>https://github.com/ramonsmits/CronTimer</RepositoryUrl>
<Copyright>Copyright 2022 (c) Ramon Smits</Copyright>
<PackageTags>cron timer</PackageTags>
<GeneratePackageOnBuild>true</GeneratePackageOnBuild>
<PublishRepositoryUrl>true</PublishRepositoryUrl>
<ContinuousIntegrationBuild>true</ContinuousIntegrationBuild>
<EmbedUntrackedSources>true</EmbedUntrackedSources>
</PropertyGroup>
<ItemGroup>
<PackageReference Include="ncrontab" Version="3.3.1" />
<PackageReference Include="TimeZoneConverter" Version="6.0.1" />
</ItemGroup>
<!--<ItemGroup Condition="'$(TargetFramework)' == 'netstandard2.1'">
<PackageReference Include="Microsoft.Extensions.Logging.Abstractions">
<Version>3.1.4</Version>
</PackageReference>
</ItemGroup>-->
</Project>

36
CronTimer/CronTimer.sln Normal file
View File

@@ -0,0 +1,36 @@

Microsoft Visual Studio Solution File, Format Version 12.00
# Visual Studio Version 16
VisualStudioVersion = 16.0.30717.126
MinimumVisualStudioVersion = 10.0.40219.1
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "CronTimer", "CronTimer.csproj", "{FB64C227-8615-4AE1-94E3-F9F9DF192B72}"
EndProject
Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Solution Items", "Solution Items", "{CCDD0B34-653C-430C-9B17-5129618F8D7D}"
ProjectSection(SolutionItems) = preProject
..\README.md = ..\README.md
EndProjectSection
EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Demo", "..\Demo\Demo.csproj", "{C2638357-1621-4422-8701-B55BFB37ACCF}"
EndProject
Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution
Debug|Any CPU = Debug|Any CPU
Release|Any CPU = Release|Any CPU
EndGlobalSection
GlobalSection(ProjectConfigurationPlatforms) = postSolution
{FB64C227-8615-4AE1-94E3-F9F9DF192B72}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
{FB64C227-8615-4AE1-94E3-F9F9DF192B72}.Debug|Any CPU.Build.0 = Debug|Any CPU
{FB64C227-8615-4AE1-94E3-F9F9DF192B72}.Release|Any CPU.ActiveCfg = Release|Any CPU
{FB64C227-8615-4AE1-94E3-F9F9DF192B72}.Release|Any CPU.Build.0 = Release|Any CPU
{C2638357-1621-4422-8701-B55BFB37ACCF}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
{C2638357-1621-4422-8701-B55BFB37ACCF}.Debug|Any CPU.Build.0 = Debug|Any CPU
{C2638357-1621-4422-8701-B55BFB37ACCF}.Release|Any CPU.ActiveCfg = Release|Any CPU
{C2638357-1621-4422-8701-B55BFB37ACCF}.Release|Any CPU.Build.0 = Release|Any CPU
EndGlobalSection
GlobalSection(SolutionProperties) = preSolution
HideSolutionNode = FALSE
EndGlobalSection
GlobalSection(ExtensibilityGlobals) = postSolution
SolutionGuid = {A639B164-6581-40DF-ADC4-479DAB467CFE}
EndGlobalSection
EndGlobal

View File

@@ -5,10 +5,143 @@ Changelog
(unreleased)
------------
Fix
~~~
- Remove uinnecessary NuGet login refs NOISSUE. [Simon Diesenreiter]
0.1.16 (2025-04-15)
-------------------
Fix
~~~
- Add direct CronTimer reference refs NOISSUE. [Simon Diesenreiter]
Other
~~~~~
0.1.15 (2025-04-15)
-------------------
Fix
~~~
- Login to NuGet feed at build refs NOISSUE. [Simon Diesenreiter]
Other
~~~~~
0.1.14 (2025-04-15)
-------------------
Fix
~~~
- Fix typo refs NOISSUE. [Simon Diesenreiter]
Other
~~~~~
0.1.13 (2025-04-15)
-------------------
Fix
~~~
- Really fix Crontab dependency refs NOISSUE. [Simon Diesenreiter]
Other
~~~~~
0.1.12 (2025-04-15)
-------------------
Fix
~~~
- Hotfixed CronTab dependencyrefs NOISSUE. [Simon Diesenreiter]
Other
~~~~~
0.1.11 (2025-04-15)
-------------------
Fix
~~~
- More debug outputs refs NOISSUE. [Simon Diesenreiter]
Other
~~~~~
0.1.10 (2025-04-15)
-------------------
Fix
~~~
- Release version jumbled up refs NOISSUE. [Simon Diesenreiter]
Other
~~~~~
0.1.9 (2025-04-15)
------------------
0.1.8 (2025-04-15)
------------------
Fix
~~~
- Additional debug outputs refs NOISSUE. [Simon Diesenreiter]
Other
~~~~~
0.1.7 (2025-04-15)
------------------
Fix
~~~
- More fixes in release logic refs NOISSUE. [Simon Diesenreiter]
Other
~~~~~
0.1.6 (2025-04-15)
------------------
Fix
~~~
- Makefile issues on sh refs NOISSUE. [Simon Diesenreiter]
Other
~~~~~
0.1.5 (2025-04-14)
------------------
Fix
~~~
- Messed up release refs NOISSUE. [Simon Diesenreiter]
0.1.4 (2025-04-14)
------------------
Fix
~~~
- Repo casing refs NOISSUE. [Simon Diesenreiter]
Other
~~~~~
0.1.3 (2025-04-14)
------------------

View File

@@ -2,7 +2,7 @@
.PHONY: issetup
issetup:
@[ -f .git/hooks/commit-msg ] || [ -v SKIP_MAKE_SETUP_CHECK ] || (echo "You must run 'make setup' first to initialize the repo!" && exit 1)
@[ -f .git/hooks/commit-msg ] || [ $SKIP_MAKE_SETUP_CHECK = "true" ] || (echo "You must run 'make setup' first to initialize the repo!" && exit 1)
.PHONY: setup
setup:

View File

@@ -1,11 +1,11 @@
<?xml version="1.0" encoding="utf-8"?>
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<packageSources>
<!--To inherit the global NuGet package sources remove the <clear/> line below -->
<clear />
<add key="nuget" value="https://api.nuget.org/v3/index.json" />
<!--add key="gitea-projects" value="https://git.disi.dev/api/packages/Projects/nuget/index.json" />
<add key="gitea-homelab" value="https://git.disi.dev/api/packages/Homelab/nuget/index.json" />
<add key="gitea-artifacts" value="https://git.disi.dev/api/packages/Artifacts/nuget/index.json" /-->
<!--add key="gitea-projects" value="https://git.disi.dev/api/packages/Projects/nuget/index.json" /-->
<!--add key="gitea-artifacts" value="https://git.disi.dev/api/packages/Artifacts/nuget/index.json" /-->
<add key="HomeLab" value="https://git.disi.dev/api/packages/HomeLab/nuget/index.json" />
</packageSources>
</configuration>
</configuration>

View File

@@ -9,6 +9,7 @@ SignalIntegration.Instance = new SignalIntegration(AppConfiguration.Instance.Sig
var builder = WebApplication.CreateBuilder(args);
Console.WriteLine("Setting up user check timer");
var userCheckTimer = new CronTimer("*/1 * * * *", "Europe/Vienna", includingSeconds: false);
userCheckTimer.OnOccurence += async (s, ea) =>
{
@@ -17,6 +18,7 @@ userCheckTimer.OnOccurence += async (s, ea) =>
var needsSaving = false;
foreach (var memberId in memberList)
{
Console.WriteLine("found member: " + memberId);
var foundUser = dci.Users.Where(u => u.SignalMemberId == memberId).SingleOrDefault();
if (foundUser == null)
{
@@ -43,6 +45,7 @@ userCheckTimer.OnOccurence += async (s, ea) =>
};
userCheckTimer.Start();
Console.WriteLine("Setting up user intro timer");
var userIntroTimer = new CronTimer("*/1 * * * *", "Europe/Vienna", includingSeconds: false);
userIntroTimer.OnOccurence += async (s, ea) =>
{
@@ -64,6 +67,8 @@ userIntroTimer.OnOccurence += async (s, ea) =>
};
userIntroTimer.Start();
Console.WriteLine("Setting up pick of the day timer");
var pickOfTheDayTimer = new CronTimer("0 8 * * *", "Europe/Vienna", includingSeconds: false);
pickOfTheDayTimer.OnOccurence += async (s, ea) =>
{

View File

@@ -1 +1 @@
0.1.3
0.1.17

View File

@@ -16,9 +16,12 @@
<PackageReference Include="Npgsql.EntityFrameworkCore.PostgreSQL" Version="9.0.4" />
<PackageReference Include="NSwag.ApiDescription.Client" Version="13.0.5" />
<PackageReference Include="Scalar.AspNetCore" Version="2.1.*" />
<PackageReference Include="CronTimer" Version="2.0.0" />
<PackageReference Include="CronTimer" Version="2.0.1" />
</ItemGroup>
<ItemGroup>
<OpenApiReference Include="swagger.json" SourceUrl="https://bbernhard.github.io/signal-cli-rest-api/src/docs/swagger.json" />
</ItemGroup>
<ItemGroup>
<ProjectReference Include="..\CronTimer\CronTimer.csproj" />
</ItemGroup>
</Project>