Imouto.BooruParser
4.0.3
dotnet add package Imouto.BooruParser --version 4.0.3
NuGet\Install-Package Imouto.BooruParser -Version 4.0.3
<PackageReference Include="Imouto.BooruParser" Version="4.0.3" />
paket add Imouto.BooruParser --version 4.0.3
#r "nuget: Imouto.BooruParser, 4.0.3"
// Install Imouto.BooruParser as a Cake Addin #addin nuget:?package=Imouto.BooruParser&version=4.0.3 // Install Imouto.BooruParser as a Cake Tool #tool nuget:?package=Imouto.BooruParser&version=4.0.3
Imouto.BooruParser
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="4.*" />
Version 4.0.0
- I'm bumping the major version due to changes in the public API. Sankaku now uses string Ids for various entities, and we have to adjust for it. Most public API types now have a string Id parameter.
- Technical: FluentAssertion has been replaced with AwesomeAssertions, you know why.
- Technical: Flurl has been upgraded to version 4, it has some breaking changes, but I've adjusted for them, we'll see how it goes.
- Technical: Upgraded to net9.0
Version 3.3.0
- Sankaku is child of devil and was broken once again. Removed old auth chan. part as now all logins goes throw beta.
Version 3.2.0
- Added Rule34, they have a lot of tagged pay-walled staff and I will be using them as tag source for this stuff. No auth is required for now.
- Sankaku was broken once again. This time they changed their auth flow on their old site. PassHash no longer works. Without auth you also can't get all of post tags (only 20 general tags). I fixed it (only god know for how long). You have to provide login and password and it should work.
Version 3.1
Once again sankaku broke everything. It's now recommended to provide login and pass_hash for sankaku in order to receive all tags from posts. Without it you can only get 20 general tags.
Version 3.0
Have to increment major version due to breaking change in danbooru api usage. Now you have to provide your own user agent for your bot in danbooru settings, otherwise danbooru requests would fail with 403 (recent change on their side).
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 register 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 | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net9.0 is compatible. 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. |
-
net9.0
- Flurl.Http (>= 4.0.2)
- HtmlAgilityPack (>= 1.11.72)
- Microsoft.Extensions.Caching.Abstractions (>= 9.0.1)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 9.0.1)
- Microsoft.Extensions.Options.ConfigurationExtensions (>= 9.0.1)
- System.IdentityModel.Tokens.Jwt (>= 8.3.1)
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 |
---|---|---|
4.0.3 | 7 | 1/24/2025 |
4.0.2 | 30 | 1/23/2025 |
3.4.1 | 216 | 5/20/2024 |
3.4.0 | 143 | 4/21/2024 |
3.3.0 | 152 | 1/25/2024 |
3.2.10 | 156 | 1/9/2024 |
3.2.9 | 227 | 12/6/2023 |
3.2.8 | 168 | 11/24/2023 |
3.2.7 | 200 | 10/29/2023 |
3.2.6 | 203 | 10/13/2023 |
3.2.5 | 179 | 10/3/2023 |
3.2.4 | 184 | 10/3/2023 |
3.2.3 | 170 | 10/2/2023 |
3.1.0 | 306 | 6/18/2023 |
3.0.2 | 204 | 6/5/2023 |
3.0.1 | 168 | 2/17/2023 |
2.0.6 | 172 | 12/28/2022 |
2.0.4 | 130 | 11/2/2022 |
2.0.3 | 139 | 10/30/2022 |
2.0.2 | 128 | 10/29/2022 |
1.18.1 | 575 | 9/17/2022 |
1.17.6 | 528 | 9/15/2022 |
1.17.5 | 495 | 9/15/2022 |
1.17.4 | 506 | 9/15/2022 |
1.17.3 | 506 | 9/15/2022 |
1.17.2 | 517 | 9/15/2022 |
1.17.1 | 519 | 9/15/2022 |
1.17.0 | 499 | 9/15/2022 |
1.16.1 | 508 | 9/8/2022 |
1.15.0 | 513 | 5/30/2022 |
1.14.1 | 523 | 5/2/2022 |
1.14.0 | 384 | 1/13/2022 |
1.13.0 | 362 | 1/11/2022 |
1.12.0 | 563 | 1/3/2021 |
1.11.0 | 666 | 5/2/2020 |
1.10.0 | 570 | 4/25/2020 |
1.9.0 | 784 | 2/7/2020 |
1.8.0 | 613 | 1/30/2020 |
1.7.0 | 661 | 12/3/2019 |
1.6.0 | 704 | 8/25/2019 |
1.5.0 | 645 | 8/25/2019 |
1.4.0 | 646 | 8/25/2019 |
1.3.0 | 722 | 3/16/2019 |
1.2.0 | 1,224 | 3/26/2018 |
1.1.0 | 1,117 | 3/25/2018 |
1.0.1 | 1,107 | 1/22/2018 |
1.0.0 | 1,157 | 9/15/2017 |