Skip to content
This repository has been archived by the owner on Jun 1, 2023. It is now read-only.

Hertizch/SonarrSharp

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

59 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

SonarrSharp

C# Sonarr API wrapper.

This project is atm. not actively developed!

Compatibility

Written as a .NET Standard library, so should be compatible with .NET framework, .NET core and Xamarin.

Installation

Available as a NuGet package:

PM> Install-Package SonarrSharp

Known Issues

  • Please tell me! :)

Usage

These are some examples on how to use the API. All methods are async/awaitable. Most methods includes help text on what they do. If you need more information on how the various endpoints works, visit https://github.com/Sonarr/Sonarr/wiki/API.

Create the client:

var sonarrClient = new SonarrClient("127.0.0.1", 8989, "apiKey");

Get all series:

var series = await sonarrClient.Series.GetSeries();
foreach (var item in series)
{
    Console.WriteLine($"{item.Title}");
}

Get all episodes in a series:

var episodes = await sonarrClient.Episode.GetEpisodes(123);
foreach (var item in episodes)
{
    Console.WriteLine($"s{item.SeasonNumber}e{item.EpisodeNumber} - {item.Title}");
}

Get all episodes airing in the next 30 days:

var calendar = await sonarrClient.Calendar.GetCalendar(DateTime.Now, DateTime.Now.AddDays(30));
foreach (var item in calendar)
{
    Console.WriteLine($"{item.AirDate}: {item.Series.Title} - s{item.SeasonNumber}e{item.EpisodeNumber} - {item.Title}");
}

Search for all episodes in a series:

var command = await.sonarrClient.Command.SeriesSearch(123);

// Get status of this started command
Console.WriteLine($"{command.Name}: {command.State}");