<!DOCTYPE html> <html lang="en"> <!-- !!! WARNING !!! This file was auto-generated from readme/spec/server_sharing.md and any manual change made to it will be overwritten. To make a change to this file please modify the source Markdown file: https://github.com/laurent22/joplin/blob/dev/readme/spec/server_sharing.md --> <head> <!-- Donate button A/B testing --> <script async src="https://www.googleoptimize.com/optimize.js?id=OPT-PW3ZPK3"></script> <meta charset="utf-8" http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" /> <link rel="icon" href="/images/favicon.png" /> <meta name="viewport" content="width=device-width, initial-scale=1" /> <meta name="theme-color" content="#000000" /> <meta name="description" content="Joplin, the open source note-taking application" /> <link rel="stylesheet" href="/css/bootstrap5.0.2.min.css" as="style" /> <link rel="stylesheet" href="/css/fontawesome-all.min.css?t=1628514896838"> <link href="https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700&display=swap" rel="stylesheet" as="style" media="all" onload="this.media='all'; this.onload = null" /> <link rel="stylesheet" href="/css/site.css?t=1628514896838" as="style" /> <title>Joplin Server sharing feature | Joplin</title> <script src="/js/jquery-3.6.0.min.js" rel="preload" as="script" ></script> </head> <body class="website-env-prod"> <div class="container-fluid generic-template -page" id="main-container"> <div class=" navbar-main white-bg" id="nav-section"> <div class="container"> <div class="row"> <div class="col-3"> <a href="/"> <img src="/images/logo-text-blue.svg" alt="" id="top-logo" width="180" /> </a> </div> <div class="col-9 text-right d-none d-md-block"> <a href="/help/" class="fw500">Help</a> <a href="https://discourse.joplinapp.org/" class="fw500">Forum</a> <a href="/plans/" class="button-link btn-trans plans-button">Joplin Cloud</a><a class="button-link btn-blue sponsor-button" href="/donate"> <i class="fas fa-heart heart-full"></i><i class="far fa-heart heart-line"></i> Support us </a> </div> <div class="col-9 text-right d-block d-md-none"> <span class="pointer" ><img src="/images/mobile-menu-black-open-icon.png" id="open-menu-mobile" alt="" /></span> <div id="menu-mobile"> <div> <div class="text-right"> <img src="/images/close-icon.png" alt="" class="pointer" id="close-menu-mobile" /> </div> <div class="text-center menu-mobile-top"> <a href="https://discourse.joplinapp.org/" class="fw500 mobile-menu-link">Forum</a> <a href="/help/" class="fw500 mobile-menu-link">Help</a> </div> <div class="menu-mobile-buttons"> <a href="/plans/" class="button-link btn-trans plans-button">Joplin Cloud</a><a class="button-link btn-blue sponsor-button" href="/donate"> <i class="fas fa-heart heart-full"></i><i class="far fa-heart heart-line"></i> Support us </a> </div> </div> <div id="toc-mobile"><div><ul> <li> <p>Applications</p> <ul> <li><a href="/desktop/">Desktop application</a></li> <li><a href="/mobile/">Mobile applications</a></li> <li><a href="/terminal/">Terminal application</a></li> <li><a href="/clipper/">Web Clipper</a></li> </ul> </li> <li> <p>Support</p> <ul> <li><a href="https://discourse.joplinapp.org">Joplin Forum</a></li> <li><a href="/markdown/">Markdown Guide</a></li> <li><a href="/e2ee/">How to enable end-to-end encryption</a></li> <li><a href="/conflict/">What is a conflict?</a></li> <li><a href="/debugging/">How to enable debug mode</a></li> <li><a href="/rich_text_editor/">About the Rich Text editor limitations</a></li> <li><a href="/faq/">FAQ</a></li> </ul> </li> <li> <p>Joplin Cloud</p> <ul> <li><a href="/share_notebook/">Sharing a notebook</a></li> <li><a href="/publish_note/">Publishing a note</a></li> </ul> </li> <li> <p>Joplin API - Get Started</p> <ul> <li><a href="/api/overview/">Joplin API Overview</a></li> <li><a href="/api/get_started/plugins/">Plugin development</a></li> <li><a href="/api/tutorials/toc_plugin/">Plugin tutorial</a></li> </ul> </li> <li> <p>Joplin API - References</p> <ul> <li><a href="https://joplinapp.org/api/references/plugin_api/classes/joplin.html">Plugin API</a></li> <li><a href="/api/references/rest_api/">Data API</a></li> <li><a href="/api/references/plugin_manifest/">Plugin manifest</a></li> <li><a href="/api/references/plugin_loading_rules/">Plugin loading rules</a></li> <li><a href="/api/references/plugin_theming/">Plugin theming</a></li> </ul> </li> <li> <p>Development</p> <ul> <li><a href="https://github.com/laurent22/joplin/blob/dev/BUILD.md">How to build the apps</a></li> <li><a href="/spec/e2ee/">End-to-end encryption spec</a></li> <li><a href="/spec/history/">Note History spec</a></li> <li><a href="/spec/sync_lock/">Sync Lock spec</a></li> <li><a href="/spec/plugins/">Plugin Architecture spec</a></li> <li><a href="/spec/search_sorting/">Search Sorting spec</a></li> <li><a href="/spec/server_file_url_format/">Server: File URL Format</a></li> <li><a href="/spec/server_delta_sync/">Server: Delta Sync</a></li> <li><a href="/spec/server_sharing/">Server: Sharing</a></li> </ul> </li> <li> <p>Google Summer of Code 2021</p> <ul> <li><a href="/gsoc2021/index/">Google Summer of Code 2021</a></li> <li><a href="/gsoc2021/pull_request_guidelines/">How to submit a GSoC pull request</a></li> <li><a href="/gsoc2021/ideas/">Project Ideas</a></li> </ul> </li> <li> <p>About</p> <ul> <li><a href="/changelog/">Changelog (Desktop App)</a></li> <li><a href="/changelog_cli/">Changelog (CLI App)</a></li> <li><a href="/changelog_server/">Changelog (Server)</a></li> <li><a href="/stats/">Stats</a></li> <li><a href="/donate/">Donate</a></li> </ul> </li> </ul> </div></div> <div> <p class="light-blue mobile-menu-link-bottom text-center"> Copyright © 2016-2021 Laurent Cozic <br/> <a href="/privacy/" class="fw500">Privacy Policy</a> </p> </div> </div> </div> </div> </div> </div> <div class="help-page-container page-server_sharing"> <div class="container"> <div class="row content-wrapper"> <div id="toc"><div><ul> <li> <p>Applications</p> <ul> <li><a href="/desktop/">Desktop application</a></li> <li><a href="/mobile/">Mobile applications</a></li> <li><a href="/terminal/">Terminal application</a></li> <li><a href="/clipper/">Web Clipper</a></li> </ul> </li> <li> <p>Support</p> <ul> <li><a href="https://discourse.joplinapp.org">Joplin Forum</a></li> <li><a href="/markdown/">Markdown Guide</a></li> <li><a href="/e2ee/">How to enable end-to-end encryption</a></li> <li><a href="/conflict/">What is a conflict?</a></li> <li><a href="/debugging/">How to enable debug mode</a></li> <li><a href="/rich_text_editor/">About the Rich Text editor limitations</a></li> <li><a href="/faq/">FAQ</a></li> </ul> </li> <li> <p>Joplin Cloud</p> <ul> <li><a href="/share_notebook/">Sharing a notebook</a></li> <li><a href="/publish_note/">Publishing a note</a></li> </ul> </li> <li> <p>Joplin API - Get Started</p> <ul> <li><a href="/api/overview/">Joplin API Overview</a></li> <li><a href="/api/get_started/plugins/">Plugin development</a></li> <li><a href="/api/tutorials/toc_plugin/">Plugin tutorial</a></li> </ul> </li> <li> <p>Joplin API - References</p> <ul> <li><a href="https://joplinapp.org/api/references/plugin_api/classes/joplin.html">Plugin API</a></li> <li><a href="/api/references/rest_api/">Data API</a></li> <li><a href="/api/references/plugin_manifest/">Plugin manifest</a></li> <li><a href="/api/references/plugin_loading_rules/">Plugin loading rules</a></li> <li><a href="/api/references/plugin_theming/">Plugin theming</a></li> </ul> </li> <li> <p>Development</p> <ul> <li><a href="https://github.com/laurent22/joplin/blob/dev/BUILD.md">How to build the apps</a></li> <li><a href="/spec/e2ee/">End-to-end encryption spec</a></li> <li><a href="/spec/history/">Note History spec</a></li> <li><a href="/spec/sync_lock/">Sync Lock spec</a></li> <li><a href="/spec/plugins/">Plugin Architecture spec</a></li> <li><a href="/spec/search_sorting/">Search Sorting spec</a></li> <li><a href="/spec/server_file_url_format/">Server: File URL Format</a></li> <li><a href="/spec/server_delta_sync/">Server: Delta Sync</a></li> <li><a href="/spec/server_sharing/">Server: Sharing</a></li> </ul> </li> <li> <p>Google Summer of Code 2021</p> <ul> <li><a href="/gsoc2021/index/">Google Summer of Code 2021</a></li> <li><a href="/gsoc2021/pull_request_guidelines/">How to submit a GSoC pull request</a></li> <li><a href="/gsoc2021/ideas/">Project Ideas</a></li> </ul> </li> <li> <p>About</p> <ul> <li><a href="/changelog/">Changelog (Desktop App)</a></li> <li><a href="/changelog_cli/">Changelog (CLI App)</a></li> <li><a href="/changelog_server/">Changelog (Server)</a></li> <li><a href="/stats/">Stats</a></li> <li><a href="/donate/">Donate</a></li> </ul> </li> </ul> </div></div> <div class="main-content"> <div class="alert alert-danger alert-env-dev" role="alert"> Running in prod mode! </div> <div class="donate-links"> <p><a href="https://www.paypal.com/cgi-bin/webscr?cmd=_donations&business=E8JMYD2LQ8MMA&lc=GB&item_name=Joplin+Development&currency_code=EUR&bn=PP%2dDonationsBF%3abtn_donateCC_LG%2egif%3aNonHosted"><img src="https://raw.githubusercontent.com/laurent22/joplin/dev/Assets/WebsiteAssets/images/badges/Donate-PayPal-green.svg" alt="Donate using PayPal"></a> <a href="https://github.com/sponsors/laurent22/"><img src="https://raw.githubusercontent.com/laurent22/joplin/dev/Assets/WebsiteAssets/images/badges/GitHub-Badge.svg" alt="Sponsor on GitHub"></a> <a href="https://www.patreon.com/joplin"><img src="https://raw.githubusercontent.com/laurent22/joplin/dev/Assets/WebsiteAssets/images/badges/Patreon-Badge.svg" alt="Become a patron"></a> <a href="https://joplinapp.org/donate/#donations"><img src="https://raw.githubusercontent.com/laurent22/joplin/dev/Assets/WebsiteAssets/images/badges/Donate-IBAN.svg" alt="Donate using IBAN"></a></p> </div> <h1>Joplin Server sharing feature<a name="joplin-server-sharing-feature" href="#joplin-server-sharing-feature" class="heading-anchor">🔗</a></h1> <h2>Sharing a file via a public URL<a name="sharing-a-file-via-a-public-url" href="#sharing-a-file-via-a-public-url" class="heading-anchor">🔗</a></h2> <p>Joplin Server is essentially a file hosting service and it allows sharing files via public URLs. To do so, an API call is made to <code>/api/shares</code> with the ID or path of the file that needs to be shared. This call returns a SHAREID that is then used to access the file via URL. When viewing the file, it will display it according to its mime type. Thus by default a Markdown file will be displayed as plain text.</p> <h2>Sharing a note via a public URL<a name="sharing-a-note-via-a-public-url" href="#sharing-a-note-via-a-public-url" class="heading-anchor">🔗</a></h2> <p>It is built on top of the file sharing feature. The file corresponding to the note is shared via the above API. Then a separate application, specific to Joplin, read and parse the Markdown file, and display it as note.</p> <p>That application works as a viewer - instead of displaying the Markdown file as plain text (by default), it renders it and displays it as HTML.</p> <p>The rendering engine is the same as the main applications, which allows us to use the same plugins and settings.</p> <h3>Attached resources<a name="attached-resources" href="#attached-resources" class="heading-anchor">🔗</a></h3> <p>Any resource attached to the note is also shared - so for example images will be displayed, and it will be possible to open any attached PDF. This</p> <h3>Linked note<a name="linked-note" href="#linked-note" class="heading-anchor">🔗</a></h3> <p>Any linked note will <strong>not</strong> be shared, due to the following reasons:</p> <ul> <li> <p>Privacy issue - you don't want to accidentally share a note just because it was linked to another note.</p> </li> <li> <p>Even if the linked note has been shared separately, we still don't give access to it. We don't know who that link has been shared with - it could be a different recipient.</p> </li> </ul> <h3>Multiple share links for a given note<a name="multiple-share-links-for-a-given-note" href="#multiple-share-links-for-a-given-note" class="heading-anchor">🔗</a></h3> <p>It should be possible to have multiple share links for a given note. For example: I share a note with one person, then the same note with a different person. I revoke the share for one person, but I sill want the other person to access the note.</p> <p>So when a share link is created for a note, the API always return a new link.</p> <h2>Sharing a note with a user<a name="sharing-a-note-with-a-user" href="#sharing-a-note-with-a-user" class="heading-anchor">🔗</a></h2> <p>TBD</p> <div class="bottom-links"> <a href="https://github.com/laurent22/joplin/blob/dev/readme/spec/server_sharing.md"> <i class="fab fa-github"></i> Improve this doc </a> </div> </div> </div> </div> </div> <footer class="darkblue-bg"> <div class="container"> <div class="row"> <div class="col-3 d-none d-md-block"> <img src="/images/logo-text.svg" alt="" width="150" /> </div> </div> <div class="row"> <div class="col-12"> <hr /> </div> </div> <div class="row"> <div class="col-12 col-md-6"> <img src="/images/logo-text.svg" width="120" class="img-center d-block d-md-none" alt="" /> <br class="d-block d-md-none" /> <p class="text-center-sm">Copyright © 2016-2021 Laurent Cozic</p> </div> <div class="col-12 col-md-6 right-links"> <p class="text-right text-center-sm"> <a href="https://github.com/laurent22/joplin/" class="github-link"><i class="fab fa-github"></i> GitHub Repository</a> <a href="/privacy/">Privacy Policy</a> </p> </div> </div> </div> </footer> </div> <script src="/js/script.js?t=1628514896838"></script> <script> if (window.location.hostname !== 'localhost') { (function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){ (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o), m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m) })(window,document,'script','https://www.google-analytics.com/analytics.js','ga'); ga('create', 'UA-103586105-1', 'auto'); ga('send', 'pageview'); } </script> </body> </html>