diff --git a/.github/workflows/gh-pages.yml b/.github/workflows/gh-pages.yml index 220d845..1598cf7 100644 --- a/.github/workflows/gh-pages.yml +++ b/.github/workflows/gh-pages.yml @@ -1,4 +1,5 @@ name: build and deploy github pages + on: push: branches: @@ -6,30 +7,17 @@ on: jobs: deploy: runs-on: ubuntu-latest + if: github.ref == 'refs/heads/main' steps: - - uses: actions/checkout@v2 + - name: checkout + uses: actions/checkout@v3.0.0 with: submodules: "recursive" fetch-depth: 0 # Fetch all history for .GitInfo and .Lastmod + + - name: build_and_deploy + uses: shalzz/zola-deploy-action@v0.17.2 + env: + PAGES_BRANCH: gh-pages + TOKEN: ${{ secrets.GITHUB_TOKEN }} - - name: Setup Python - uses: actions/setup-python@v1 - with: - python-version: '3.9' - architecture: 'x64' - - - name: Install dependencies - run: | - python3 -m pip install --upgrade pip - python3 -m pip install mkdocs - python3 -m pip install mkdocs-material - - - name: Build site - run: mkdocs build - - - name: Deploy - uses: peaceiris/actions-gh-pages@v3 - with: - github_token: ${{ secrets.GITHUB_TOKEN }} - publish_dir: ./site - keep_files: true diff --git a/.gitignore b/.gitignore index c2679e3..77f12ae 100644 --- a/.gitignore +++ b/.gitignore @@ -1,2 +1 @@ -venv/ -site/ +docs/ diff --git a/config.toml b/config.toml new file mode 100644 index 0000000..499197a --- /dev/null +++ b/config.toml @@ -0,0 +1,111 @@ +# The URL the site will be built for +base_url = "https://photos.network" + +title = "Photos.network" +description = "The main website for Photos.network a self-hosted and open source photo management service." + +default_language = "en" + +output_dir = "docs" + +# Whether to automatically compile all Sass files in the sass directory +compile_sass = true + +ignored_content = [] + +generate_feed = true + +# The filename to use for the feed. Used as the template filename, too. +# Defaults to "atom.xml", which has a built-in template that renders an Atom 1.0 feed. +# There is also a built-in template "rss.xml" that renders an RSS 2.0 feed. +feed_filename = "atom.xml" + +# Whether to build a search index to be used later on by a JavaScript library +build_search_index = true + + +[markdown] +# Whether to do syntax highlighting +highlight_code = true + + +[search] +# Whether to include the title of the page/section in the index +include_title = true +# Whether to include the description of the page/section in the index +include_description = true +# Whether to include the path of the page/section in the index +include_path = true +# Whether to include the rendered content of the page/section in the index +include_content = true +# At which character to truncate the content to. Useful if you have a lot of pages and the index would +# become too big to load on the site. Defaults to not being set. +truncate_content_length = 100 + + + +[languages.de] +build_search_index = true +title = "Photos.network" + +[extra] +enable_search = false +enable_sidebar = true +enable_adsense = false +enable_multilingue = false +enable_darkmode = false + +[extra.lang] +items = [ + { lang = "en", links = [ + { base_url = "/", name = "English" }, + { base_url = "/de", name = "German" }, + ] }, + { lang = "de", links = [ + { base_url = "/", name = "Englisch" }, + { base_url = "/de", name = "Deutsch" }, + ] }, +] + +[extra.navbar] +items = [ + { lang = "en", links = [ + { url = "/", name = "Home" }, + #{ url = "/installation", name = "Installation" }, + #{ url = "/documentation", name = "Documentation" }, + ] }, + { lang = "de", links = [ + { url = "/de", name = "Start" }, + #{ url = "/de/installation", name = "Installation" }, + #{ url = "/de/documentation", name = "Dokumentation" }, + ]} +] + +[extra.sidebar] +items = [] + +# Index page +[extra.index] +title = "Photos.network" +image = "logo.png" +image_alt = "Logo of the Photos.network project." + +[extra.default_author] +name = "Stürmer, Benjamin" + +[extra.social] +github = "https://github.com/photos-network" +twitter = "https://twitter.com/photosnetwork" +email = "info@photos.network" +linkedin = "" +stackoverflow = "" +telegram = "" + +[extra.favicon] +favicon = "/icons/favicon.ico" +favicon_16x16 = "/icons/favicon-16x16.png" +favicon_32x32 = "/icons/favicon-32x32.png" +apple_touch_icon = "/icons/apple-touch-icon.png" +android_chrome_512 = "/icons/android-icon-310x310.png" +android_chrome_192 = "/icons/android-icon-192x192.png" +manifest = "/icons/site.webmanifest" diff --git a/content/_index.de.md b/content/_index.de.md new file mode 100644 index 0000000..b1869a6 --- /dev/null +++ b/content/_index.de.md @@ -0,0 +1,6 @@ ++++ +title = "Landing" +description = "Photos.network" +date = 2020-12-28 ++++ +Photos.network ist ein selbstgehosteter Dienst zum Speichern und Teilen von Fotos, bei dem der Datenschutz im Vordergrund steht. diff --git a/content/_index.md b/content/_index.md new file mode 100644 index 0000000..aa966fb --- /dev/null +++ b/content/_index.md @@ -0,0 +1,6 @@ ++++ +title = "Landing" +description = "Photos.network" +date = 2020-12-28 ++++ +Photos.network is a self-hosted, privacy first photo storage and sharing service. diff --git a/content/documentation.md b/content/documentation.md new file mode 100644 index 0000000..dc77695 --- /dev/null +++ b/content/documentation.md @@ -0,0 +1,97 @@ ++++ +title = "Configuration" +description = "This is fun" +date = 2020-12-28 ++++ + +## Minimal configuration +```json +{ + "internal_url": "192.168.0.1", + "external_url": "photos.external.com", + "clients": [ + { + "name": "Frontend", + "client_id": "", + "client_secret": "", + "redirect_uris": [ + "http://127.0.0.1:7778/callback" + ] + }, + { + "name": "Android App", + "client_id": "", + "client_secret": "", + "redirect_uris": [ + "photosapp://authenticate" + ] + } + ], + "addons": [ + { + "name": "api" + } + ] +} +``` + + +| Properties | Description | +| ------------------- | ------------------------------------ | +| `internal_url` | Indicates the internal network address. | +| `external_url` | The external network address e.g.: used to create links for sharing. | +| `clients` | List of clients e.g. Web frontend or Android. | +| `addons` | List of addons and their custom configurations. | + + +## Nginx + +It is recommended to run **photos.network** behind a reverse proxy like nginx or HAProxy. +First of all, it increases the performance and it prevents from many attacks based on malformed http requests. + +#### Nginx + Round-robin + +```conf +upstream core { + server 127.0.0.1:7777 fail_timeout=0; +} + +upstream frontend { + server 127.0.0.1:7778 fail_timeout=0; +} + +server { + listen 80; + return 301 https://$host$request_uri; +} + +server { + listen 443 ssl http2; + listen [::]:443 ssl http2; + client_max_body_size 4G; + + server_name photos.example.com; + + ssl_certificate /etc/secrets/cert.pem; + ssl_certificate_key /etc/secrets/key.pem; + + location / { + proxy_set_header Host $http_host; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + proxy_set_header X-Real-IP $remote_addr; + proxy_redirect off; + proxy_buffering off; + proxy_pass http://frontend; + } + + location /api { + proxy_pass http://core; + } + + location /oauth { + proxy_pass http://core; + } +} + +``` diff --git a/content/privacy.md b/content/privacy.md new file mode 100644 index 0000000..88e261b --- /dev/null +++ b/content/privacy.md @@ -0,0 +1,8 @@ ++++ +title = "Privacy" +description = "Privacy policy for the website and mobile apps" +date = 2020-12-28 ++++ + +[Photos.network](https://photos.network) is focusing on privacy and will not track any user data. + diff --git a/docs/security.md b/content/security.md similarity index 67% rename from docs/security.md rename to content/security.md index 02dc81d..cd0a52f 100644 --- a/docs/security.md +++ b/content/security.md @@ -1,7 +1,12 @@ -# Security ++++ +title = "Security" +description = "How to handle found security vulnerabilities" +date = 2020-12-28 ++++ -If you think that you have found a security vulnerability in Photos.network, please disclose it to us via our security e-mail address at security@photos.network. +If you think that you have found a security vulnerability in Photos.network, please disclose it to us via our security e-mail address at [security@photos.network](mailto:security@photos.network). Please do not make vulnerabilities public without notifying us and giving us at least 2 weeks to respond. If you are going to write about Photos.network’s security, please get in touch, so we can make sure that all claims are correct. + diff --git a/docs/_css/extra.css b/docs/_css/extra.css deleted file mode 100644 index e69de29..0000000 diff --git a/docs/_js/extra.js b/docs/_js/extra.js deleted file mode 100644 index e69de29..0000000 diff --git a/docs/documentation/index.md b/docs/documentation/index.md deleted file mode 100644 index 4cbd179..0000000 --- a/docs/documentation/index.md +++ /dev/null @@ -1,4 +0,0 @@ -# Documentation - -You'll find guides for beginners and advanced users. -Covering the configuration of the core system, addons for data sync and others. diff --git a/docs/index.md b/docs/index.md deleted file mode 100644 index b6452e9..0000000 --- a/docs/index.md +++ /dev/null @@ -1,18 +0,0 @@ ---- -hide: -- navigation -- toc ---- -# Photos.network - -Photos.network is an open source project for self hosted photo management. -Its core features are: - -* Share photos with friends, family or public -* Filter / Search photos by attributes like location or date -* Group photos by objects like people of objects - -!!!warning - This application is in development and not available for endusers yet! - -![Placeholder](https://dummyimage.com/800x400/eee/aaa){: loading=lazy } diff --git a/docs/installation/docker.md b/docs/installation/docker.md deleted file mode 100644 index d6bca9a..0000000 --- a/docs/installation/docker.md +++ /dev/null @@ -1,5 +0,0 @@ ---- -hide: -- toc ---- -# Docker Installation diff --git a/docs/installation/index.md b/docs/installation/index.md deleted file mode 100644 index ce0394d..0000000 --- a/docs/installation/index.md +++ /dev/null @@ -1,21 +0,0 @@ ---- -hide: -- toc ---- -# Standalone Installation - -This guide will help you to get Photos.network up and running in your local environment. - -## Suggested Hardware -It is recommended to use at least the following hardware to get a smooth experience: - - - [Raspberry Pi 4](https://www.raspberrypi.org/products/) - -## Installation - -1. Download the regarding [system image]() -2. Copy the image with [balenaEtcher](https://www.balena.io/etcher/) onto a SD Card -3. Put the SD Card into the Raspberry Pi and power it up -4. Photos.network should be available after a few seconds -5. Open `http://X.X.X.X:8123` in a browser on a different computer in the same network - (replace X.X.X.X with the IP Adress of the Raspberry Pi) diff --git a/docs/privacy.md b/docs/privacy.md deleted file mode 100644 index 0557a91..0000000 --- a/docs/privacy.md +++ /dev/null @@ -1 +0,0 @@ -# Privacy Policy diff --git a/mkdocs.yml b/mkdocs.yml deleted file mode 100644 index 5f7475d..0000000 --- a/mkdocs.yml +++ /dev/null @@ -1,57 +0,0 @@ -site_name: photos.network -site_url: https://photos.network -repo_url: https://github.com/photos-network -repo_name: photos.network -site_description: "https://photos.network is an open source project for self hosted photo management." -site_author: "Stürmer, Benjamin" -copyright: 'Copyright © 2020 Photos network developers' - -extra_css: - - _css/extra.css - -extra_javascript: - - _js/extra.js - -extra: - version: 1.0 - social: - - icon: fontawesome/brands/docker - link: https://hub.docker.com/r/thebino/photos - - icon: fontawesome/brands/twitter - link: https://twitter.com/photos.network - -markdown_extensions: - - attr_list - - admonition - -strict: true - -# Navigation -nav: - - 'Home': 'index.md' - - 'Installation': - - 'Standalone': 'installation/index.md' - - 'Docker': 'installation/docker.md' - - 'Documentation': - - 'Configuration': 'documentation/index.md' - -# Theme -theme: - name: material - custom_dir: overrides - - palette: - - scheme: preference - primary: indigo - accent: pink - - # disable font loading to comply GDPR - font: false - - icon: - logo: material/image - repo: fontawesome/brands/github - - features: - - navigation.instant - - navigation.tabs diff --git a/overrides/partials/footer.html b/overrides/partials/footer.html deleted file mode 100644 index 32bd5be..0000000 --- a/overrides/partials/footer.html +++ /dev/null @@ -1,29 +0,0 @@ -{% import "partials/language.html" as lang with context %} - diff --git a/static/favicon.ico b/static/favicon.ico new file mode 100644 index 0000000..6a8620f Binary files /dev/null and b/static/favicon.ico differ diff --git a/static/icons/android-icon-192x192.png b/static/icons/android-icon-192x192.png new file mode 100644 index 0000000..ef0c8b6 Binary files /dev/null and b/static/icons/android-icon-192x192.png differ diff --git a/static/icons/android-icon-310x310.png b/static/icons/android-icon-310x310.png new file mode 100644 index 0000000..0e6a9b2 Binary files /dev/null and b/static/icons/android-icon-310x310.png differ diff --git a/static/icons/apple-touch-icon.png b/static/icons/apple-touch-icon.png new file mode 100644 index 0000000..6c122b8 Binary files /dev/null and b/static/icons/apple-touch-icon.png differ diff --git a/static/icons/favicon-16x16.png b/static/icons/favicon-16x16.png new file mode 100644 index 0000000..e7305f8 Binary files /dev/null and b/static/icons/favicon-16x16.png differ diff --git a/static/icons/favicon-32x32.png b/static/icons/favicon-32x32.png new file mode 100644 index 0000000..c04768d Binary files /dev/null and b/static/icons/favicon-32x32.png differ diff --git a/static/icons/favicon.ico b/static/icons/favicon.ico new file mode 100644 index 0000000..6a8620f Binary files /dev/null and b/static/icons/favicon.ico differ diff --git a/static/js/jquery-3.6.4.min.js b/static/js/jquery-3.6.4.min.js new file mode 100644 index 0000000..0de648e --- /dev/null +++ b/static/js/jquery-3.6.4.min.js @@ -0,0 +1,2 @@ +/*! jQuery v3.6.4 | (c) OpenJS Foundation and other contributors | jquery.org/license */ +!function(e,t){"use strict";"object"==typeof module&&"object"==typeof module.exports?module.exports=e.document?t(e,!0):function(e){if(!e.document)throw new Error("jQuery requires a window with a document");return t(e)}:t(e)}("undefined"!=typeof window?window:this,function(C,e){"use strict";var t=[],r=Object.getPrototypeOf,s=t.slice,g=t.flat?function(e){return t.flat.call(e)}:function(e){return t.concat.apply([],e)},u=t.push,i=t.indexOf,n={},o=n.toString,y=n.hasOwnProperty,a=y.toString,l=a.call(Object),v={},m=function(e){return"function"==typeof e&&"number"!=typeof e.nodeType&&"function"!=typeof e.item},x=function(e){return null!=e&&e===e.window},E=C.document,c={type:!0,src:!0,nonce:!0,noModule:!0};function b(e,t,n){var r,i,o=(n=n||E).createElement("script");if(o.text=e,t)for(r in c)(i=t[r]||t.getAttribute&&t.getAttribute(r))&&o.setAttribute(r,i);n.head.appendChild(o).parentNode.removeChild(o)}function w(e){return null==e?e+"":"object"==typeof e||"function"==typeof e?n[o.call(e)]||"object":typeof e}var f="3.6.4",S=function(e,t){return new S.fn.init(e,t)};function p(e){var t=!!e&&"length"in e&&e.length,n=w(e);return!m(e)&&!x(e)&&("array"===n||0===t||"number"==typeof t&&0+~]|"+M+")"+M+"*"),U=new RegExp(M+"|>"),X=new RegExp(F),V=new RegExp("^"+I+"$"),G={ID:new RegExp("^#("+I+")"),CLASS:new RegExp("^\\.("+I+")"),TAG:new RegExp("^("+I+"|[*])"),ATTR:new RegExp("^"+W),PSEUDO:new RegExp("^"+F),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+M+"*(even|odd|(([+-]|)(\\d*)n|)"+M+"*(?:([+-]|)"+M+"*(\\d+)|))"+M+"*\\)|)","i"),bool:new RegExp("^(?:"+R+")$","i"),needsContext:new RegExp("^"+M+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+M+"*((?:-\\d)?\\d*)"+M+"*\\)|)(?=[^-]|$)","i")},Y=/HTML$/i,Q=/^(?:input|select|textarea|button)$/i,J=/^h\d$/i,K=/^[^{]+\{\s*\[native \w/,Z=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,ee=/[+~]/,te=new RegExp("\\\\[\\da-fA-F]{1,6}"+M+"?|\\\\([^\\r\\n\\f])","g"),ne=function(e,t){var n="0x"+e.slice(1)-65536;return t||(n<0?String.fromCharCode(n+65536):String.fromCharCode(n>>10|55296,1023&n|56320))},re=/([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,ie=function(e,t){return t?"\0"===e?"\ufffd":e.slice(0,-1)+"\\"+e.charCodeAt(e.length-1).toString(16)+" ":"\\"+e},oe=function(){T()},ae=be(function(e){return!0===e.disabled&&"fieldset"===e.nodeName.toLowerCase()},{dir:"parentNode",next:"legend"});try{H.apply(t=O.call(p.childNodes),p.childNodes),t[p.childNodes.length].nodeType}catch(e){H={apply:t.length?function(e,t){L.apply(e,O.call(t))}:function(e,t){var n=e.length,r=0;while(e[n++]=t[r++]);e.length=n-1}}}function se(t,e,n,r){var i,o,a,s,u,l,c,f=e&&e.ownerDocument,p=e?e.nodeType:9;if(n=n||[],"string"!=typeof t||!t||1!==p&&9!==p&&11!==p)return n;if(!r&&(T(e),e=e||C,E)){if(11!==p&&(u=Z.exec(t)))if(i=u[1]){if(9===p){if(!(a=e.getElementById(i)))return n;if(a.id===i)return n.push(a),n}else if(f&&(a=f.getElementById(i))&&v(e,a)&&a.id===i)return n.push(a),n}else{if(u[2])return H.apply(n,e.getElementsByTagName(t)),n;if((i=u[3])&&d.getElementsByClassName&&e.getElementsByClassName)return H.apply(n,e.getElementsByClassName(i)),n}if(d.qsa&&!N[t+" "]&&(!y||!y.test(t))&&(1!==p||"object"!==e.nodeName.toLowerCase())){if(c=t,f=e,1===p&&(U.test(t)||z.test(t))){(f=ee.test(t)&&ve(e.parentNode)||e)===e&&d.scope||((s=e.getAttribute("id"))?s=s.replace(re,ie):e.setAttribute("id",s=S)),o=(l=h(t)).length;while(o--)l[o]=(s?"#"+s:":scope")+" "+xe(l[o]);c=l.join(",")}try{return H.apply(n,f.querySelectorAll(c)),n}catch(e){N(t,!0)}finally{s===S&&e.removeAttribute("id")}}}return g(t.replace(B,"$1"),e,n,r)}function ue(){var r=[];return function e(t,n){return r.push(t+" ")>b.cacheLength&&delete e[r.shift()],e[t+" "]=n}}function le(e){return e[S]=!0,e}function ce(e){var t=C.createElement("fieldset");try{return!!e(t)}catch(e){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function fe(e,t){var n=e.split("|"),r=n.length;while(r--)b.attrHandle[n[r]]=t}function pe(e,t){var n=t&&e,r=n&&1===e.nodeType&&1===t.nodeType&&e.sourceIndex-t.sourceIndex;if(r)return r;if(n)while(n=n.nextSibling)if(n===t)return-1;return e?1:-1}function de(t){return function(e){return"input"===e.nodeName.toLowerCase()&&e.type===t}}function he(n){return function(e){var t=e.nodeName.toLowerCase();return("input"===t||"button"===t)&&e.type===n}}function ge(t){return function(e){return"form"in e?e.parentNode&&!1===e.disabled?"label"in e?"label"in e.parentNode?e.parentNode.disabled===t:e.disabled===t:e.isDisabled===t||e.isDisabled!==!t&&ae(e)===t:e.disabled===t:"label"in e&&e.disabled===t}}function ye(a){return le(function(o){return o=+o,le(function(e,t){var n,r=a([],e.length,o),i=r.length;while(i--)e[n=r[i]]&&(e[n]=!(t[n]=e[n]))})})}function ve(e){return e&&"undefined"!=typeof e.getElementsByTagName&&e}for(e in d=se.support={},i=se.isXML=function(e){var t=e&&e.namespaceURI,n=e&&(e.ownerDocument||e).documentElement;return!Y.test(t||n&&n.nodeName||"HTML")},T=se.setDocument=function(e){var t,n,r=e?e.ownerDocument||e:p;return r!=C&&9===r.nodeType&&r.documentElement&&(a=(C=r).documentElement,E=!i(C),p!=C&&(n=C.defaultView)&&n.top!==n&&(n.addEventListener?n.addEventListener("unload",oe,!1):n.attachEvent&&n.attachEvent("onunload",oe)),d.scope=ce(function(e){return a.appendChild(e).appendChild(C.createElement("div")),"undefined"!=typeof e.querySelectorAll&&!e.querySelectorAll(":scope fieldset div").length}),d.cssHas=ce(function(){try{return C.querySelector(":has(*,:jqfake)"),!1}catch(e){return!0}}),d.attributes=ce(function(e){return e.className="i",!e.getAttribute("className")}),d.getElementsByTagName=ce(function(e){return e.appendChild(C.createComment("")),!e.getElementsByTagName("*").length}),d.getElementsByClassName=K.test(C.getElementsByClassName),d.getById=ce(function(e){return a.appendChild(e).id=S,!C.getElementsByName||!C.getElementsByName(S).length}),d.getById?(b.filter.ID=function(e){var t=e.replace(te,ne);return function(e){return e.getAttribute("id")===t}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n=t.getElementById(e);return n?[n]:[]}}):(b.filter.ID=function(e){var n=e.replace(te,ne);return function(e){var t="undefined"!=typeof e.getAttributeNode&&e.getAttributeNode("id");return t&&t.value===n}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n,r,i,o=t.getElementById(e);if(o){if((n=o.getAttributeNode("id"))&&n.value===e)return[o];i=t.getElementsByName(e),r=0;while(o=i[r++])if((n=o.getAttributeNode("id"))&&n.value===e)return[o]}return[]}}),b.find.TAG=d.getElementsByTagName?function(e,t){return"undefined"!=typeof t.getElementsByTagName?t.getElementsByTagName(e):d.qsa?t.querySelectorAll(e):void 0}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if("*"===e){while(n=o[i++])1===n.nodeType&&r.push(n);return r}return o},b.find.CLASS=d.getElementsByClassName&&function(e,t){if("undefined"!=typeof t.getElementsByClassName&&E)return t.getElementsByClassName(e)},s=[],y=[],(d.qsa=K.test(C.querySelectorAll))&&(ce(function(e){var t;a.appendChild(e).innerHTML="",e.querySelectorAll("[msallowcapture^='']").length&&y.push("[*^$]="+M+"*(?:''|\"\")"),e.querySelectorAll("[selected]").length||y.push("\\["+M+"*(?:value|"+R+")"),e.querySelectorAll("[id~="+S+"-]").length||y.push("~="),(t=C.createElement("input")).setAttribute("name",""),e.appendChild(t),e.querySelectorAll("[name='']").length||y.push("\\["+M+"*name"+M+"*="+M+"*(?:''|\"\")"),e.querySelectorAll(":checked").length||y.push(":checked"),e.querySelectorAll("a#"+S+"+*").length||y.push(".#.+[+~]"),e.querySelectorAll("\\\f"),y.push("[\\r\\n\\f]")}),ce(function(e){e.innerHTML="";var t=C.createElement("input");t.setAttribute("type","hidden"),e.appendChild(t).setAttribute("name","D"),e.querySelectorAll("[name=d]").length&&y.push("name"+M+"*[*^$|!~]?="),2!==e.querySelectorAll(":enabled").length&&y.push(":enabled",":disabled"),a.appendChild(e).disabled=!0,2!==e.querySelectorAll(":disabled").length&&y.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),y.push(",.*:")})),(d.matchesSelector=K.test(c=a.matches||a.webkitMatchesSelector||a.mozMatchesSelector||a.oMatchesSelector||a.msMatchesSelector))&&ce(function(e){d.disconnectedMatch=c.call(e,"*"),c.call(e,"[s!='']:x"),s.push("!=",F)}),d.cssHas||y.push(":has"),y=y.length&&new RegExp(y.join("|")),s=s.length&&new RegExp(s.join("|")),t=K.test(a.compareDocumentPosition),v=t||K.test(a.contains)?function(e,t){var n=9===e.nodeType&&e.documentElement||e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)while(t=t.parentNode)if(t===e)return!0;return!1},j=t?function(e,t){if(e===t)return l=!0,0;var n=!e.compareDocumentPosition-!t.compareDocumentPosition;return n||(1&(n=(e.ownerDocument||e)==(t.ownerDocument||t)?e.compareDocumentPosition(t):1)||!d.sortDetached&&t.compareDocumentPosition(e)===n?e==C||e.ownerDocument==p&&v(p,e)?-1:t==C||t.ownerDocument==p&&v(p,t)?1:u?P(u,e)-P(u,t):0:4&n?-1:1)}:function(e,t){if(e===t)return l=!0,0;var n,r=0,i=e.parentNode,o=t.parentNode,a=[e],s=[t];if(!i||!o)return e==C?-1:t==C?1:i?-1:o?1:u?P(u,e)-P(u,t):0;if(i===o)return pe(e,t);n=e;while(n=n.parentNode)a.unshift(n);n=t;while(n=n.parentNode)s.unshift(n);while(a[r]===s[r])r++;return r?pe(a[r],s[r]):a[r]==p?-1:s[r]==p?1:0}),C},se.matches=function(e,t){return se(e,null,null,t)},se.matchesSelector=function(e,t){if(T(e),d.matchesSelector&&E&&!N[t+" "]&&(!s||!s.test(t))&&(!y||!y.test(t)))try{var n=c.call(e,t);if(n||d.disconnectedMatch||e.document&&11!==e.document.nodeType)return n}catch(e){N(t,!0)}return 0":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(te,ne),e[3]=(e[3]||e[4]||e[5]||"").replace(te,ne),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||se.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&se.error(e[0]),e},PSEUDO:function(e){var t,n=!e[6]&&e[2];return G.CHILD.test(e[0])?null:(e[3]?e[2]=e[4]||e[5]||"":n&&X.test(n)&&(t=h(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(te,ne).toLowerCase();return"*"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=m[e+" "];return t||(t=new RegExp("(^|"+M+")"+e+"("+M+"|$)"))&&m(e,function(e){return t.test("string"==typeof e.className&&e.className||"undefined"!=typeof e.getAttribute&&e.getAttribute("class")||"")})},ATTR:function(n,r,i){return function(e){var t=se.attr(e,n);return null==t?"!="===r:!r||(t+="","="===r?t===i:"!="===r?t!==i:"^="===r?i&&0===t.indexOf(i):"*="===r?i&&-1:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i;function j(e,n,r){return m(n)?S.grep(e,function(e,t){return!!n.call(e,t,e)!==r}):n.nodeType?S.grep(e,function(e){return e===n!==r}):"string"!=typeof n?S.grep(e,function(e){return-1)[^>]*|#([\w-]+))$/;(S.fn.init=function(e,t,n){var r,i;if(!e)return this;if(n=n||D,"string"==typeof e){if(!(r="<"===e[0]&&">"===e[e.length-1]&&3<=e.length?[null,e,null]:q.exec(e))||!r[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(r[1]){if(t=t instanceof S?t[0]:t,S.merge(this,S.parseHTML(r[1],t&&t.nodeType?t.ownerDocument||t:E,!0)),N.test(r[1])&&S.isPlainObject(t))for(r in t)m(this[r])?this[r](t[r]):this.attr(r,t[r]);return this}return(i=E.getElementById(r[2]))&&(this[0]=i,this.length=1),this}return e.nodeType?(this[0]=e,this.length=1,this):m(e)?void 0!==n.ready?n.ready(e):e(S):S.makeArray(e,this)}).prototype=S.fn,D=S(E);var L=/^(?:parents|prev(?:Until|All))/,H={children:!0,contents:!0,next:!0,prev:!0};function O(e,t){while((e=e[t])&&1!==e.nodeType);return e}S.fn.extend({has:function(e){var t=S(e,this),n=t.length;return this.filter(function(){for(var e=0;e\x20\t\r\n\f]*)/i,he=/^$|^module$|\/(?:java|ecma)script/i;ce=E.createDocumentFragment().appendChild(E.createElement("div")),(fe=E.createElement("input")).setAttribute("type","radio"),fe.setAttribute("checked","checked"),fe.setAttribute("name","t"),ce.appendChild(fe),v.checkClone=ce.cloneNode(!0).cloneNode(!0).lastChild.checked,ce.innerHTML="",v.noCloneChecked=!!ce.cloneNode(!0).lastChild.defaultValue,ce.innerHTML="",v.option=!!ce.lastChild;var ge={thead:[1,"","
"],col:[2,"","
"],tr:[2,"","
"],td:[3,"","
"],_default:[0,"",""]};function ye(e,t){var n;return n="undefined"!=typeof e.getElementsByTagName?e.getElementsByTagName(t||"*"):"undefined"!=typeof e.querySelectorAll?e.querySelectorAll(t||"*"):[],void 0===t||t&&A(e,t)?S.merge([e],n):n}function ve(e,t){for(var n=0,r=e.length;n",""]);var me=/<|&#?\w+;/;function xe(e,t,n,r,i){for(var o,a,s,u,l,c,f=t.createDocumentFragment(),p=[],d=0,h=e.length;d\s*$/g;function je(e,t){return A(e,"table")&&A(11!==t.nodeType?t:t.firstChild,"tr")&&S(e).children("tbody")[0]||e}function De(e){return e.type=(null!==e.getAttribute("type"))+"/"+e.type,e}function qe(e){return"true/"===(e.type||"").slice(0,5)?e.type=e.type.slice(5):e.removeAttribute("type"),e}function Le(e,t){var n,r,i,o,a,s;if(1===t.nodeType){if(Y.hasData(e)&&(s=Y.get(e).events))for(i in Y.remove(t,"handle events"),s)for(n=0,r=s[i].length;n").attr(n.scriptAttrs||{}).prop({charset:n.scriptCharset,src:n.url}).on("load error",i=function(e){r.remove(),i=null,e&&t("error"===e.type?404:200,e.type)}),E.head.appendChild(r[0])},abort:function(){i&&i()}}});var Ut,Xt=[],Vt=/(=)\?(?=&|$)|\?\?/;S.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var e=Xt.pop()||S.expando+"_"+Ct.guid++;return this[e]=!0,e}}),S.ajaxPrefilter("json jsonp",function(e,t,n){var r,i,o,a=!1!==e.jsonp&&(Vt.test(e.url)?"url":"string"==typeof e.data&&0===(e.contentType||"").indexOf("application/x-www-form-urlencoded")&&Vt.test(e.data)&&"data");if(a||"jsonp"===e.dataTypes[0])return r=e.jsonpCallback=m(e.jsonpCallback)?e.jsonpCallback():e.jsonpCallback,a?e[a]=e[a].replace(Vt,"$1"+r):!1!==e.jsonp&&(e.url+=(Et.test(e.url)?"&":"?")+e.jsonp+"="+r),e.converters["script json"]=function(){return o||S.error(r+" was not called"),o[0]},e.dataTypes[0]="json",i=C[r],C[r]=function(){o=arguments},n.always(function(){void 0===i?S(C).removeProp(r):C[r]=i,e[r]&&(e.jsonpCallback=t.jsonpCallback,Xt.push(r)),o&&m(i)&&i(o[0]),o=i=void 0}),"script"}),v.createHTMLDocument=((Ut=E.implementation.createHTMLDocument("").body).innerHTML="
",2===Ut.childNodes.length),S.parseHTML=function(e,t,n){return"string"!=typeof e?[]:("boolean"==typeof t&&(n=t,t=!1),t||(v.createHTMLDocument?((r=(t=E.implementation.createHTMLDocument("")).createElement("base")).href=E.location.href,t.head.appendChild(r)):t=E),o=!n&&[],(i=N.exec(e))?[t.createElement(i[1])]:(i=xe([e],t,o),o&&o.length&&S(o).remove(),S.merge([],i.childNodes)));var r,i,o},S.fn.load=function(e,t,n){var r,i,o,a=this,s=e.indexOf(" ");return-1").append(S.parseHTML(e)).find(r):e)}).always(n&&function(e,t){a.each(function(){n.apply(this,o||[e.responseText,t,e])})}),this},S.expr.pseudos.animated=function(t){return S.grep(S.timers,function(e){return t===e.elem}).length},S.offset={setOffset:function(e,t,n){var r,i,o,a,s,u,l=S.css(e,"position"),c=S(e),f={};"static"===l&&(e.style.position="relative"),s=c.offset(),o=S.css(e,"top"),u=S.css(e,"left"),("absolute"===l||"fixed"===l)&&-1<(o+u).indexOf("auto")?(a=(r=c.position()).top,i=r.left):(a=parseFloat(o)||0,i=parseFloat(u)||0),m(t)&&(t=t.call(e,n,S.extend({},s))),null!=t.top&&(f.top=t.top-s.top+a),null!=t.left&&(f.left=t.left-s.left+i),"using"in t?t.using.call(e,f):c.css(f)}},S.fn.extend({offset:function(t){if(arguments.length)return void 0===t?this:this.each(function(e){S.offset.setOffset(this,t,e)});var e,n,r=this[0];return r?r.getClientRects().length?(e=r.getBoundingClientRect(),n=r.ownerDocument.defaultView,{top:e.top+n.pageYOffset,left:e.left+n.pageXOffset}):{top:0,left:0}:void 0},position:function(){if(this[0]){var e,t,n,r=this[0],i={top:0,left:0};if("fixed"===S.css(r,"position"))t=r.getBoundingClientRect();else{t=this.offset(),n=r.ownerDocument,e=r.offsetParent||n.documentElement;while(e&&(e===n.body||e===n.documentElement)&&"static"===S.css(e,"position"))e=e.parentNode;e&&e!==r&&1===e.nodeType&&((i=S(e).offset()).top+=S.css(e,"borderTopWidth",!0),i.left+=S.css(e,"borderLeftWidth",!0))}return{top:t.top-i.top-S.css(r,"marginTop",!0),left:t.left-i.left-S.css(r,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){var e=this.offsetParent;while(e&&"static"===S.css(e,"position"))e=e.offsetParent;return e||re})}}),S.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(t,i){var o="pageYOffset"===i;S.fn[t]=function(e){return B(this,function(e,t,n){var r;if(x(e)?r=e:9===e.nodeType&&(r=e.defaultView),void 0===n)return r?r[i]:e[t];r?r.scrollTo(o?r.pageXOffset:n,o?n:r.pageYOffset):e[t]=n},t,e,arguments.length)}}),S.each(["top","left"],function(e,n){S.cssHooks[n]=_e(v.pixelPosition,function(e,t){if(t)return t=Be(e,n),Pe.test(t)?S(e).position()[n]+"px":t})}),S.each({Height:"height",Width:"width"},function(a,s){S.each({padding:"inner"+a,content:s,"":"outer"+a},function(r,o){S.fn[o]=function(e,t){var n=arguments.length&&(r||"boolean"!=typeof e),i=r||(!0===e||!0===t?"margin":"border");return B(this,function(e,t,n){var r;return x(e)?0===o.indexOf("outer")?e["inner"+a]:e.document.documentElement["client"+a]:9===e.nodeType?(r=e.documentElement,Math.max(e.body["scroll"+a],r["scroll"+a],e.body["offset"+a],r["offset"+a],r["client"+a])):void 0===n?S.css(e,t,i):S.style(e,t,n,i)},s,n?e:void 0,n)}})}),S.each(["ajaxStart","ajaxStop","ajaxComplete","ajaxError","ajaxSuccess","ajaxSend"],function(e,t){S.fn[t]=function(e){return this.on(t,e)}}),S.fn.extend({bind:function(e,t,n){return this.on(e,null,t,n)},unbind:function(e,t){return this.off(e,null,t)},delegate:function(e,t,n,r){return this.on(t,e,n,r)},undelegate:function(e,t,n){return 1===arguments.length?this.off(e,"**"):this.off(t,e||"**",n)},hover:function(e,t){return this.mouseenter(e).mouseleave(t||e)}}),S.each("blur focus focusin focusout resize scroll click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup contextmenu".split(" "),function(e,n){S.fn[n]=function(e,t){return 0 + +
+
+

© 2020 Photos network developers

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+ + + + + {% if config.extra.enable_search %} + + + + {% endif %} + + + {% if config.extra.enable_multilingue %} + + {% endif %} + + + {% block extra_js %} + {% endblock extra_js %} + + diff --git a/templates/inc_navigation.html b/templates/inc_navigation.html new file mode 100644 index 0000000..6660a2b --- /dev/null +++ b/templates/inc_navigation.html @@ -0,0 +1,192 @@ + \ No newline at end of file diff --git a/templates/index.html b/templates/index.html new file mode 100644 index 0000000..4889d57 --- /dev/null +++ b/templates/index.html @@ -0,0 +1,240 @@ +{% extends "layout.html" %} + +{% block content %} + +
+ + +
+ +
+
+

Self-hosted photo sharing

+

Photos.network is a self-hosted, privacy first and extensible photo storage and sharing service.

+

Instead of relaying on big companies, keep full control of all access rights.

+
+
+ +
+ + +
+
+
+

Find photos and videos

+

When searching for photos and videos from the past, there are 3 major factors.

+
+ + +
+ ecommerce +
+

Taken at a specific location

+ +

People wanna share photos and videos from a vacation trip, a weekend travel or from any place they visited. They remember the approximate or even the precise position. Searching on a map or by entering locations like countries, cities or even geo positions will help users.

+
+
+ + +
+
+

Containing people or objects

+ +

Remembering other people or objects beeing present when the photo or video was taken. Label and group items by faces

+
+ ecommerce +
+ + +
+ ecommerce +
+

Browse through time

+ +

Sometimes people are just looking for a photo taken during a range of time, like a season or an annual event. All items will be tagged by the date they are taken and when added to the system.

+
+
+
+
+ + +
+
+ +
+

Roadmap

+

What is the current roadmap of the project.

+
+ + +
+
+
+
+
+
+
+ + + + +
+
+

Proof of concept

+

In the PoC the idea was put to test on real scenarious.

+
+
+
+ + +
+
+
+
+
+
+
+ + + + +
+
+

MvP

+

The Minimum viable product contains just the base features to create media items, attach photos and videos to it and browse owned items.

+
+
+
+ + +
+
+
+
+
 
+
+
+ + + + +
+
+

Sharing internal

+

Sharing albums with other accounts on the same instance.

+
+
+
+ + +
+
+
+
+
 
+
+
+ + + + + +
+
+

Sharing publicly

+

Click on a link and browse through a shared album without the need of an account.

+
+
+
+ + +
+
+
+
+
 
+
+
+ + + + + +
+
+

Reinforcement learning

+

Group and categorize photos and videos based on previous user labels to get better results.

+
+
+
+
+
+ + + +
+
+
+

Frequently asked questions

+

If you have anything else you want to ask, reach out to us.

+
+
    +
  • +
      + +
    • +

      Where comes the hype from?

      +

      With the enforcement of GDPR in May 2018 an increased interested in data privacy arrised. Also the aquiring and discontinuing of the famous image organizer Picassa left a lot of users behind.

      +
    • + +
    +
  • +
  • +
      + + +
    • +

      Why another photo management application?

      The list of photo and video gallery projects out there is amazing. Testing most of them ended in at least one of few complains:

      + +
        +
      • sluggish performance
      • +
      • hard installation and setup
      • +
      • not working with an existing folder structure
      • +
      • supporting multiple TB of photos and videos
      • +
      • process RAW files
      • +
      • lack of control
      • +
      • data privacy
      • +
      +
    • + +
    +
  • +
  • +
      + + +
    • +

      Why not use or contribute to one of the big players?

      +

      Here’s the thing: you’re the one doing the insider trading, not us. We’re just giving you the tips and some tools to make trades. We’re not doing anything wrong here.

      +
        +
      • Plex is great for browsing and viewing photos, but it doesn't offer an API for 3rd party clients.
      • +
      • Nextcloud can't work with RAW files nor with existing folder structures
      • +
      • Ownphotos not maintained anymore
      • +
      • LibrePhotos (Ownphotos fork) lacks of extensibility
      • +
      +
    • + +
    +
  • +
+
+
+ + + +
+{% endblock content %} diff --git a/templates/layout.html b/templates/layout.html new file mode 100644 index 0000000..983c1ed --- /dev/null +++ b/templates/layout.html @@ -0,0 +1,54 @@ + + + + + + + + {% block title %} + {{ config.title }} + {% endblock title %} + + + + + {% if config.extra.favicon.webmanifest %} + + {% endif %} + {% if config.extra.favicon.favicon_16x16 %} + + {% endif %} + {% if config.extra.favicon.favicon_32x32 %} + + {% endif %} + {% if config.extra.favicon.android_chrome_512 %} + + {% endif %} + {% if config.extra.favicon.android_chrome_192 %} + + {% endif %} + {% if config.extra.favicon.apple_touch_icon %} + + {% endif %} + {% if config.extra.favicon.apple_touch_icon %} + + {% endif %} + + + + + + + + + +{% include "inc_navigation.html" %} + + + +{% block content %} + {{ page.content | safe }} +{% endblock content %} + + +{% include "inc_footer.html" %} diff --git a/templates/page.html b/templates/page.html new file mode 100644 index 0000000..763fc03 --- /dev/null +++ b/templates/page.html @@ -0,0 +1,19 @@ +{% extends "layout.html" %} + +{% block content %} +
+
+ +

{{ page.title }}

+ +
+
+ + {{ page.content | safe }} + +
+
+ +
+
+{% endblock content %}