Skip to content

Latest commit

 

History

History
266 lines (188 loc) · 4.73 KB

README.zh-CN.md

File metadata and controls

266 lines (188 loc) · 4.73 KB

furaffinity-api

FurAffinity wrapper for Node.js
npm npm NPM

English | 中文

重要提示: 本项目适用于 Furaffinity 的 现代 风格.

安装

npm install furaffinity-api

APIs

从 4.1.0 开始,你可以通过 lowerCase 来调用任意 API。 (例如,const {login, search} form "furaffinity-api";

Login(a: string, b: string)

使用 cookie 登录 furaffinity

import { Login } from "furaffinity-api";
// or
const { Login } = require("furaffinity-api");

// to allow all results to be accessible, add your cookies
Login("cookie_a", "cookie_b");

Search(query: string, options: SearchOptions)

搜索作品

import { Search, Type } from 'furaffinity-api';

Search('search query', { /** SearchOptions */ type?, rating?, page? }).then(res => {
  // 结果
  res[0].getSubmission().then(submission => {
    // 作品详情
  });
});

Browse(options?: BrowseOptions)

获取浏览页作品

import { Browse } from "furaffinity-api";

Browse({
  /** BrowseOptions */
}).then((res) => {
  // 结果
  res[0].getSubmission().then((submission) => {
    // 作品详情
  });
});

Submission(id: string)

获取特定的作品

import { Submission } from "furaffinity-api";

Submission("1234567890").then((res) => {
  // res is a Submission
});

User()

获取当前用户信息

import { User } from "furaffinity-api";

User().then((user) => {
  // console.log(user);
});

Author(id: string)

获取某个作者的用户信息

import { Author, WatchingList } from "furaffinity-api";

Author("user_id").then((res) => {
  // 某作者信息
  // 包含 id, name, url and avatar(可能为 undefined)
  WatchingList(res.id).then((list) => {
    // 查询该作者的关注列表
  });
});

Gallery(id: string)

获取某用户的画廊

import { Gallery } from "furaffinity-api";

Gallery("author_id").then((res) => {
  // 结果
  res[0].getSubmission().then((submission) => {
    // 作品详情
  });
});

Scraps(id: string)

获取某用户废弃作品

import { Scraps } from "furaffinity-api";

Scraps("author_id").then((res) => {
  // 结果
  res[0].getSubmission().then((submission) => {
    // 作品详情
  });
});

Submissions()

根据时间线,获取作品详情

import { Submissions } from "furaffinity-api";

Submissions().then((res) => {
  // 结果
  res[0].getSubmission().then((submission) => {
    // 某条作品详情
  });
});

WatchingList(id: string)

获取某用户的关注列表(暂不能获取头像)

import { WatchingList } from "furaffinity-api";

WatchingList("author_id").then((list) => {
  // 作者列表
});

MyWatchingList()

Login first 获取当前登录用户的关注列表(暂不能获取头像)

import { MyWatchingList } from "furaffinity-api";

MyWatchingList().then((list) => {
  // 作者列表
});

removeFromInbox()

Login first 从时间线中移除作品:

import { removeFromInbox } from "furaffinity-api";

removeFromInbox(['viewId', 'viewId']);

watchAuthor()

Login first 关注一个用户,如果已关注则无效果:

import { watchAuthor } from "furaffinity-api";

watchAuthor('userId');

unwatchAuthor()

Login first 取消关注一个用户,如果未关注则无效果:

import { unwatchAuthor } from "furaffinity-api";

unwatchAuthor('userId');

toggleWatch()

Login first 请求 IAuthor 上拿到的 watchLink,用来切换关注状态:

import { toggleWatch } from "furaffinity-api";

toggleWatch('https://www.furaffinity.net/watch/userid/?key=033d7e8f2860f80850557df7ed99120ac9f926e3');

测试

在测试前,先在 /tests/jest.config.ts 中添加配置:

export const options: ITestConfig = {
  loginOptions: {
    cookieA: "your cookie a", // your cookies
    cookieB: "your cookie b"
  },
  watchOptions: {
    userId: "your userid",
    shouldContainUserId: "userid you are watching"
  },
  authorOptions: {
    userId: "your favorite author's userid"
  }
};

接着运行:

npm run test

鸣谢

License

ISC