Skip to content

JacobLinCool/LeetCode-Query

Repository files navigation

LeetCode Query

The API to get user profiles, submissions, and problems on LeetCode, with highly customizable GraphQL API and Rate Limiter.

Features

Without Authentication

  • Get Public User Profile.
  • Get User's Recent Submissions. (Public, Max: 20)
  • Get User Contest Records. (thanks to @laporchen)
  • Get All of User's Submissions. (Only for leetcode.cn endpoint)
  • Get All Problem List, or with filter of difficulty and tags.
  • Get Problem Detail.
  • Get Daily Challenge.

Authenticated

  • Get All Submissions of The Authenticated User.
  • Get Submission Details, including the code and percentiles.

Other

  • Customable GraphQL Query API.
  • Customable Rate Limiter. (Default: 20 req / 10 sec)
  • Customable Fetcher.

Examples

Get An User's Public Profile

Includes recent submissions and posts.

import { LeetCode } from "leetcode-query";

const leetcode = new LeetCode();
const user = await leetcode.user("username");

/*
// An Example for leetcode.cn endpoint
import { LeetCodeCN } from "leetcode-query";

const leetcodeCN = new LeetCodeCN();
const user = await leetcodeCN.user("leetcode");
*/

Get All Of Your Submissions

import { LeetCode, Credential } from "leetcode-query";

const credential = new Credential();
await credential.init("YOUR-LEETCODE-SESSION-COOKIE");

const leetcode = new LeetCode(credential);
console.log(await leetcode.submissions({ limit: 10, offset: 0 }));

Use Custom Fetcher

You can use your own fetcher, for example, fetch through a real browser.

import { LeetCode, fetcher } from "leetcode-query";
import { chromium } from "playwright-extra";
import stealth from "puppeteer-extra-plugin-stealth";

// setup browser
const _browser = chromium.use(stealth()).launch();
const _page = _browser
    .then((browser) => browser.newPage())
    .then(async (page) => {
        await page.goto("https://leetcode.com");
        return page;
    });

// use a custom fetcher
fetcher.set(async (...args) => {
    const page = await _page;

    const res = await page.evaluate(async (args) => {
        const res = await fetch(...args);
        return {
            body: await res.text(),
            status: res.status,
            statusText: res.statusText,
            headers: Object.fromEntries(res.headers),
        };
    }, args);

    return new Response(res.body, res);
});

// use as normal
const lc = new LeetCode();
const daily = await lc.daily();
console.log(daily);
await _browser.then((browser) => browser.close());

Documentation

Documentation for this package is available on https://jacoblincool.github.io/LeetCode-Query/.

Links

About

A LeetCode Query API for TypeScript & JavaScript.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 9

Languages

pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy