DeviantArtFs 0.6.0
See the version list below for details.
dotnet add package DeviantArtFs --version 0.6.0
NuGet\Install-Package DeviantArtFs -Version 0.6.0
<PackageReference Include="DeviantArtFs" Version="0.6.0" />
paket add DeviantArtFs --version 0.6.0
#r "nuget: DeviantArtFs, 0.6.0"
// Install DeviantArtFs as a Cake Addin #addin nuget:?package=DeviantArtFs&version=0.6.0 // Install DeviantArtFs as a Cake Tool #tool nuget:?package=DeviantArtFs&version=0.6.0
DeviantArtFs
A .NET / F# library to interact with the DeviantArt / Sta.sh API.
If you're using this library in a .NET Framework project and it doesn't run, make sure that the dependencies (FSharp.Core, FSharp.Data, FSharp.Control.AsyncSeq) are installed.
Currently unsupported features
- The following groups of endpoints are not currently implemented:
- Comments
- Feed
- Messages
- Notes
- The "expand" parameter (user.details, user.geo, etc) is not currently supported.
- The "ext_preload" parameter (gallery/folders, collections/folders) is not currently supported.
- The "mature_content" parameter is not currently supported.
Supported endpoints
Browse
- GET /browse/categorytree
- GET /browse/dailydeviations
- GET /browse/hot
- GET /browse/morelikethis
- GET /browse/morelikethis/preview
- GET /browse/newest
- GET /browse/popular
- GET /browse/tags
- GET /browse/tags/search
- GET /browse/undiscovered
- GET /browse/user/journals
Collections
- GET /collections/{folderid}
- GET /collections/folders
- POST /collections/fave
- POST /collections/unfave
- POST /collections/folders/create
- GET /collections/folders/remove/{folderid}
Data
- GET /data/countries
- GET /data/privacy
- GET /data/submission
- GET /data/tos
Deviation
- GET /deviation/{deviationid}
- GET /deviation/content
- GET /deviation/download/{deviationid}
- GET /deviation/embeddedcontent
- GET /deviation/metadata
- GET /deviation/whofaved
Gallery
- GET /gallery/gallery/{folderid}
- GET /gallery/all
- GET /gallery/folders
- POST /gallery/folders/create
- GET /gallery/folders/remove/{folderid}
Stash
- GET /stash/{stackid}
- GET /stash/{stackid}/contents
- POST /stash/delete
- GET /stash/delta
- GET /stash/item/{itemid}
- POST /stash/move/{stackid}
- POST /stash/position/{stackid}
- POST /stash/publish
- GET /stash/publish/categorytree
- GET /stash/publish/userdata
- GET /stash/space
- POST /stash/submit
- POST /stash/update/{stackid}
The DeviantArt.Stash.Marshal library provides a StashRoot object that can process delta entries.
User
- GET /user/damntoken
- GET /user/friends/{username}
- GET /user/friends/search
- GET /user/friends/unwatch/{username}
- POST /user/friends/watch/{username}
- GET /user/friends/watching/{username}
- GET /user/profile/{username}
- POST /user/profile/update
- GET /user/statuses
- GET /user/statuses/{statusid}
- POST /user/statuses/post
- GET /user/watchers/{username}
- GET /user/whoami
- POST /user/whois
Util
- GET /placebo
Usage
Each request you can make has a module (static class) in one of the DeviantArtFs.Requests namespaces, with AsyncExecute and ExecuteAsync methods. AsyncExecute returns an F# asynchronous workflow, while ExecuteAsync returns a Task<T>.
Some modules also have the methods ToAsyncSeq (which takes a request and offset and wraps the results using FSharp.Control.AsyncSeq) or ToArrayAsync (which takes a request and optionally an offset and/or limit and compiles an array.)
The methods sometimes vary in their response objects as well; AsyncExecute
and ToAsyncSeq will typically return a class or interface that uses option
types to represent fields that may or may not exist, while ExecuteAsync and
ToArrayAsync will return an interface that uses nullable reference types (or
Nullable<T>) for such fields. In many cases, the return object is actually the
same, even when the type is different. For example, the Deviation class has
a property named Excerpt of type string option
, but it also implements the
interface IBclDeviation, which has a Excerpt property of type string
that
can also be null. ("Bcl" stands for Base Class Library - these interfaces are
designed to be used from other .NET languages outside F#.)
Example (C#):
var list = new List<IBclDeviation>();
int offset = 0;
while (true) {
var req = new DeviantArtFs.Requests.Gallery.GalleryAllViewRequest();
var paging = new PagingParams {
Offset = offset,
Limit = 24
};
IBclDeviantArtPagedResult<IBclDeviation> resp =
await DeviantArtFs.Requests.Gallery.GalleryAllView.ExecuteAsync(token, paging, req);
list.AddRange(resp.Results);
offset = resp.NextOffset ?? 0;
if (!resp.HasMore) break;
}
Example (F#):
let list = new ResizeArray<Deviation>()
let mutable offset = 0
let mutable more = true
while more do
let req = new DeviantArtFs.Requests.Gallery.GalleryAllViewRequest()
let paging = new PagingParams(Offset = 0, Limit = Nullable 24)
let! (resp: DeviantArtPagedResult<Deviation>) = DeviantArtFs.Requests.Gallery.GalleryAllView.AsyncExecute token paging req
list.AddRange(resp.Results)
offset <- resp.NextOffset |> Option.defaultValue 0
more <- resp.HasMore
Note how the result from AsyncExecute is DeviantArtPagedResult
, which has a NextOffset field of int option
,
while the result from ExecuteAsync is IBclDeviantArtPagedResult
, which has a NextOffset field of int?
.
See ENDPOINTS.md for more information.
Authentication
See also: https://www.deviantart.com/developers/authentication
Both Authorization Code (recommended) and Implicit grant types are supported. If you are writing a Windows desktop application, you can use the forms in the DeviantArtFs.WinForms package to get a code or token from the user.
The DeviantArtAuth class provides methods to support the Authorization Code grant type (getting tokens from an authorization code and refreshing tokens).
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. 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. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- FSharp.Control.AsyncSeq (>= 2.0.21)
- FSharp.Core (>= 4.5.4)
- FSharp.Data (>= 3.0.0)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on DeviantArtFs:
Package | Downloads |
---|---|
DeviantArtFs.Stash.Marshal
An F#/.NET library to interact with the Sta.sh API and manage state (.NET Standard 2.0) |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
11.0.0 | 87 | 10/28/2024 |
11.0.0-beta2 | 70 | 10/28/2024 |
10.1.0-beta2 | 92 | 10/20/2024 |
10.1.0-beta1 | 76 | 9/21/2024 |
10.0.0 | 125 | 8/8/2024 |
10.0.0-rc1 | 98 | 8/8/2024 |
9.2.1-rc1 | 82 | 8/7/2024 |
9.2.0 | 111 | 6/19/2024 |
9.2.0-beta1 | 97 | 6/19/2024 |
9.1.1 | 123 | 4/27/2024 |
9.1.0-rc1 | 213 | 11/27/2023 |
9.0.0 | 274 | 11/22/2023 |
9.0.0-beta4 | 145 | 5/30/2023 |
9.0.0-beta2 | 111 | 5/28/2023 |
8.0.0 | 466 | 5/30/2021 |
8.0.0-beta4 | 283 | 5/30/2021 |
8.0.0-beta3 | 337 | 5/30/2021 |
8.0.0-beta2 | 238 | 5/30/2021 |
7.0.1 | 405 | 1/11/2021 |
7.0.0 | 384 | 1/9/2021 |
7.0.0-beta1 | 296 | 1/9/2021 |
6.0.2 | 369 | 1/5/2021 |
6.0.1 | 435 | 12/28/2020 |
6.0.0 | 346 | 12/27/2020 |
6.0.0-beta2 | 331 | 12/26/2020 |
6.0.0-beta1 | 323 | 12/26/2020 |
5.0.0 | 520 | 2/11/2020 |
5.0.0-beta1 | 438 | 2/11/2020 |
4.0.0 | 506 | 1/23/2020 |
4.0.0-beta2 | 453 | 1/23/2020 |
4.0.0-beta1 | 462 | 1/22/2020 |
3.0.0 | 555 | 1/17/2020 |
2.2.0 | 558 | 1/6/2020 |
2.1.0 | 534 | 9/9/2019 |
2.0.0-beta3 | 507 | 3/9/2019 |
2.0.0-beta2 | 486 | 3/8/2019 |
2.0.0-beta1 | 481 | 3/6/2019 |
1.1.0-beta1 | 476 | 3/5/2019 |
1.0.0 | 703 | 2/10/2019 |
0.9.0 | 1,352 | 1/29/2019 |
0.8.0 | 695 | 1/28/2019 |
0.7.3 | 717 | 1/22/2019 |
0.7.2 | 696 | 1/22/2019 |
0.7.1 | 1,359 | 1/19/2019 |
0.7.0 | 731 | 1/18/2019 |
0.6.0 | 1,391 | 1/14/2019 |
0.5.0 | 1,361 | 1/11/2019 |
0.4.0 | 1,383 | 1/3/2019 |
0.3.0 | 1,386 | 12/31/2018 |
0.2.0-alpha | 1,185 | 12/27/2018 |
0.1.0-alpha | 621 | 12/21/2018 |
0.6.0: Refactoring (return types with F#-style fields for F#-style methods, and .NET-style fields for .NET-style methods)