GHM.Job
2.0.0
There is a newer version of this package available.
See the version list below for details.
See the version list below for details.
dotnet add package GHM.Job --version 2.0.0
NuGet\Install-Package GHM.Job -Version 2.0.0
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="GHM.Job" Version="2.0.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add GHM.Job --version 2.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: GHM.Job, 2.0.0"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install GHM.Job as a Cake Addin #addin nuget:?package=GHM.Job&version=2.0.0 // Install GHM.Job as a Cake Tool #tool nuget:?package=GHM.Job&version=2.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
<p align="center"> <img src="logo.png" alt="logo" width="200px"/> </p>
<h1 align="center"> GHM.Job </h1>
GHM.Job is a nuget package aims to run jobs in separates ways(Get Request, Run Request and Update Request).
Install Package
.NET CLI
dotnet add package GHM.Job
Package Manager
NuGet\Install-Package GHM.Job
Example
To run a Job
The Job Run the Sequence:
- Get Requests Unique or List
- Execute Request
- After Execute Request
- On error Execute Request
- Update Request
- After Update Request
- On error Update Request
- After Work Request
using GHM.Job;
public class MyBackgroundService : BackgroundService
{
private readonly IJobService<string> _jobService = new JobService<string>();
protected override async Task ExecuteAsync(CancellationToken stoppingToken)
{
var result = "processing";
string Requester() => " => data";
string Executer(string data) => result += data + " => Executer";
void Updater(string data) => result += " => Updater";
void AfterWork() => result += " => AfterWork";
void AfterExecuter(string data) => result += " => AfterExecuter";
string LoggerId(string data) => data;
// Act
var job = Job.Create(
requesterUnique: Requester,
executer: Executer,
updater: Updater,
afterWork: AfterWork,
afterExecuter: AfterExecuter,
loggerId: LoggerId
);
// Setting delay: 1 second to the next job running.
await _jobService.ExecuteAsync(job, TimeSpan.FromSeconds(1), stoppingToken);
// Running 1 time.
await _jobService.ExecuteAsync(job, stoppingToken);
// result = "processing => data => Executer => AfterExecuter => Updater => AfterWork"
}
}
You can run your job async.
using GHM.Job;
public class MyBackgroundService : BackgroundService
{
private readonly IJobService<string> _jobService = new JobService<string>();
protected override async Task ExecuteAsync(CancellationToken stoppingToken)
{
var result = "processing";
Task<string> RequesterAsync() => Task.FromResult(" => data");
Task<string> ExecuterAsync(string data) => Task.FromResult(result += data + " => Executer");
Task UpdaterAsync(string data) => Task.FromResult(result += " => Updater");
void AfterWork() => result += " => AfterWork";
void AfterExecuter(string data) => result += " => AfterExecuter";
string LoggerId(string data) => data;
// Act
var job = JobAsync.Create(
requesterUnique: RequesterAsync,
executer: ExecuterAsync,
updater: UpdaterAsync,
afterWork: AfterWork,
afterExecuter: AfterExecuter,
loggerId: LoggerId
);
// Setting delay: 1 second to the next job running.
await _jobService.ExecuteAsync(job, TimeSpan.FromSeconds(1), stoppingToken);
// Running 1 time.
await _jobService.ExecuteAsync(job, stoppingToken);
// result = "processing => data => Executer => AfterExecuter => Updater => AfterWork"
}
}
Classes
IJobService
It is a interface implemented by JobService<TRequest>
namespace GHM.Job;
public class JobService<TRequest> : IJobService<TRequest>
{
public async Task ExecuteAsync<TResponse>(
Job<TRequest, TResponse> job,
TimeSpan interval,
CancellationToken token = default
)
{
while (!token.IsCancellationRequested)
{
await Task.Run(job.DoWork, token);
await Task.Delay(interval, token);
}
}
public async Task ExecuteAsync<TResponse>(Job<TRequest, TResponse> job, CancellationToken token = default)
{
await Task.Run(job.DoWork, token);
}
}
Star
if you enjoy, don't forget the ⭐ and install the package 😊.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net7.0 is compatible. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
net7.0
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.