Files
Pinry/development/index.html
2024-09-30 20:58:34 +08:00

650 lines
18 KiB
HTML

<!doctype html>
<html lang="en" class="no-js">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width,initial-scale=1">
<meta http-equiv="x-ua-compatible" content="ie=edge">
<meta name="description" content="Docs for the Pinry project.">
<link rel="canonical" href="https://pinry.github.io/pinry/development/">
<meta name="author" content="Pinry's Contributors">
<meta name="lang:clipboard.copy" content="Copy to clipboard">
<meta name="lang:clipboard.copied" content="Copied to clipboard">
<meta name="lang:search.language" content="en">
<meta name="lang:search.pipeline.stopwords" content="True">
<meta name="lang:search.pipeline.trimmer" content="True">
<meta name="lang:search.result.none" content="No matching documents">
<meta name="lang:search.result.one" content="1 matching document">
<meta name="lang:search.result.other" content="# matching documents">
<meta name="lang:search.tokenizer" content="[\s\-]+">
<link rel="shortcut icon" href="../assets/images/favicon.png">
<meta name="generator" content="mkdocs-1.0.4, mkdocs-material-4.6.0">
<title>Development - Pinry Docs</title>
<link rel="stylesheet" href="../assets/stylesheets/application.1b62728e.css">
<link rel="stylesheet" href="../assets/stylesheets/application-palette.a8b3c06d.css">
<meta name="theme-color" content="#3f51b5">
<script src="../assets/javascripts/modernizr.268332fc.js"></script>
<link href="https://fonts.gstatic.com" rel="preconnect" crossorigin>
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Roboto:300,400,400i,700%7CRoboto+Mono&display=fallback">
<style>body,input{font-family:"Roboto","Helvetica Neue",Helvetica,Arial,sans-serif}code,kbd,pre{font-family:"Roboto Mono","Courier New",Courier,monospace}</style>
<link rel="stylesheet" href="../assets/fonts/material-icons.css">
<link rel="manifest" href="../manifest.webmanifest">
</head>
<body dir="ltr" data-md-color-primary="indigo" data-md-color-accent="indigo">
<svg class="md-svg">
<defs>
<svg xmlns="http://www.w3.org/2000/svg" width="416" height="448" viewBox="0 0 416 448" id="__github"><path fill="currentColor" d="M160 304q0 10-3.125 20.5t-10.75 19T128 352t-18.125-8.5-10.75-19T96 304t3.125-20.5 10.75-19T128 256t18.125 8.5 10.75 19T160 304zm160 0q0 10-3.125 20.5t-10.75 19T288 352t-18.125-8.5-10.75-19T256 304t3.125-20.5 10.75-19T288 256t18.125 8.5 10.75 19T320 304zm40 0q0-30-17.25-51T296 232q-10.25 0-48.75 5.25Q229.5 240 208 240t-39.25-2.75Q130.75 232 120 232q-29.5 0-46.75 21T56 304q0 22 8 38.375t20.25 25.75 30.5 15 35 7.375 37.25 1.75h42q20.5 0 37.25-1.75t35-7.375 30.5-15 20.25-25.75T360 304zm56-44q0 51.75-15.25 82.75-9.5 19.25-26.375 33.25t-35.25 21.5-42.5 11.875-42.875 5.5T212 416q-19.5 0-35.5-.75t-36.875-3.125-38.125-7.5-34.25-12.875T37 371.5t-21.5-28.75Q0 312 0 260q0-59.25 34-99-6.75-20.5-6.75-42.5 0-29 12.75-54.5 27 0 47.5 9.875t47.25 30.875Q171.5 96 212 96q37 0 70 8 26.25-20.5 46.75-30.25T376 64q12.75 25.5 12.75 54.5 0 21.75-6.75 42 34 40 34 99.5z"/></svg>
</defs>
</svg>
<input class="md-toggle" data-md-toggle="drawer" type="checkbox" id="__drawer" autocomplete="off">
<input class="md-toggle" data-md-toggle="search" type="checkbox" id="__search" autocomplete="off">
<label class="md-overlay" data-md-component="overlay" for="__drawer"></label>
<a href="#developing-pinry" tabindex="1" class="md-skip">
Skip to content
</a>
<header class="md-header" data-md-component="header">
<nav class="md-header-nav md-grid">
<div class="md-flex">
<div class="md-flex__cell md-flex__cell--shrink">
<a href="https://pinry.github.io/pinry/" title="Pinry Docs" class="md-header-nav__button md-logo">
<i class="md-icon"></i>
</a>
</div>
<div class="md-flex__cell md-flex__cell--shrink">
<label class="md-icon md-icon--menu md-header-nav__button" for="__drawer"></label>
</div>
<div class="md-flex__cell md-flex__cell--stretch">
<div class="md-flex__ellipsis md-header-nav__title" data-md-component="title">
<span class="md-header-nav__topic">
Pinry Docs
</span>
<span class="md-header-nav__topic">
Development
</span>
</div>
</div>
<div class="md-flex__cell md-flex__cell--shrink">
<label class="md-icon md-icon--search md-header-nav__button" for="__search"></label>
<div class="md-search" data-md-component="search" role="dialog">
<label class="md-search__overlay" for="__search"></label>
<div class="md-search__inner" role="search">
<form class="md-search__form" name="search">
<input type="text" class="md-search__input" name="query" placeholder="Search" autocapitalize="off" autocorrect="off" autocomplete="off" spellcheck="false" data-md-component="query" data-md-state="active">
<label class="md-icon md-search__icon" for="__search"></label>
<button type="reset" class="md-icon md-search__icon" data-md-component="reset" tabindex="-1">
&#xE5CD;
</button>
</form>
<div class="md-search__output">
<div class="md-search__scrollwrap" data-md-scrollfix>
<div class="md-search-result" data-md-component="result">
<div class="md-search-result__meta">
Type to start searching
</div>
<ol class="md-search-result__list"></ol>
</div>
</div>
</div>
</div>
</div>
</div>
<div class="md-flex__cell md-flex__cell--shrink">
<div class="md-header-nav__source">
<a href="https://github.com/pinry/pinry/" title="Go to repository" class="md-source" data-md-source="github">
<div class="md-source__icon">
<svg viewBox="0 0 24 24" width="24" height="24">
<use xlink:href="#__github" width="24" height="24"></use>
</svg>
</div>
<div class="md-source__repository">
pinry/pinry
</div>
</a>
</div>
</div>
</div>
</nav>
</header>
<div class="md-container">
<main class="md-main" role="main">
<div class="md-main__inner md-grid" data-md-component="container">
<div class="md-sidebar md-sidebar--primary" data-md-component="navigation">
<div class="md-sidebar__scrollwrap">
<div class="md-sidebar__inner">
<nav class="md-nav md-nav--primary" data-md-level="0">
<label class="md-nav__title md-nav__title--site" for="__drawer">
<a href="https://pinry.github.io/pinry/" title="Pinry Docs" class="md-nav__button md-logo">
<i class="md-icon"></i>
</a>
Pinry Docs
</label>
<div class="md-nav__source">
<a href="https://github.com/pinry/pinry/" title="Go to repository" class="md-source" data-md-source="github">
<div class="md-source__icon">
<svg viewBox="0 0 24 24" width="24" height="24">
<use xlink:href="#__github" width="24" height="24"></use>
</svg>
</div>
<div class="md-source__repository">
pinry/pinry
</div>
</a>
</div>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href=".." title="Home" class="md-nav__link">
Home
</a>
</li>
<li class="md-nav__item">
<a href="../screenshots/" title="Screenshots" class="md-nav__link">
Screenshots
</a>
</li>
<li class="md-nav__item">
<a href="../extensions/" title="Extensions" class="md-nav__link">
Extensions
</a>
</li>
<li class="md-nav__item">
<a href="../theories/" title="Theories" class="md-nav__link">
Theories
</a>
</li>
<li class="md-nav__item">
<a href="../install-with-docker/" title="Install with Docker" class="md-nav__link">
Install with Docker
</a>
</li>
<li class="md-nav__item md-nav__item--active">
<input class="md-toggle md-nav__toggle" data-md-toggle="toc" type="checkbox" id="__toc">
<label class="md-nav__link md-nav__link--active" for="__toc">
Development
</label>
<a href="./" title="Development" class="md-nav__link md-nav__link--active">
Development
</a>
<nav class="md-nav md-nav--secondary">
<label class="md-nav__title" for="__toc">Table of contents</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="#testing" class="md-nav__link">
Testing
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="../api/" title="API support" class="md-nav__link">
API support
</a>
</li>
<li class="md-nav__item">
<a href="../plugin-system/" title="Plugin System" class="md-nav__link">
Plugin System
</a>
</li>
<li class="md-nav__item">
<a href="../upgrade-guide/" title="Upgrade Guide" class="md-nav__link">
Upgrade Guide
</a>
</li>
<li class="md-nav__item">
<a href="../docs/" title="Docs" class="md-nav__link">
Docs
</a>
</li>
<li class="md-nav__item">
<a href="../passwords/" title="Passwords" class="md-nav__link">
Passwords
</a>
</li>
<li class="md-nav__item">
<a href="../assets/" title="Assets" class="md-nav__link">
Assets
</a>
</li>
<li class="md-nav__item">
<a href="../contributing/" title="Contributing" class="md-nav__link">
Contributing
</a>
</li>
<li class="md-nav__item">
<a href="../license/" title="License" class="md-nav__link">
License
</a>
</li>
</ul>
</nav>
</div>
</div>
</div>
<div class="md-sidebar md-sidebar--secondary" data-md-component="toc">
<div class="md-sidebar__scrollwrap">
<div class="md-sidebar__inner">
<nav class="md-nav md-nav--secondary">
<label class="md-nav__title" for="__toc">Table of contents</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="#testing" class="md-nav__link">
Testing
</a>
</li>
</ul>
</nav>
</div>
</div>
</div>
<div class="md-content">
<article class="md-content__inner md-typeset">
<a href="https://github.com/pinry/pinry/edit/master/docs/src/development.md" title="Edit this page" class="md-icon md-content__icon">&#xE3C9;</a>
<h1 id="developing-pinry">Developing Pinry<a class="headerlink" href="#developing-pinry" title="Permanent link">&para;</a></h1>
<p>Pinry currently has two major requirements:</p>
<ul>
<li>Python@3.6+</li>
<li>NodeJS@18</li>
</ul>
<p>For minor requirements you need two have installed two package managers that
are not the defaults for these languages:</p>
<ul>
<li>Python, poetry</li>
<li>NodeJS, pnpm</li>
</ul>
<p>To install these is pretty simple, you can just run:</p>
<div class="codehilite"><pre><span></span>cd pinry
pip install poetry
npm install -g pnpm
</pre></div>
<p>After that you can install this project with:</p>
<div class="codehilite"><pre><span></span>poetry install
cd pinry-spa; pnpm install
</pre></div>
<p>You will need to run two separate items as of right now, the SPA and the
backend:</p>
<div class="codehilite"><pre><span></span>poetry run python manage.py migrate
poetry run python manage.py runserver
</pre></div>
<p>And from another terminal:</p>
<div class="codehilite"><pre><span></span>cd pinry-spa; pnpm serve
</pre></div>
<h2 id="testing">Testing<a class="headerlink" href="#testing" title="Permanent link">&para;</a></h2>
<p>We have many tests built into Pinry to ensure that changes don't break
anything. If you are live dangerously and have cutting edge new Pinry
features first you can use our master branch for your own instance. We
recommend using our tags/versions though.</p>
<p>To run Pinry's tests inside the Pinry repo run:</p>
<div class="codehilite"><pre><span></span>poetry run python manage.py test
</pre></div>
<h1 id="docker">Docker<a class="headerlink" href="#docker" title="Permanent link">&para;</a></h1>
<p>Follow the steps below to install Pinry locally or on any server. This
process installs the minimal requirements to run Pinry. For development
requirements and procedures, see testing above.</p>
<p>Current docker configuration will just mount source code directory to
docker app directory and run any codes existed in current git branch,
you may also add "local_settings.py" to customize settings without
changing settings file in <code>pinry/settings</code>.</p>
<ul>
<li>
<p>Install the requirements:</p>
<ul>
<li>Docker</li>
<li>Docker Compose</li>
</ul>
</li>
<li>
<p>Set any custom configuration options you need and run</p>
<p>cp docker-compose.example.yml docker-compose.yml </p>
<h1 id="edit-docker-composeyml-and-change-the-secret-key">edit docker-compose.yml and change the secret-key,<a class="headerlink" href="#edit-docker-composeyml-and-change-the-secret-key" title="Permanent link">&para;</a></h1>
<h1 id="dont-forget-to-backup-this-config-file">don't forget to backup this config file.<a class="headerlink" href="#dont-forget-to-backup-this-config-file" title="Permanent link">&para;</a></h1>
<h1 id="you-should-build-frontend-first">You should build frontend first<a class="headerlink" href="#you-should-build-frontend-first" title="Permanent link">&para;</a></h1>
<p>docker-compose up build_frontend </p>
<h1 id="then-start-the-backend-server">then start the backend server<a class="headerlink" href="#then-start-the-backend-server" title="Permanent link">&para;</a></h1>
<p>docker-compose up -d web</p>
</li>
<li>
<p>If you want to run Pinry with current user in docker</p>
<p>./start_docker_with_current_user.sh [-d]</p>
</li>
<li>
<p>Bootstrap the database(optional)</p>
<p>docker-compose exec web python3 manage.py migrate --settings=pinry.settings.docker</p>
</li>
</ul>
<p><strong>Note</strong> : No static file server configured, your should configure nginx or other server to serve
static files from <code>./static</code>(as path <code>/static</code>) and <code>./pinry-spa/dist</code> (as html root <code>/</code>)</p>
</article>
</div>
</div>
</main>
<footer class="md-footer">
<div class="md-footer-nav">
<nav class="md-footer-nav__inner md-grid">
<a href="../install-with-docker/" title="Install with Docker" class="md-flex md-footer-nav__link md-footer-nav__link--prev" rel="prev">
<div class="md-flex__cell md-flex__cell--shrink">
<i class="md-icon md-icon--arrow-back md-footer-nav__button"></i>
</div>
<div class="md-flex__cell md-flex__cell--stretch md-footer-nav__title">
<span class="md-flex__ellipsis">
<span class="md-footer-nav__direction">
Previous
</span>
Install with Docker
</span>
</div>
</a>
<a href="../api/" title="API support" class="md-flex md-footer-nav__link md-footer-nav__link--next" rel="next">
<div class="md-flex__cell md-flex__cell--stretch md-footer-nav__title">
<span class="md-flex__ellipsis">
<span class="md-footer-nav__direction">
Next
</span>
API support
</span>
</div>
<div class="md-flex__cell md-flex__cell--shrink">
<i class="md-icon md-icon--arrow-forward md-footer-nav__button"></i>
</div>
</a>
</nav>
</div>
<div class="md-footer-meta md-typeset">
<div class="md-footer-meta__inner md-grid">
<div class="md-footer-copyright">
<div class="md-footer-copyright__highlight">
Copyright &copy; 2019 Pinry's Contributors
</div>
powered by
<a href="https://www.mkdocs.org">MkDocs</a>
and
<a href="https://squidfunk.github.io/mkdocs-material/">
Material for MkDocs</a>
</div>
<div class="md-footer-social">
<link rel="stylesheet" href="../assets/fonts/font-awesome.css">
<a href="https://github.com/pinry/pinry" class="md-footer-social__link fa fa-"></a>
</div>
</div>
</div>
</footer>
</div>
<script src="../assets/javascripts/application.808e90bb.js"></script>
<script>app.initialize({version:"1.0.4",url:{base:".."}})</script>
</body>
</html>