A javascript / typescript http and websocket client and type system for Lemmy.
Find a file
2024-09-29 21:03:08 -04:00
.github
.husky
src Post scheduling (#347) 2024-09-24 15:00:49 -04:00
.gitignore
.prettierrc.json
.woodpecker.yml
CHANGELOG.md Updating git cliff. (#361) 2024-09-27 20:24:25 +00:00
cliff.toml Updating git cliff. (#361) 2024-09-27 20:24:25 +00:00
copy_generated_types_from_lemmy.sh Sso support dess (#348) 2024-09-18 09:36:47 -04:00
deploy.sh
eslint.config.mjs Update dependency eslint to v9 (#272) 2024-05-15 13:28:23 -04:00
generate_changelog.sh Adding git cliff to auto-generate changelogs (#350) 2024-09-19 16:28:48 -04:00
LICENSE
package.json Update types from main branch (#356) 2024-09-23 08:39:46 -04:00
pnpm-lock.yaml Update dependency eslint to v9.11.1 2024-09-29 21:03:08 -04:00
putTypesInIndex.js
README.md Better readme example. (#261) 2024-05-04 18:42:51 +00:00
renovate.json Adding renovate schedule. (#325) 2024-08-01 07:08:20 -04:00
tsconfig.json

GitHub tag (latest SemVer) GitHub issues License GitHub stars

lemmy-js-client

A javascript / typescript http client and type system for Lemmy.

Installation

pnpm install lemmy-js-client

Usage

HTTP Client

LemmyHttp docs

import { LemmyHttp, Login } from "lemmy-js-client";

// Build the client
const baseUrl = "https://lemmy.ml";
const client: LemmyHttp = new LemmyHttp(baseUrl);

// Build the login form
const loginForm: Login = {
  username_or_email: "my_name",
  password: "my_pass",
};

// Login and set the client headers with your jwt
const { jwt } = await client.login(loginForm);
client.setHeaders({ Authorization: `Bearer ${jwt}` });

// Fetch top posts for the day
const getPostsForm: GetPosts = {
  sort: "TopDay",
  type_: "Local",
};
const posts = await client.getPosts(getPostsForm);

Development

Use pnpm add to develop and test changes locally:

pnpm add path/to/lemmy-js-client