6 Commits

Author SHA1 Message Date
c1e7e93ed7 Fix E621 Null 2020-03-28 14:13:17 +00:00
ed236340cd Fix Null Refs with ImageUrl 2020-03-28 13:58:59 +00:00
f2d21dc411 Merge branch 'master' of https://github.com/exsersewo/Booru.Net 2020-03-28 13:14:42 +00:00
7266a2162d Readded DanBooruImage#Score 2020-03-28 13:13:51 +00:00
4e6b8b2de8 Update README.md 2020-03-28 12:40:29 +00:00
f12f9d70a0 Fix visibility of fields 2020-03-28 12:37:29 +00:00
11 changed files with 110 additions and 27 deletions

View File

@@ -3,8 +3,8 @@
<PropertyGroup> <PropertyGroup>
<OutputType>Exe</OutputType> <OutputType>Exe</OutputType>
<TargetFramework>netcoreapp2.1</TargetFramework> <TargetFramework>netcoreapp2.1</TargetFramework>
<AssemblyVersion>2020.3.24.0</AssemblyVersion> <AssemblyVersion>2020.3.29.0</AssemblyVersion>
<FileVersion>2020.3.24.0</FileVersion> <FileVersion>2020.3.29.0</FileVersion>
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>

View File

@@ -32,7 +32,7 @@ namespace Booru.Net.Tests
break; break;
case 1: case 1:
var p = await new E621Client().GetImagesAsync().ConfigureAwait(false); var p = await new E621Client().GetImagesAsync().ConfigureAwait(false);
Console.WriteLine(p.Posts.All(x => x != null)); Console.WriteLine(p.Posts.Any(x => x.ImageUrl != null));
break; break;
case 2: case 2:
posts = await new GelbooruClient().GetImagesAsync().ConfigureAwait(false); posts = await new GelbooruClient().GetImagesAsync().ConfigureAwait(false);
@@ -56,7 +56,7 @@ namespace Booru.Net.Tests
if (posts != null) if (posts != null)
{ {
Console.WriteLine(posts.All(x => x != null)); Console.WriteLine(posts.Any(x => x.ImageUrl != null));
} }
} }
catch(Exception ex) catch(Exception ex)

View File

@@ -24,14 +24,11 @@ Yande.re</Description>
<PackageTags>booru imageboard api wrapper</PackageTags> <PackageTags>booru imageboard api wrapper</PackageTags>
<PackageLicenseUrl></PackageLicenseUrl> <PackageLicenseUrl></PackageLicenseUrl>
<PackageRequireLicenseAcceptance>true</PackageRequireLicenseAcceptance> <PackageRequireLicenseAcceptance>true</PackageRequireLicenseAcceptance>
<Version>2.0.0.0</Version> <Version>2.0.3</Version>
<PackageLicenseFile>LICENSE</PackageLicenseFile> <PackageLicenseFile>LICENSE</PackageLicenseFile>
<AssemblyVersion>2.0.0.0</AssemblyVersion> <AssemblyVersion>2020.3.0.0</AssemblyVersion>
<FileVersion>2.0.0.0</FileVersion> <FileVersion>2020.3.0.0</FileVersion>
<PackageReleaseNotes>⚠ This version is not compatible with 1.0.0.X code ⚠ <PackageReleaseNotes>Fix some null ref issues with images</PackageReleaseNotes>
Wrapper Restructuring &amp; Seperate out each client from the container client
Fix bugs presented from some booru's updating</PackageReleaseNotes>
</PropertyGroup> </PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|AnyCPU'"> <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|AnyCPU'">

View File

@@ -4,7 +4,16 @@ using System.Collections.Generic;
namespace Booru.Net namespace Booru.Net
{ {
public class DanbooruImage : BooruImage public class DanbooruImage : BooruImage
{ {
[JsonProperty("score")]
public int? Score { get; set; }
[JsonProperty("file_url")]
private string FileUrl { get; set; }
public override string ImageUrl
=> FileUrl;
[JsonProperty("tag_string")] [JsonProperty("tag_string")]
private string TagString { get; set; } private string TagString { get; set; }

View File

@@ -12,12 +12,26 @@ namespace Booru.Net
[JsonProperty("directory")] [JsonProperty("directory")]
public string Directory { get; set; } public string Directory { get; set; }
[JsonProperty("file")]
public E621ImageSource File { get; set; }
[JsonProperty("preview")]
public E621ImageSource PreviewImage { get; set; }
[JsonProperty("sample")]
public E621ImageSource SampleImage { get; set; }
[JsonProperty("flags")]
public E621ImageFlags Flags { get; set; }
[JsonProperty("tags")] [JsonProperty("tags")]
[JsonConverter(typeof(TagGroupConverter))] [JsonConverter(typeof(TagGroupConverter))]
private List<Dictionary<string, List<string>>> PTags { get; set; } private List<Dictionary<string, List<string>>> PTags { get; set; }
public IReadOnlyList<Dictionary<string, List<string>>> Tags { get { return PTags.AsReadOnly(); } } public IReadOnlyList<Dictionary<string, List<string>>> Tags { get { return PTags.AsReadOnly(); } }
public override string ImageUrl => File.Url;
public override string PostUrl { get { return "https://e621.net/post/show/" + ID; } } public override string PostUrl { get { return "https://e621.net/post/show/" + ID; } }
} }
} }

View File

@@ -0,0 +1,25 @@
using Newtonsoft.Json;
namespace Booru.Net
{
public class E621ImageFlags
{
[JsonProperty("pending")]
public bool Pending { get; private set; }
[JsonProperty("flagged")]
public bool Flagged { get; private set; }
[JsonProperty("note_locked")]
public bool NoteLocked { get; private set; }
[JsonProperty("status_locked")]
public bool StatusLocked { get; private set; }
[JsonProperty("rating_locked")]
public bool RatingLocked { get; private set; }
[JsonProperty("deleted")]
public bool Deleted { get; private set; }
}
}

View File

@@ -0,0 +1,28 @@
using Newtonsoft.Json;
namespace Booru.Net
{
public class E621ImageSource
{
[JsonProperty("width")]
public int Width { get; private set; }
[JsonProperty("height")]
public int Height { get; private set; }
[JsonProperty("ext")]
public string Extension { get; private set; }
[JsonProperty("size")]
public ulong Size { get; private set; }
[JsonProperty("has")]
public bool Has { get; private set; }
[JsonProperty("md5")]
public string MD5 { get; private set; }
[JsonProperty("url")]
public string Url { get; private set; }
}
}

View File

@@ -8,9 +8,9 @@ namespace Booru.Net
public int Up { get; set; } public int Up { get; set; }
[JsonProperty("down")] [JsonProperty("down")]
private int Down { get; set; } public int Down { get; set; }
[JsonProperty("total")] [JsonProperty("total")]
private int Total { get; set; } public int Total { get; set; }
} }
} }

View File

@@ -11,6 +11,12 @@ namespace Booru.Net
[JsonProperty("directory")] [JsonProperty("directory")]
public string Directory { get; set; } public string Directory { get; set; }
[JsonProperty("file_url")]
private string FileUrl { get; set; }
public override string ImageUrl
=> FileUrl;
[JsonProperty("tags")] [JsonProperty("tags")]
private string Ptags { get; set; } private string Ptags { get; set; }

View File

@@ -10,9 +10,9 @@ namespace Booru.Net
[JsonProperty("rating")] [JsonProperty("rating")]
private string Prating { get; set; } private string Prating { get; set; }
public virtual string ImageUrl { get; set; } public virtual string ImageUrl { get; private set; }
public virtual string PostUrl { get; set; } public virtual string PostUrl { get; private set; }
public Rating Rating public Rating Rating
{ {

View File

@@ -14,9 +14,22 @@ Currently supported Boards are:
# How to get started # How to get started
```cs ```cs
var BooruClient = new BooruClient(); var GelbooruClient = new GelbooruClient();
var posts = await BooruClient.GetGelbooruImagesAsync("aisha_clanclan", "melfina"); var posts = await GelbooruClient.GetImagesAsync("aisha_clanclan", "melfina");
if(posts != null)
{
...
}
List<string> tags = new List<string>
{
"aisha_clanclan",
"melfina"
};
posts = await GelbooruClient.GetImagesAsync(tags);
if(posts != null) if(posts != null)
{ {
@@ -24,14 +37,5 @@ if(posts != null)
} }
``` ```
List of Methods in Wrapper:
- `GetGelbooruImagesAsync(IEnumerable<string> tags)`
- `GetDanbooruImagesAsync(IEnumerable<string> tags)`
- `GetRule34ImagesAsync(IEnumerable<string> tags)`
- `GetE621ImagesAsync(IEnumerable<string> tags)`
- `GetKonaChanImagesAsync(IEnumerable<string> tags)`
- `GetYandereImagesAsync(IEnumerable<string> tags)`
- `GetRealBooruImagesAsync(IEnumerable<string> tags)`
# Contributing # Contributing
If you wish to add more booru's to the wrapper/make the code better/optimise the code, please fork your own version and pull-request it. If you are planning on adding another booru to the wrapper, please do it in a similar style to the currently existing methods. If you wish to add more booru's to the wrapper/make the code better/optimise the code, please fork your own version and pull-request it. If you are planning on adding another booru to the wrapper, please do it in a similar style to the currently existing methods.