Imouto.BooruParser 2.0.4

There is a newer version of this package available.
See the version list below for details.
dotnet add package Imouto.BooruParser --version 2.0.4                
NuGet\Install-Package Imouto.BooruParser -Version 2.0.4                
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="Imouto.BooruParser" Version="2.0.4" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Imouto.BooruParser --version 2.0.4                
#r "nuget: Imouto.BooruParser, 2.0.4"                
#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 Imouto.BooruParser as a Cake Addin
#addin nuget:?package=Imouto.BooruParser&version=2.0.4

// Install Imouto.BooruParser as a Cake Tool
#tool nuget:?package=Imouto.BooruParser&version=2.0.4                

Imouto.BooruParser

NuGet license

The dotnet library for retrieving info from booru sites (chan.sankakucomplex.com, danbooru.donmai.us, yande.re, gelbooru.com). You can get individual posts, tags/notes history, and search by tags. Install as NuGet package:

Install-Package Imouto.BooruParser
<PackageReference Include="Imouto.BooruParser" Version="2.0.0" />

Version 2.0 released!

The new version of this library has been released. It's a complete rewrite and has a lot of breaking changes. Please don't update unless you're ready to spent some time in refactoring and reading.

The new version has gelbooru as partly supported booru. It doesn't provide a way to get tags or notes history, but you can search and retrieve posts by id or md5. To consume this library you should use IBooruApiLoader interface. The library provides following implementations, one for each booru:

var loader = new DanbooruApiLoader(...);
var loader = new YandereApiLoader(...);
var loader = new SankakuApiLoader(...);
var loader = new GelbooruApiLoader(...);

The recommended way to consume them is to regiter them in your container:

services.AddBooruParsers();

// OPTIONAL
// It'ts nessesary for Sankaku auth management. 
// You can skip it, if you don't plan to access sankaku with authorization.
services.AddMemoryCache();

But you can also register them yourself. You also need to provide configuration for booru if you want to have more relaxed limits:

services.Configure<DanbooruSettings>(Configuration.GetSection("Danbooru"));
services.Configure<GelbooruSettings>(Configuration.GetSection("Gelbooru"));
services.Configure<SankakuSettings>(Configuration.GetSection("Sankaku"));
services.Configure<YandereSettings>(Configuration.GetSection("Yandere"));

Each settings has PauseBetweenRequestsInMs param which defines a pause between requests. 0 means you can run your requests in parallel and any positive number means that all requests would be called with the provided pause in ms between them. It's important to have some reserves to not get banned.

! Sankaku is a difficult case for the authorization. It requires access and refresh tokens (you can extract them from cookies), but refresh token has to be updated. So SankakuSettings has a callback method SaveTokensCallbackAsync that will be called, when it's necessary to update refresh and access tokens. It's you responsibility to store them somewhere and pass on the next application start.

Simplest usage

var loader = new DanbooruApiLoader(
    new PerBaseUrlFlurlClientFactory(), 
    Options.Create(new DanbooruSettings()))
    
var post = await loader.GetPostAsync(5628013);
Console.WriteLine(post.Md5);

Version 1.x.x

Simplest usage

var username = "user";~~~~
var apiKey = "HBArbAk4WcKTSeAfsyBO";
var delayBetweenRequestsInMs = 1240;

var danbooruLoader = new DanbooruLoader(username, apiKey, delayBetweenRequestsInMs);
var post = await danbooruLoader.LoadPostAsync(5628013);
Console.WriteLine(post.Md5);
Product 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.

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
3.4.1 162 5/20/2024
3.4.0 131 4/21/2024
3.3.0 146 1/25/2024
3.2.10 150 1/9/2024
3.2.9 221 12/6/2023
3.2.8 162 11/24/2023
3.2.7 194 10/29/2023
3.2.6 197 10/13/2023
3.2.5 173 10/3/2023
3.2.4 178 10/3/2023
3.2.3 164 10/2/2023
3.1.0 300 6/18/2023
3.0.2 198 6/5/2023
3.0.1 162 2/17/2023
2.0.6 166 12/28/2022
2.0.4 122 11/2/2022
2.0.3 131 10/30/2022
2.0.2 120 10/29/2022
1.18.1 567 9/17/2022
1.17.6 520 9/15/2022
1.17.5 487 9/15/2022
1.17.4 498 9/15/2022
1.17.3 498 9/15/2022
1.17.2 509 9/15/2022
1.17.1 511 9/15/2022
1.17.0 489 9/15/2022
1.16.1 500 9/8/2022
1.15.0 505 5/30/2022
1.14.1 515 5/2/2022
1.14.0 376 1/13/2022
1.13.0 352 1/11/2022
1.12.0 555 1/3/2021
1.11.0 658 5/2/2020
1.10.0 562 4/25/2020
1.9.0 776 2/7/2020
1.8.0 605 1/30/2020
1.7.0 652 12/3/2019
1.6.0 695 8/25/2019
1.5.0 636 8/25/2019
1.4.0 637 8/25/2019
1.3.0 712 3/16/2019
1.2.0 1,214 3/26/2018
1.1.0 1,107 3/25/2018
1.0.1 1,097 1/22/2018
1.0.0 1,145 9/15/2017