Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/russkyc/gumroad-licensing-netstandard

Gumroad license manager for .NET standard
https://github.com/russkyc/gumroad-licensing-netstandard

csharp dotnet dotnet-licensing gumroad gumroad-api gumroad-licensing licensing

Last synced: 2 months ago
JSON representation

Gumroad license manager for .NET standard

Awesome Lists containing this project

README

        



Russkyc.GumroadLicensing.NetStandard


Nuget





This is a managed .NET client for license validation using the Gumroad API. Making Gumroad license key validation for .NET easier to implement.

## Setup

```csharp
// Imports
using Russkyc.GumroadLicensing.NetStandard;

// !important
// Initialize licensing using product key
// before calling any GetLicenseInfo or ValidateLicense
GumroadLicensing.Initialize("");
```

### Get License Information

This can be used to get license information from the gumroad api. Do note the following:

- This does not perform license validation.
- This does not increment or decrement license uses.
- Use this only if you need to get information regarding a specific license key.

**Code:**

```csharp
var licenseInfo = await GumroadLicensing.GetLicenseInfo("");
```
**Serialized LicenseInfo Object (Class Properties are in PascalCase):**
```json
{
"Success": true,
"LicenseInfo": {
"id": "",
"order_number": "",
"sale_id": "",
"sale_timestamp": "2024-09-22T12:36:37Z",
"created_at": "2024-09-22T12:36:37Z",
"product_id": "",
"product_name": "",
"short_product_id": "",
"permalink": "",
"product_permalink": "https://.gumroad.com/",
"variants": "",
"license_key": "",
"quantity": 1,
"uses": 2,
"price": 1500,
"currency": "usd",
"gumroad_fee": 150,
"email": "@gmail.com",
"purchaser_id": "",
"ip_country": "Philippines",
"seller_id": "",
"refunded": false,
"disputed": false,
"dispute_won": false,
"chargebacked": false,
"is_gift_receiver_purchase": false,
"test": true,
"referrer": "https://app.gumroad.com/",
"can_contact": true,
"discover_fee_charged": false
},
"Message": null
}
```

### Validate License

This can be used to verify licenses using the gumroad api. Do note the following:

- This performs license validation only and does not return any additional information except seats and uses.
- Validation fails if the license has been refunded.
- By default, the behavior is set to validate seats and increment the use per validation. If the use is equal to the seats then the validation will fail unless seat validation is disabled.
- If subscription validation is enabled, it will also check if the subscription has been cancelled or expired.
- Use this only if you need to check license key validity.

**Code:**

```csharp
// Validate License
// Optional Parameters:
// email: default null, validates if provided
// validateSeats: default true (validates uses and seats, does not increment uses if disabled)
// subscription: default true (validates expiration and cancelation of subscription)
var validationInfo = await GumroadLicensing.ValidateLicense("");
```
**Serialized validationInfo Object (Class Properties are in PascalCase):**

```json
{
"Valid": true,
"ValidationInfo": {
"seats": 2,
"uses": 1
},
"Message": null
}
```