InvvardDev.Ifttt
0.1.14-alpha1
Prefix Reserved
dotnet add package InvvardDev.Ifttt --version 0.1.14-alpha1
NuGet\Install-Package InvvardDev.Ifttt -Version 0.1.14-alpha1
<PackageReference Include="InvvardDev.Ifttt" Version="0.1.14-alpha1" />
paket add InvvardDev.Ifttt --version 0.1.14-alpha1
#r "nuget: InvvardDev.Ifttt, 0.1.14-alpha1"
// Install InvvardDev.Ifttt as a Cake Addin #addin nuget:?package=InvvardDev.Ifttt&version=0.1.14-alpha1&prerelease // Install InvvardDev.Ifttt as a Cake Tool #tool nuget:?package=InvvardDev.Ifttt&version=0.1.14-alpha1&prerelease
IFTTT.NET: Simplifying IFTTT integration for .NET Developers
IFTTT.NET is a powerful .NET library designed to streamline your interaction with the IFTTT platform. Whether you're building web applications, services, or IoT solutions, our toolkit empowers you to seamlessly integrate IFTTT into your projects.
Why Use IFTTT.NET?
- Boilerplate-Free: Say goodbye to repetitive code! Our library abstracts away the complexities of IFTTT integration, allowing you to focus on what matters most.
- Minimal Effort: Get started quickly. IFTTT.NET simplifies the process of setting up triggers, actions, and applets.
- Modern API: We've designed IFTTT.NET to be intuitive and easy to use.
Getting Started
TL;DR
Go to the Samples folder and check out the sample projects.
Setup an IFTTT Trigger
Install package: Add our NuGet package InvvardDev.Ifttt to your project.
Create a Trigger class: add a class implementing the
ITrigger
interface with the TriggerAttribute on top. This will allow IFTTT.NET to find, recognize and handle your Trigger:[Trigger("trigger_slug")] public class YourNewTrigger : ITrigger { [DataField("trigger_field_slug")] public string YourTriggerFieldName { get; init; } = default!; public Task ExecuteAsync(TriggerRequest triggerRequest, CancellationToken cancellationToken = default) { // Your trigger logic goes here return Task.CompletedTask; } }
The
TriggerAttribute
is used to define the Trigger slug. TheDataFieldAttribute
is used to define the Trigger field slug.
TheExecuteAsync
method is the entry point for your Trigger logic. It will be called by IFTTT.NET when the Trigger is activated.Add the test setup: one of the mandatory step for publishing an IFTTT service is to have a test setup endpoint.
Just add a class implementing theITestSetup
interface.public class TestSetup : ITestSetup { public Task<ProcessorPayload> PrepareSetupListing() { var processors = new ProcessorPayload { Triggers = new Processors() }; processors.Triggers .AddProcessor("trigger_slug") .AddDataField("trigger_slug", "trigger_field_slug", "some_value"); return Task.FromResult(processors); } }
The
PrepareSetupListing
method is used to define the test setup payload. It will be called by IFTTT.NET when the test setup endpoint is called.
You can find the complete list of required Triggers, actions and queries in your service dashboard, under theAPI
tab,Endpoint tests
section,Test setup
tab and click on either "View or Download a scaffold JSON response for your service".Configure startup: In your application startup logic, configure the IFTTT.NET client:
var builder = WebApplication.CreateBuilder(args); builder.Services .AddIftttToolkit("<your-service-key>") .AddTestSetupService<TestSetup>() .AddTriggerAutoMapper() .AddTriggers(); var app = builder.Build(); app.ConfigureIftttToolkit() .UseServiceKeyAuthentication() .ConfigureTriggers(); app.Run();
Run your application: That's it! Your Trigger is now ready to be used in IFTTT Applets.
Swagger support
Swagger is a good way to test your Triggers and Actions. Just add the AddSwaggerGen
and UseSwagger
methods to your application startup logic (see step 4).
builder.Services.AddSwaggerGen();
[...]
app.UseSwagger().UseSwaggerUI();
In the event that you want to run Swagger with the Service Key Authentication activated, configure SwaggerGen like this:
builder.Services.AddSwaggerGen(options => options.AddIftttServiceKeyScheme());
It will add a new security scheme to the Swagger UI, allowing you to test your Triggers and actions with the Service Key Authentication.
Real time notifications
Next, you can use the real time notification feature to make your Trigger more responsive.
When you have a new data to send to IFTTT, prepare your Trigger identities or User IDs and call ITriggerHook.SendNotification
.
Here is an example of a controller sending a notification to IFTTT with Trigger identities:
[ApiController]
[Route("api/[controller]")]
public class RealTimeNotificationController(ITriggerHook realTimeHook) : ControllerBase
{
[HttpPost]
public async Task NotifyAsync(CancellationToken cancellationToken = default)
{
var notificationRequest = new List<RealTimeNotificationModel>
{
RealTimeNotificationModel.CreateTriggerIdentity("trigger_identity_12345"),
RealTimeNotificationModel.CreateTriggerIdentity("trigger_identity_67890"),
};
await realTimeHook.SendNotification(notificationRequest, cancellationToken);
}
}
If you use User IDs, just call RealTimeNotificationModel.CreateUserId("<user_id>")
instead of RealTimeNotificationModel.CreateTriggerIdentity("<trigger_identity>")
.
Roadmap
As of today, the library is still in its early stages and only supports Triggers, basic Data field and Service Key Authentication. We are working on adding support for Data field validation, User Authenticated integration and other advanced features .
Fortunately, IFTTT is designed in such a way that once Triggers are implemented, Actions and Queries should be easy to implement.
Contributing
Check the contributing introduction.
Glossary
As IFTTT is designed in a way that Trigger, Action and Query have a common structure.
So in order to be as generic as possible, here are some definitions of the terms used in the library:
- Processor: refers to a Trigger, an Action or a Query.
- Data field: a field that is used to pass data to or from a Trigger, an Action or a Query.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. 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 is compatible. 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. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
-
net6.0
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 8.0.0)
- Microsoft.Extensions.DependencyModel (>= 8.0.0)
- Swashbuckle.AspNetCore.SwaggerGen (>= 6.5.0)
-
net7.0
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 8.0.0)
- Microsoft.Extensions.DependencyModel (>= 8.0.0)
- Swashbuckle.AspNetCore.SwaggerGen (>= 6.5.0)
-
net8.0
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 8.0.0)
- Microsoft.Extensions.DependencyModel (>= 8.0.0)
- Swashbuckle.AspNetCore.SwaggerGen (>= 6.5.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
0.1.14-alpha1 | 83 | 7/15/2024 |
0.1.13 | 108 | 7/14/2024 |
0.1.12-alpha2 | 93 | 7/7/2024 |
0.1.12-alpha1 | 92 | 7/7/2024 |
0.1.10-alpha2 | 130 | 6/13/2024 |