Lu.Ma 1.0.5

dotnet add package Lu.Ma --version 1.0.5                
NuGet\Install-Package Lu.Ma -Version 1.0.5                
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="Lu.Ma" Version="1.0.5" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Lu.Ma --version 1.0.5                
#r "nuget: Lu.Ma, 1.0.5"                
#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 Lu.Ma as a Cake Addin
#addin nuget:?package=Lu.Ma&version=1.0.5

// Install Lu.Ma as a Cake Tool
#tool nuget:?package=Lu.Ma&version=1.0.5                

PathCat Icon

Lu.Ma ✨

NuGet Badge

Welcome to the unofficial Lu.Ma .NET SDK! This SDK is designed to provide a seamless way to interact with the Lu.Ma API, allowing you to manage events and calendars programmatically. The SDK is available under the MIT license, and contributions are welcome.

Overview

The Lu.Ma .NET SDK offers two primary classes that developers will interact with:

  • CalendarManager
  • EventManager

These classes provide methods to create, update, and manage events and calendars on Lu.Ma.

Getting Started

Installation

To get started with the Lu.Ma .NET SDK, you can download the package from NuGet.

dotnet add package Lu.Ma

Setting Up Dependency Injection

To use the Lu.Ma SDK with dependency injection in your .NET application, you need to configure your services. Here’s how you can do it:

  1. Add the necessary services to your Startup.cs or Program.cs.
public void ConfigureServices(IServiceCollection services)
{
    services.AddLuMa(options =>
    {
        options.ApiKey = "YOUR_API_KEY";
    });

    // Other service configurations...
}

You can find the ServiceCollectionExtensions class here.

Supported API Functions

Lu.Ma.EventManager Class

Function Required Parameters Description Return Type DOC URL
CreateEventAsync CreateEventRequest request Create an event under your Luma account Task<CreateEventResponse> Create Event
GetEventAsync string apiId Get details about an event you are a host of Task<GetEventResponse> Get Event
GetEventGuestsAsync string eventApiId, string? approvalStatus = null, string? sortColumn = null, string? sortDirection = null Get list of guests who have registered or been invited to an event IAsyncEnumerable<EventEntry> Get Event Guests
UpdateEventAsync UpdateEventRequest request Update attributes on the event Task Update Event
GetEventGuestAsync string eventApiId, string? apiId = null, string? email = null, string? proxyKey = null Get a guest by their Guest API ID, email or Proxy Key Task<EventEntry> Get Event Guest
AddGuestsAsync AddGuestRequest request Add a guest to the event. They will be added with the status "Going" Task Add Guests
UpdateGuestStatusAsync UpdateGuestStatusRequest request Update the status of a guest Task Update Guest Status
AddHostAsync AddHostRequest request Add a host to help you manage the event Task Add Host
CreateCouponAsync CreateCouponRequest request Create a coupon that can be applied to an event Task Create Coupon
UpdateCouponAsync UpdateCouponRequest request Update a coupon on an event Task Update Coupon

Lu.Ma.CalendarManager Class

Function Required Parameters Description Return Type DOC URL
ListEventsAsync DateTime? before = null, DateTime? after = null List all events managed by your calendar IAsyncEnumerable<CalendarEntry> List Events
ImportPeopleAsync ImportPeopleRequest request Import people to your calendar to invite them to events and send them newsletters Task Import People

Usage

Below are examples of how to use the CalendarManager and EventManager classes.

CalendarManager

List Events
var calendarManager = serviceProvider.GetService<CalendarManager>();

await foreach (var eventItem in calendarManager.ListEventsAsync(DateTime.UtcNow.AddMonths(-1), DateTime.UtcNow))
{
    Console.WriteLine($"{eventItem.Name} - {eventItem.StartTime}");
}

EventManager

Create Event
var eventManager = serviceProvider.GetService<EventManager>();
var newEvent = new CreateEventRequest
{
    Name = "Sample Event",
    StartTime = DateTime.UtcNow.AddDays(7),
    EndTime = DateTime.UtcNow.AddDays(7).AddHours(1),
    Description = "This is a sample event created using Lu.Ma SDK."
};

var createdEvent = await eventManager.CreateEventAsync(newEvent);
Console.WriteLine($"Event Created: {createdEvent.Id}");
Get Event Details
var eventId = "EVENT_ID";
var eventDetails = await eventManager.GetEventAsync(eventId);
Console.WriteLine($"Event Name: {eventDetails.Name}");

API Documentation

The Lu.Ma API is a JSON-based RESTful API that allows you to read data and take actions on your Lu.Ma events and guests. For detailed API documentation, visit the Lu.Ma API Docs.

Requirements

Authentication

To authenticate your requests, you'll need an API key. You can generate an API key on your Lu.Ma dashboard.

Here is an example CURL request to check authentication:

curl -X GET https://api.lu.ma/public/v1/event/get \
     -H "x-luma-api-key: YOUR_API_KEY"

License

This SDK is available under the MIT License.

Contributions

Pull requests and contributions are welcome. Please open an issue to discuss any changes before submitting a pull request.

About

For more information about the business and its offerings, visit Lu.Ma.


Thank you for using the Lu.Ma .NET SDK. We look forward to your contributions and feedback!

Product Compatible and additional computed target framework versions.
.NET 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

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
1.0.5 115 7/11/2024
1.0.3 101 7/11/2024
1.0.0 107 7/11/2024

Initial release of the unofficial Lu.Ma .NET SDK with support for managing events and calendars.