MCPcopy Index your code
hub / github.com/sissbruecker/linkding

github.com/sissbruecker/linkding @v1.45.0 sqlite

repository ↗ · DeepWiki ↗ · release v1.45.0 ↗
2,558 symbols 13,419 edges 252 files 37 documented · 1%
README
<a href="https://github.com/sissbruecker/linkding">
    <img src="https://github.com/sissbruecker/linkding/raw/v1.45.0/assets/header.svg" height="50">
</a>

Introduction

linkding is a bookmark manager that you can host yourself. It's designed be to be minimal, fast, and easy to set up using Docker.

The name comes from: - link which is often used as a synonym for URLs and bookmarks in common language - Ding which is German for thing - ...so basically something for managing your links

Feature Overview: - Clean UI optimized for readability - Organize bookmarks with tags - Bulk editing, Markdown notes, read it later functionality - Share bookmarks with other users or guests - Automatically provides titles, descriptions and icons of bookmarked websites - Automatically archive websites, either as local HTML file or on Internet Archive - Import and export bookmarks in Netscape HTML format - Installable as a Progressive Web App (PWA) - Extensions for Firefox and Chrome, as well as a bookmarklet - SSO support via OIDC or authentication proxies - REST API for developing 3rd party apps - Admin panel for user self-service and raw data access

Demo: https://demo.linkding.link/

Screenshot:

Screenshot

Getting Started

The following links help you to get started with linkding: - Install linkding on your own server or check managed hosting options - Install the browser extension - Check out community projects, which include mobile apps, browser extensions, libraries and more

Documentation

The full documentation is now available at linkding.link.

If you want to contribute to the documentation, you can find the source files in the docs folder.

If you want to contribute a community project, feel free to submit a PR.

Contributing

Small improvements, bugfixes and documentation improvements are always welcome. If you want to contribute a larger feature, consider opening an issue first to discuss it. I may choose to ignore PRs for features that don't align with the project's goals or that I don't want to maintain.

Development

The application is built using the Django web framework. You can get started by checking out the excellent Django docs. The bookmarks folder contains the actual bookmark application. Other than that the code should be self-explanatory / standard Django stuff 🙂.

Prerequisites

  • Python 3.13
  • uv
  • Node.js

Setup

Initialize the development environment with:

make init

This sets up a virtual environment using uv, installs NPM dependencies and runs migrations to create the initial database.

Create a user for the frontend:

uv run manage.py createsuperuser --username=joe --email=joe@example.com

Run the frontend build for bundling frontend components with:

make frontend

Then start the Django development server with:

make serve

The frontend is now available under http://localhost:8000

Tests

Run all tests with pytest:

make test

Linting

Run linting with ruff:

make lint

Formatting

Format Python code with ruff, Django templates with djlint, and JavaScript code with prettier:

make format

DevContainers

This repository also supports DevContainers: Open in Remote - Containers

Once checked out, only the following commands are required to get started:

Create a user for the frontend:

uv run manage.py createsuperuser --username=joe --email=joe@example.com

Start the Node.js development server (used for compiling JavaScript components like tag auto-completion) with:

make frontend

Start the Django development server with:

make serve

The frontend is now available under http://localhost:8000

Core symbols most depended-on inside this repo

setup_bookmark
called by 1123
bookmarks/tests/helpers.py
reverse
called by 833
bookmarks/migrations/0007_userprofile.py
get
called by 551
bookmarks/tests/helpers.py
setup_tag
called by 431
bookmarks/tests/helpers.py
get_or_create_test_user
called by 251
bookmarks/tests/helpers.py
post
called by 241
bookmarks/tests/helpers.py
save
called by 217
bookmarks/forms.py
setup_user
called by 162
bookmarks/tests/helpers.py

Shape

Method 1,913
Class 336
Function 290
Route 19

Languages

Python94%
TypeScript6%

Modules by API surface

bookmarks/tests/test_search_query_parser.py182 symbols
bookmarks/tests/test_queries.py105 symbols
bookmarks/tests/test_bookmarks_list_template.py94 symbols
bookmarks/tests/test_bookmarks_api.py78 symbols
bookmarks/tests/test_bookmarks_service.py75 symbols
bookmarks/views/contexts.py63 symbols
bookmarks/tests/test_bookmark_action_view.py60 symbols
bookmarks/tests/test_bookmarks_tasks.py52 symbols
bookmarks/models.py50 symbols
bookmarks/tests/helpers.py44 symbols
bookmarks/tests/test_bookmark_details_modal.py39 symbols
bookmarks/services/search_query_parser.py38 symbols

Dependencies from manifests, versioned

@astrojs/starlight0.37.1 · 1×
@floating-ui/dom1.7.4 · 1×
@hotwired/turbo8.0.6 · 1×
@rollup/plugin-node-resolve16.0.1 · 1×
@rollup/plugin-terser0.4.4 · 1×
@rollup/wasm-node4.13.0 · 1×
astro5.6.1 · 1×
cssnano7.0.6 · 1×
lit3.3.1 · 1×
postcss8.4.45 · 1×
postcss-cli11.0.0 · 1×
postcss-import16.1.0 · 1×

For agents

$ claude mcp add linkding \
  -- python -m otcore.mcp_server <graph>

⬇ download graph artifact