2021-09-10 04:30:02 -07:00
<!DOCTYPE html>
<!-- [if IE 8]><html class="no - js lt - ie9" lang="en" > <![endif] -->
<!-- [if gt IE 8]><! --> < html class = "no-js" lang = "en" > <!-- <![endif] -->
< head >
< meta charset = "utf-8" >
< meta http-equiv = "X-UA-Compatible" content = "IE=edge" >
< meta name = "viewport" content = "width=device-width, initial-scale=1.0" >
< link rel = "canonical" href = "https://blog.trentsonlinedocs.xyz/posts/prosody-photo-uploads/" >
< link rel = "shortcut icon" href = "../../img/favicon.ico" >
< title > Prosody Photo Uploads - Trent's Blog< / title >
< link rel = "stylesheet" href = "https://fonts.googleapis.com/css?family=Lato:400,700|Roboto+Slab:400,700|Inconsolata:400,700" / >
< link rel = "stylesheet" href = "../../css/theme.css" / >
< link rel = "stylesheet" href = "../../css/theme_extra.css" / >
< link rel = "stylesheet" href = "https://cdnjs.cloudflare.com/ajax/libs/highlight.js/10.5.0/styles/github.min.css" / >
< link href = "../../extra.css" rel = "stylesheet" / >
< script >
// Current page data
var mkdocs_page_name = "Prosody Photo Uploads";
var mkdocs_page_input_path = "posts/prosody-photo-uploads.md";
var mkdocs_page_url = "/posts/prosody-photo-uploads/";
< / script >
< script src = "../../js/jquery-2.1.1.min.js" defer > < / script >
< script src = "../../js/modernizr-2.8.3.min.js" defer > < / script >
< script src = "https://cdnjs.cloudflare.com/ajax/libs/highlight.js/10.5.0/highlight.min.js" > < / script >
< script > hljs . initHighlightingOnLoad ( ) ; < / script >
< / head >
< body class = "wy-body-for-nav" role = "document" >
< div class = "wy-grid-for-nav" >
< nav data-toggle = "wy-nav-shift" class = "wy-nav-side stickynav" >
< div class = "wy-side-scroll" >
< div class = "wy-side-nav-search" >
< a href = "../.." class = "icon icon-home" > Trent's Blog< / a >
< div role = "search" >
< form id = "rtd-search-form" class = "wy-form" action = "../../search.html" method = "get" >
< input type = "text" name = "q" placeholder = "Search docs" title = "Type search term here" / >
< / form >
< / div >
< / div >
2021-01-25 08:37:39 -08:00
2021-09-10 04:30:02 -07:00
< div class = "wy-menu wy-menu-vertical" data-spy = "affix" role = "navigation" aria-label = "main navigation" >
< p class = "caption" > < span class = "caption-text" > RSS< / span > < / p >
< ul >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../rss/" > RSS< / a >
< / li >
< / ul >
< p class = "caption" > < span class = "caption-text" > Links< / span > < / p >
< ul >
< li class = "toctree-l1" > < a class = "reference internal" href = "../../links/" > Links< / a >
< / li >
< li class = "toctree-l1" > < a class = "" href = "https://trentpalmer.org" > TrentReads< / a >
< / li >
< li class = "toctree-l1" > < a class = "" href = "https://blog.trentpalmer.org" > AttentionSpanHistory< / a >
< / li >
< li class = "toctree-l1" > < a class = "" href = "https://github.com/TrentSPalmer" > GitHub< / a >
< / li >
< li class = "toctree-l1" > < a class = "" href = "https://twitter.com/boringtrent" > Twitter< / a >
< / li >
< li class = "toctree-l1" > < a class = "" href = "https://www.facebook.com/trentspalmer" > Facebook< / a >
< / li >
< li class = "toctree-l1" > < a class = "" href = "https://docs.trentsonlinedocs.xyz/" > TrentDocs< / a >
< / li >
< li class = "toctree-l1" > < a class = "" href = "https://trentsonlinedocs.xyz/hugo-themes-report/hugo-themes-report.html" > HugoThemesReport< / a >
< / li >
< li class = "toctree-l1" > < a class = "" href = "https://play.google.com/store/apps/details?id=org.trentpalmer.libre_gps_parser" > LibreGpsParser< / a >
< / li >
< li class = "toctree-l1" > < a class = "" href = "https://concise-pdx.com/" > ConcisePDX< / a >
< / li >
< li class = "toctree-l1" > < a class = "" href = "https://trentspalmer.github.io/fcc-challenges/" > FreeCodeCampChallenges< / a >
< / li >
< li class = "toctree-l1" > < a class = "" href = "https://trentpalmer.work/6a57bbe24d8244289610bf57533d6c6f/" > DeviceLayout< / a >
< / li >
< / ul >
< p class = "caption" > < span class = "caption-text" > Posts< / span > < / p >
< ul class = "current" >
< li class = "toctree-l1" > < a class = "reference internal" href = "../trents-favorite-podcasts/" > Trent's Favorite Podcasts< / a >
< / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../test-qr-svg-django/" > Test QRCODE Svg in Django< / a >
< / li >
< li class = "toctree-l1 current" > < a class = "reference internal current" href = "./" > Prosody Photo Uploads< / a >
< ul class = "current" >
< / ul >
< / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../xmpp-apt-notifications/" > Xmpp Apt Notifications< / a >
< / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../apache-virtual-hosts/" > Apache Virtual Hosts< / a >
< / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../sendxmpp-handler-for-python-logging/" > SENDXMPPHandler for Python Logging< / a >
< / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../instructions-for-tethering-from-phone/" > Instructions For Tethering From Phone< / a >
< / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../lmde4-custom-partitions-disk-encryption/" > LMDE4 Custom Partitions Disk Encryption< / a >
< / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../linux-move-cursor-with-keyboard/" > Linux Move Cursor With Keyboard< / a >
< / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../simplified-raspberry-streaming/" > Simplified Raspberry Streaming< / a >
< / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../clear-linux-encrypted-xfs-root/" > Clear Linux Encrypted xfs Root< / a >
< / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../clear-linux-guest-virt-manager/" > Clear Linux Guest Virt Manager< / a >
< / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../faster-partitioning-with-sgdisk/" > Faster Partitioning With sgdisk< / a >
< / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../lmde3-xfs-full-disk-encryption/" > LMDE3 xfs Full Disk Encryption< / a >
< / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "../rewrite-hugo-themes-report-in-python/" > Rewrite Hugo Themes Report in Python< / a >
< / li >
< / ul >
< / div >
< / div >
< / nav >
2021-09-02 14:05:12 -07:00
2021-09-10 04:30:02 -07:00
< section data-toggle = "wy-nav-shift" class = "wy-nav-content-wrap" >
2021-09-02 14:05:12 -07:00
2021-09-10 04:30:02 -07:00
< nav class = "wy-nav-top" role = "navigation" aria-label = "top navigation" >
< i data-toggle = "wy-nav-top" class = "fa fa-bars" > < / i >
< a href = "../.." > Trent's Blog< / a >
< / nav >
2021-09-02 14:05:12 -07:00
2021-09-10 04:30:02 -07:00
< div class = "wy-nav-content" >
< div class = "rst-content" >
< div role = "navigation" aria-label = "breadcrumbs navigation" >
< ul class = "wy-breadcrumbs" >
< li > < a href = "../.." > Docs< / a > » < / li >
2021-09-02 14:05:12 -07:00
2021-09-10 04:30:02 -07:00
< li > Posts » < / li >
2021-09-02 14:05:12 -07:00
2021-09-10 04:30:02 -07:00
< li > Prosody Photo Uploads< / li >
< li class = "wy-breadcrumbs-aside" >
2021-09-02 14:05:12 -07:00
< / li >
2021-01-25 08:37:39 -08:00
< / ul >
2021-09-10 04:30:02 -07:00
< hr / >
< / div >
< div role = "main" >
< div class = "section" >
2021-01-25 08:37:39 -08:00
< p > date: 2021-01-25< / p >
< h2 id = "introduction" > < strong > Introduction< / strong > < / h2 >
< p > Install < a href = "https://prosody.im/" target = "_blank" > prosody< / a > on < a href = "https://www.debian.org/" target = "_blank" > Debian 10< / a >
with photoupload, postgresql database, and letsencrypt certs.< / p >
< h2 id = "dns" > < strong > DNS< / strong > < / h2 >
< ul >
< li > Log into your dns provider and create A and AAAA records for < em > xmpp.example.com< / em > < / li >
< li > Log into your dns provider and create A and AAAA records for < em > xmppupload.example.com< / em > < / li >
< / ul >
< h2 id = "firewall" > < strong > FireWall< / strong > < / h2 >
< p > Incidentally, you definitely do want to use a non-standard ssh port for connecting over the internet.< / p >
< p > I would suggest that a firewall is important, because I couldn't figure out how to completely disable
port 5280 for the http protocol, in the clear, in the prosody config.< / p >
< h3 id = "ports" > ports< / h3 >
< ul >
< li > < code > 80/tcp< / code > , < code > 443/tcp< / code > for certbot< / li >
< li > < code > 4444/tcp< / code > i.e. port 4444 for ssh< / li >
< li > < code > 5222/tcp< / code > for xmpp-client< / li >
< li > < code > 5269/tcp< / code > for xmpp-server< / li >
< li > < code > 5281/tcp< / code > for https connections to prosody for uploads and photos< / li >
< / ul >
< h3 id = "firewall-with-ufw" > FireWall with UFW< / h3 >
< ul >
< li > < code > ufw allow http< / code > < / li >
< li > < code > ufw allow https< / code > < / li >
< li > < code > ufw allow xmpp-client< / code > < / li >
< li > < code > ufw allow xmpp-server< / code > < / li >
< li > < code > ufw allow 5281/tcp< / code > < / li >
< li > < code > ufw allow 4444/tcp< / code > i.e. if 4444 for ssh< / li >
< li > < code > ufw enable< / code > to start the firewall< / li >
< / ul >
< h2 id = "postgresql-database" > < strong > Postgresql Database< / strong > < / h2 >
< h3 id = "install-the-postgresql-database" > Install the postgresql database.< / h3 >
< p > < div class = "highlight" > < pre > < span > < / span > < code > < span class = "go" > apt-get install postgresql postgresql-contrib< / span >
< / code > < / pre > < / div >
Log into the psql command line.
< div class = "highlight" > < pre > < span > < / span > < code > < span class = "go" > sudo -u postgres psql< / span >
< / code > < / pre > < / div >
Create prosody database
< div class = "highlight" > < pre > < span > < / span > < code > < span class = "n" > postgres< / span > < span class = "o" > =#< / span > < span class = "k" > CREATE< / span > < span class = "k" > DATABASE< / span > < span class = "n" > prosody< / span > < span class = "p" > ;< / span >
< / code > < / pre > < / div >
Creat prosody user
< div class = "highlight" > < pre > < span > < / span > < code > < span class = "n" > postgres< / span > < span class = "o" > =#< / span > < span class = "k" > CREATE< / span > < span class = "k" > ROLE< / span > < span class = "n" > prosody< / span > < span class = "k" > WITH< / span > < span class = "n" > LOGIN< / span > < span class = "p" > ;< / span >
< / code > < / pre > < / div >
Set password for user
< div class = "highlight" > < pre > < span > < / span > < code > < span class = "n" > postgres< / span > < span class = "o" > =#< / span > < span class = "err" > \< / span > < span class = "n" > password< / span > < span class = "n" > prosody< / span >
< / code > < / pre > < / div >
Quit < code > psql< / code >
< div class = "highlight" > < pre > < span > < / span > < code > < span class = "n" > postgres< / span > < span class = "o" > =#< / span > < span class = "err" > \< / span > < span class = "n" > q< / span >
< / code > < / pre > < / div > < / p >
< h3 id = "allow-authentication-in-pg_hbaconf" > allow authentication in < code > pg_hba.conf< / code > < / h3 >
< p > To connect to postgresql via unix socket
< div class = "highlight" > < pre > < span > < / span > < code > < span class = "c1" > # /etc/postgresql/11/main/pg_hba.conf< / span >
< span class = "c1" > # make sure this line is above< / span >
< span class = "na" > local prosody prosody md5< / span >
< span class = "c1" > # make sure this line is below< / span >
< span class = "na" > local all all peer< / span >
< / code > < / pre > < / div >
or i.e. through a wireguard tunnel
< div class = "highlight" > < pre > < span > < / span > < code > < span class = "c1" > # /etc/postgresql/11/main/pg_hba.conf< / span >
< span class = "c1" > # where 10.0.22.5 is the ip address of the machine that prosody will run on < / span >
< span class = "na" > host prosody prosody 10.0.22.5/32 md5< / span >
< / code > < / pre > < / div > < / p >
< p > and then restart postgresql
< div class = "highlight" > < pre > < span > < / span > < code > < span class = "go" > systemctl restart postgresql< / span >
< / code > < / pre > < / div > < / p >
< h2 id = "prosody" > < strong > Prosody< / strong > < / h2 >
< h3 id = "install-prosody" > Install Prosody< / h3 >
< div class = "highlight" > < pre > < span > < / span > < code > < span class = "go" > apt install prosody prosody-modules lua-dbi-postgresql< / span >
< / code > < / pre > < / div >
< h3 id = "configure-prosody" > Configure Prosody< / h3 >
< p > backup the prosody config file
< div class = "highlight" > < pre > < span > < / span > < code > < span class = "go" > cp /etc/prosody/prosody.cfg.lua /etc/prosody/prosody.cfg.lua.bak< / span >
< / code > < / pre > < / div > < / p >
< p > if you want to disable advertising version and uptime, allow message archives,
and disallow registration, change this
< div class = "highlight" > < pre > < span > < / span > < code > < span class = "na" > -- /etc/prosody/prosody.cfg.lua< / span >
< span class = "na" > modules_enabled< / span > < span class = "o" > =< / span > < span class = "s" > {< / span >
< span class = "na" > ...< / span >
< span class = "na" > -- Nice to have< / span >
< span class = "na" > " version" ; -- Replies to server version requests< / span >
< span class = "na" > " uptime" ; -- Report how long server has been running< / span >
< span class = "na" > " time" ; -- Let others know the time here on this server< / span >
< span class = "na" > " ping" ; -- Replies to XMPP pings with pongs< / span >
< span class = "na" > " register" ; -- Allow users to register on this server using a client and change passwords< / span >
< span class = "na" > --" mam" ; -- Store messages in an archive and allow users to access it< / span >
< span class = "na" > --" csi_simple" ; -- Simple Mobile optimizations< / span >
< span class = "na" > ...< / span >
< span class = "na" > }< / span >
< / code > < / pre > < / div > < / p >
< p > to this
< div class = "highlight" > < pre > < span > < / span > < code > < span class = "na" > -- /etc/prosody/prosody.cfg.lua< / span >
< span class = "na" > modules_enabled< / span > < span class = "o" > =< / span > < span class = "s" > {< / span >
< span class = "na" > ...< / span >
< span class = "na" > -- Nice to have< / span >
< span class = "na" > --" version" ; -- Replies to server version requests< / span >
< span class = "na" > --" uptime" ; -- Report how long server has been running< / span >
< span class = "na" > " time" ; -- Let others know the time here on this server< / span >
< span class = "na" > " ping" ; -- Replies to XMPP pings with pongs< / span >
< span class = "na" > --" register" ; -- Allow users to register on this server using a client and change passwords< / span >
< span class = "na" > " mam" ; -- Store messages in an archive and allow users to access it< / span >
< span class = "na" > --" csi_simple" ; -- Simple Mobile optimizations< / span >
< span class = "na" > ...< / span >
< span class = "na" > }< / span >
< / code > < / pre > < / div > < / p >
< p > to force certificate authentication for server-to-server connections,
make the following edit around line 123
< div class = "highlight" > < pre > < span > < / span > < code > < span class = "na" > -- /etc/prosody/prosody.cfg.lua< / span >
< span class = "na" > -- Force certificate authentication for server-to-server connections?< / span >
< span class = "na" > -- change this< / span >
< span class = "na" > s2s_secure_auth< / span > < span class = "o" > =< / span > < span class = "s" > false< / span >
< span class = "na" > -- to this< / span >
< span class = "na" > s2s_secure_auth< / span > < span class = "o" > =< / span > < span class = "s" > true< / span >
< / code > < / pre > < / div > < / p >
< p > around line 147 enable sql
< div class = "highlight" > < pre > < span > < / span > < code > < span class = "na" > -- /etc/prosody/prosody.cfg.lua< / span >
< span class = "na" > -- change this< / span >
< span class = "na" > --storage< / span > < span class = "o" > =< / span > < span class = "s" > " sql" < / span >
< span class = "na" > -- to this< / span >
< span class = "na" > storage< / span > < span class = "o" > =< / span > < span class = "s" > " sql" < / span >
< / code > < / pre > < / div > < / p >
< p > and describe the database connection
< div class = "highlight" > < pre > < span > < / span > < code > < span class = "na" > -- /etc/prosody/prosody.cfg.lua< / span >
< span class = "na" > -- change this< / span >
< span class = "na" > --sql< / span > < span class = "o" > =< / span > < span class = "s" > {< / span >
2021-04-19 19:26:40 -07:00
< span class = "na" > driver< / span > < span class = "o" > =< / span > < span class = "s" > " PostgreSQL" ,< / span >
< span class = "na" > database< / span > < span class = "o" > =< / span > < span class = "s" > " prosody" ,< / span >
< span class = "na" > username< / span > < span class = "o" > =< / span > < span class = "s" > " prosody" ,< / span >
< span class = "na" > password< / span > < span class = "o" > =< / span > < span class = "s" > " secret" ,< / span >
< span class = "na" > host< / span > < span class = "o" > =< / span > < span class = "s" > " localhost" < / span >
2021-01-25 08:37:39 -08:00
< span class = "na" > }< / span >
< span class = "na" > -- to this< / span >
< span class = "na" > sql< / span > < span class = "o" > =< / span > < span class = "s" > {< / span >
2021-04-19 19:26:40 -07:00
< span class = "na" > driver< / span > < span class = "o" > =< / span > < span class = "s" > " PostgreSQL" ,< / span >
< span class = "na" > database< / span > < span class = "o" > =< / span > < span class = "s" > " prosody" ,< / span >
< span class = "na" > username< / span > < span class = "o" > =< / span > < span class = "s" > " prosody" ,< / span >
< span class = "na" > password< / span > < span class = "o" > =< / span > < span class = "s" > " secret" ,< / span >
< span class = "na" > host< / span > < span class = "o" > =< / span > < span class = "s" > " localhost" < / span >
2021-01-25 08:37:39 -08:00
< span class = "na" > }< / span >
< span class = "na" > -- or to use a unix socket in Debian 10< / span >
< span class = "na" > sql< / span > < span class = "o" > =< / span > < span class = "s" > {< / span >
2021-04-19 19:26:40 -07:00
< span class = "na" > driver< / span > < span class = "o" > =< / span > < span class = "s" > " PostgreSQL" ,< / span >
< span class = "na" > database< / span > < span class = "o" > =< / span > < span class = "s" > " prosody" ,< / span >
< span class = "na" > username< / span > < span class = "o" > =< / span > < span class = "s" > " prosody" ,< / span >
< span class = "na" > password< / span > < span class = "o" > =< / span > < span class = "s" > " secret" ,< / span >
< span class = "na" > host< / span > < span class = "o" > =< / span > < span class = "s" > " /var/run/postgresql" < / span >
2021-01-25 08:37:39 -08:00
< span class = "na" > }< / span >
< / code > < / pre > < / div > < / p >
< p > somewhere around line 196, describe the certificate file for the upoad subdomain
< div class = "highlight" > < pre > < span > < / span > < code > < span class = "na" > -- /etc/prosody/prosody.cfg.lua< / span >
< span class = "na" > -- change this< / span >
< span class = "na" > --https_certificate< / span > < span class = "o" > =< / span > < span class = "s" > " /etc/prosody/certs/localhost.crt" < / span >
< span class = "na" > -- to this< / span >
< span class = "na" > https_certificate< / span > < span class = "o" > =< / span > < span class = "s" > " /etc/prosody/certs/xmppupload.example.com.crt" < / span >
< / code > < / pre > < / div > < / p >
< p > somewhere around line 210 describe your virtualhost
< div class = "highlight" > < pre > < span > < / span > < code > < span class = "na" > -- /etc/prosody/prosody.cfg.lua< / span >
< span class = "na" > VirtualHost " xmpp.example.com" < / span >
< span class = "na" > disco_items< / span > < span class = "o" > =< / span > < span class = "s" > {< / span >
2021-04-19 19:26:40 -07:00
< span class = "na" > {" xmppupload.example.com" },< / span >
2021-01-25 08:37:39 -08:00
< span class = "na" > }< / span >
< / code > < / pre > < / div > < / p >
< p > add the following to the end of the file
< div class = "highlight" > < pre > < span > < / span > < code > < span class = "na" > -- /etc/prosody/prosody.cfg.lua< / span >
< span class = "na" > Component " xmppupload.example.com" " http_upload" < / span >
< / code > < / pre > < / div > < / p >
< p > and then restart prosody
< div class = "highlight" > < pre > < span > < / span > < code > < span class = "go" > systemctl restart prososdy< / span >
< / code > < / pre > < / div > < / p >
< h2 id = "certbot" > < strong > Certbot< / strong > < / h2 >
< p > install certbot
< div class = "highlight" > < pre > < span > < / span > < code > < span class = "go" > apt install certbot< / span >
< / code > < / pre > < / div >
get certificates
< div class = "highlight" > < pre > < span > < / span > < code > < span class = "go" > certbot certonly -d xmpp.example.com< / span >
< span class = "go" > certbot certonly -d xmppupload.example.com< / span >
< / code > < / pre > < / div >
import the certificates into prosody and restart prosody
< div class = "highlight" > < pre > < span > < / span > < code > < span class = "go" > prosodyctl --root cert import /etc/letsencrypt/live< / span >
< span class = "go" > systemctl restart prosody< / span >
< / code > < / pre > < / div >
create the following renewal-hook for letsencrypt
< div class = "highlight" > < pre > < span > < / span > < code > < span class = "gp" > #< / span > !/bin/bash
2021-04-19 19:26:40 -07:00
< span class = "gp" > # < / span > /etc/letsencrypt/renewal-hooks/deploy/prosody_deploy_hook
2021-01-25 08:37:39 -08:00
< span class = "go" > prosodyctl --root cert import /etc/letsencrypt/live< / span >
< / code > < / pre > < / div > < / p >
< / div >
2021-04-19 19:26:40 -07:00
< / div >
2021-09-10 04:30:02 -07:00
< footer >
2021-01-25 08:37:39 -08:00
2021-09-10 04:30:02 -07:00
< div class = "rst-footer-buttons" role = "navigation" aria-label = "footer navigation" >
2021-01-25 08:37:39 -08:00
2021-09-10 04:30:02 -07:00
< a href = "../xmpp-apt-notifications/" class = "btn btn-neutral float-right" title = "Xmpp Apt Notifications" > Next < span class = "icon icon-circle-arrow-right" > < / span > < / a >
2021-01-25 08:37:39 -08:00
2021-09-10 04:30:02 -07:00
< a href = "../test-qr-svg-django/" class = "btn btn-neutral" title = "Test QRCODE Svg in Django" > < span class = "icon icon-circle-arrow-left" > < / span > Previous< / a >
2021-09-02 13:52:37 -07:00
2021-09-10 04:30:02 -07:00
< / div >
< hr / >
< div role = "contentinfo" >
<!-- Copyright etc -->
2021-09-02 13:52:37 -07:00
2021-01-25 08:37:39 -08:00
< / div >
2021-09-10 04:30:02 -07:00
Built with < a href = "https://www.mkdocs.org/" > MkDocs< / a > using a < a href = "https://github.com/snide/sphinx_rtd_theme" > theme< / a > provided by < a href = "https://readthedocs.org" > Read the Docs< / a > .
2021-01-25 08:37:39 -08:00
< / footer >
2021-09-10 04:30:02 -07:00
< / div >
< / div >
< / section >
< / div >
< div class = "rst-versions" role = "note" aria-label = "versions" >
< span class = "rst-current-version" data-toggle = "rst-current-version" >
2021-04-19 19:26:40 -07:00
2021-01-25 08:37:39 -08:00
2021-09-10 04:30:02 -07:00
< span > < a href = "../test-qr-svg-django/" style = "color: #fcfcfc" > « Previous< / a > < / span >
2021-01-25 08:37:39 -08:00
2021-09-10 04:30:02 -07:00
< span > < a href = "../xmpp-apt-notifications/" style = "color: #fcfcfc" > Next » < / a > < / span >
< / span >
< / div >
< script > var base _url = '../..' ; < / script >
< script src = "../../js/theme_extra.js" defer > < / script >
< script src = "../../js/theme.js" defer > < / script >
< script src = "../../search/main.js" defer > < / script >
< script defer >
window.onload = function () {
SphinxRtdTheme.Navigation.enable(true);
};
< / script >
< / body >
< / html >