No description
Find a file
2025-12-04 03:04:27 +02:00
.github Trigger build when release branch pushed 2025-11-14 13:08:12 +11:00
.idea Feature: Support Multiple URLs in Studios (#6223) 2025-11-10 14:34:21 +11:00
cmd add lumberjack log rotation (#5696) 2025-11-18 14:04:22 +11:00
docker [packaging] switch to pnpm (#6186) 2025-11-10 09:17:25 +11:00
docs [packaging] switch to pnpm (#6186) 2025-11-10 09:17:25 +11:00
graphql Merge e057b2899b into 39fd8a6550 2025-12-04 03:04:27 +02:00
internal Feature: Manual StashId Search - Tags (#6374) 2025-12-04 11:20:29 +11:00
pkg Merge e057b2899b into 39fd8a6550 2025-12-04 03:04:27 +02:00
scripts Login page internationalisation (#5765) 2025-03-27 11:56:43 +11:00
ui Merge e057b2899b into 39fd8a6550 2025-12-04 03:04:27 +02:00
.dockerignore Improve client-side graphql scalar types (#4511) 2024-02-07 09:49:32 +11:00
.gitattributes Refactor build (#493) 2020-04-29 12:13:08 +10:00
.gitignore Login page internationalisation (#5765) 2025-03-27 11:56:43 +11:00
.golangci.yml Fix lint error 2025-02-18 18:18:48 +11:00
.gqlgenc.yml Upgrade gqlgenc (#5901) 2025-06-03 08:55:51 +10:00
.mockery.yml Model refactor (#3915) 2023-09-01 10:39:29 +10:00
go.mod Bump golang.org/x/crypto from 0.38.0 to 0.45.0 (#6300) 2025-11-28 14:05:19 +11:00
go.sum Bump golang.org/x/crypto from 0.38.0 to 0.45.0 (#6300) 2025-11-28 14:05:19 +11:00
gqlgen.yml Add findFiles and findFile graphql queries (#5941) 2025-06-24 13:05:17 +10:00
LICENSE Add LICENSE until we get all signers on the switch (#297) 2020-01-20 22:18:12 -05:00
Makefile [packaging] switch to pnpm (#6186) 2025-11-10 09:17:25 +11:00
README.md docs: Improve README clarity and formatting 2025-11-28 00:24:06 +02:00
tools.go Update go dependencies (#3480) 2023-02-28 08:26:14 +11:00

Stash

Build Docker pulls GitHub Sponsors Open Collective backers Go Report Card Discord GitHub release (latest by date) GitHub issues by-label

Stash is a self-hosted webapp written in Go which organizes and serves your diverse content collection, catering to both your SFW and NSFW needs.

Screenshot of Stash web application interface

  • Stash gathers information about videos in your collection from the internet, and is extensible through the use of community-built plugins for a large number of content producers and sites.
  • Stash supports a wide variety of both video and image formats.
  • You can tag videos and find them later.
  • Stash provides statistics about performers, tags, studios and more.

You can watch a SFW demo video to see it in action.

For further information you can consult the documentation or access the in-app manual from within the application (also available at docs.stashapp.cc/in-app-manual).

Installing Stash

Step-by-step instructions are available at docs.stashapp.cc/installation.

Windows Users:

As of version 0.27.0, Stash no longer supports Windows 7, 8, Server 2008 and Server 2012.
At least Windows 10 or Server 2016 is required.

Mac Users:

As of version 0.29.0, Stash requires macOS 11 Big Sur or later.
Stash can still be run through docker on older versions of macOS.

Windows macOS Linux Docker
Latest Release
Development Preview
Latest Release
Development Preview
Latest Release (amd64)
Development Preview (amd64)
More Architectures...
Instructions
Sample docker-compose.yml

Download links for other platforms and architectures are available on the Releases page.

First Run

Windows/macOS Users: Security Prompt

On Windows or macOS, running the app might present a security prompt since the application binary isn't yet signed.

  • On Windows, bypass this by clicking "more info" and then the "run anyway" button.
  • On macOS, Control+Click the app, click "Open", and then "Open" again.

ffmpeg

Stash requires FFmpeg. If you don't have it installed, Stash will prompt you to download a copy during setup. It is recommended that Linux users install ffmpeg from their distro's package manager.

Usage

Quickstart Guide

Stash is a web-based application. Once the application is running, the interface is available (by default) from http://localhost:9999.

On first run, Stash will prompt you for some configuration options and media directories to index, called "Scanning" in Stash. After scanning, your media will be available for browsing, curating, editing, and tagging.

Stash can pull metadata (performers, tags, descriptions, studios, and more) directly from many sites through the use of scrapers, which integrate directly into Stash. Identifying an entire collection will typically require a mix of multiple sources:

  • The stashapp team maintains StashDB, a crowd-sourced repository of scene, studio, and performer information. Connecting it to Stash will allow you to automatically identify much of a typical media collection. It runs on our stash-box software and is primarily focused on mainstream digital scenes and studios. Instructions, invite codes, and more can be found in this guide to Accessing StashDB.
  • Several community-managed stash-box databases can also be connected to Stash in a similar manner. Each one serves a slightly different niche and follows their own methodology. A rundown of each stash-box, their differences, and the information you need to sign up can be found in this guide to Accessing Stash-Boxes.
  • Many community-maintained scrapers can also be downloaded, installed, and updated from within Stash, allowing you to pull data from a wide range of other websites and databases. They can be found by navigating to Settings → Metadata Providers → Available Scrapers → Community (stable). These can be trickier to use than a stash-box because every scraper works a little differently. For more information, please visit the CommunityScrapers repository.
  • All of the above methods of scraping data into Stash are also covered in more detail in our Guide to Scraping.

StashDB is the canonical instance of our open source metadata API, stash-box.

Translation

Translate

Stash is available in 32 languages (so far!) and it could be in your language too. We use Weblate to coordinate community translations. If you want to help us translate Stash, you can make an account at Codeberg's Weblate to contribute to new or existing languages. Thanks!

The badge below shows the current translation status of Stash across all supported languages:

Translation status

Support & Resources

Need help or want to get involved? Start with the documentation, then reach out to the community if you need further assistance.

For Developers

Pull requests are welcome!

See Development and Contributing for information on working with the codebase, getting a local development setup, and contributing changes.