A javascript / typescript http and websocket client and type system for Lemmy.
Find a file
renovate[bot] db23cd070d
Update pnpm to v9.1.4 (#274)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-05-31 20:53:47 -04:00
.github
.husky Migrate from yarn to pnpm. (#236) 2024-01-28 22:08:00 -05:00
src Remove pointless integer annotations. #190 (#260) 2024-04-30 06:34:18 -04:00
.gitignore
.prettierrc.json
.woodpecker.yml Fixing npm publish. 2024-03-27 10:38:53 -04:00
copy_generated_types_from_lemmy.sh Remove pointless integer annotations. #190 (#260) 2024-04-30 06:34:18 -04:00
deploy.sh Migrate from yarn to pnpm. (#236) 2024-01-28 22:08:00 -05:00
eslint.config.mjs Update dependency eslint to v9 (#272) 2024-05-15 13:28:23 -04:00
LICENSE
package.json Update pnpm to v9.1.4 (#274) 2024-05-31 20:53:47 -04:00
pnpm-lock.yaml Update dependency eslint to v9 (#272) 2024-05-15 13:28:23 -04:00
putTypesInIndex.js
README.md Better readme example. (#261) 2024-05-04 18:42:51 +00:00
renovate.json Configure Renovate (#263) 2024-05-15 10:10:34 -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