.NET client for the Paperless-ngx API.
A separate NuGet package is provided for ASP.NET Core (IConfiguration and IServiceCollection) . For use outside of ASP.NET Core, see the example in tests.
-
Add configuration (see options)
"Paperless": { "BaseAddress": "", "Token": "" }
-
Register required services (see tests)
serviceCollection .AddSingleton(DateTimeZoneProviders.Tzdb) .AddPaperlessDotNet(Configuration);
-
Use
IPaperlessClient
to access all endpoints, or one of the specific clients defined inIPaperlessClient
Paperless supports adding custom fields to documents. In order to use custom fields, first define a class with a property for each field:
internal sealed class CustomFields
{
public string? Field1 { get; set; }
public Uri? Field2 { get; set; }
public LocalDate? Field3 { get; set; }
public bool? Field4 { get; set; }
public int? Field5 { get; set; }
public float? Field6 { get; set; }
public float? Field7 { get; set; }
public int[]? Field8 { get; set; }
}
Then create a JsonSerializerContext
with all the API models that use custom fields:
[JsonSerializable(typeof(PaginatedList<Document<CustomFields>>))]
[JsonSerializable(typeof(DocumentUpdate<CustomFields>))]
internal sealed partial class SerializerContext : JsonSerializerContext;
And configure JSON serialization for the client:
serviceCollection.AddPaperlessDotNet(
configuration,
options =>
{
options.Options.Converters.Add(new CustomFieldsConverter<CustomFields>(options));
options.Options.TypeInfoResolverChain.Add(SerializerContext.Default);
});
For a working example see unit tests and integration tests.