shaarpy


Nameshaarpy JSON
Version 1.2.0 PyPI version JSON
download
home_pagehttps://github.com/foxmask/shaarpy/
SummaryShaarPy: Share your thoughts, links, ideas, notes. self-hosting bookmarks and micro blogging. If you ever wanted Shaarli in python, that's it ^_*
upload_time2025-01-05 15:37:05
maintainerNone
docs_urlNone
author폭스마스크
requires_python>=3.11
licenseDO WHAT THE FUCK YOU WANT TO PUBLIC LICENSE Version 2, December 2004 Copyright (C) 2022 FoxMaSk <foxmask+wtfpl@pm.me> Everyone is permitted to copy and distribute verbatim or modified copies of this license document, and changing it is allowed as long as the name is changed. DO WHAT THE FUCK YOU WANT TO PUBLIC LICENSE TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION 0. You just DO WHAT THE FUCK YOU WANT TO.
keywords python django shaarli
VCS
bugtrack_url
requirements Django django-environ django-simple-search Markdown rich pytz python-slugify Jinja2
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # ShaarPy

<img src="https://github.com/foxmask/shaarpy/blob/main/docs/shaarpy.png" height="179" width="200"/>

Share Thoughts, Ideas, Links, Notes.

a 'Shaarli cloned' in Python made with Django

![Main page](https://github.com/foxmask/shaarpy/blob/main/docs/shaarpy_home.png)

## Features

* bookmarking
* microblogging

### Notes

- Create *notes* in **Markdown**

### Links

- Drop a URL and ShaarPy will grab the article page with **image** and **video** if the source website provides ones
<a href="https://github.com/foxmask/shaarpy/blob/main/docs/shaarpy_article.png"><img src="https://github.com/foxmask/shaarpy/blob/main/docs/shaarpy_article.png" alt="article with image" width="400"/></a>

### Tags

- Manage tags
- Tag Cloud

<a href="https://github.com/foxmask/shaarpy/blob/main/docs/tags_list.png"><img src="https://github.com/foxmask/shaarpy/blob/main/docs/tags_list.png" alt="tag cloud" width="400"/></a>

### Daily links history

- See the links of the day and navigate throw the calendar to go back to your old links

<a href="https://github.com/foxmask/shaarpy/blob/main/docs/daily.png"><img src="https://github.com/foxmask/shaarpy/blob/main/docs/daily.png" alt="daily links" width="400"/></a>

### Tools

- for each link added, a markdown file can be create in a folder that will be sync on your mobile with the help of "[syncthing](https://syncthing.net/)"
- Import of  **Shaarli** exported bookmark, or even **FireFox** bookmarks
- you can export/import your data in **json**
- Import your Pelican blog markdown files

**export**

```bash
python manage.py dumpdata --format json --indent 2 > fixtures/my_shaarpy_dump.json
```

**import**

```bash
python manage.py loaddata --format json  fixtures/my_shaarpy_dump.json
```

### Bookmarklet

Drag the link you'll find under your profile, to the bookmark of the browser

![Bookmarklet](https://github.com/foxmask/shaarpy/blob/main/docs/bookmarklet.png)

Now you'are able to post a new link just be clicking this bookmarklet wherever you are on the web

## Links sync on mobile

If you don't host ShaarPy on a dedicated server, you can run it locally and sync the links in markdown file and sync them on mobile.

Then files are generated, you may found them on your mobile (thanks to syncthing for managing that task)


### original webpage

![Link of the website](https://github.com/foxmask/shaarpy/blob/main/docs/shaarpy_article_website.png)

### shaarpy grabbed link

![Link in shaarpy](https://github.com/foxmask/shaarpy/blob/main/docs/shaarpy_article.png)

### shaarpy link on mobile

![Shaarpy link on mobile](https://github.com/foxmask/shaarpy/blob/main/docs/article_mobile.png)

(I use "Epsilon Notes" for that)


## Installation

## :package: Installation

### Requirements

* Python from 3.11 3.12 3.13
* Django from 5.1+

### Installation

create a virtualenv

```bash
python3 -m venv shaarpy
cd shaarpy
source bin/activate
```

install the project

```bash
git clone https://github.com/foxmask/shaarpy.git
cd shaarpy
```

##  :wrench: Settings

copy the sample config file

```bash
cp env.sample .env
```

and set the following values, for examples

```ini
# for meta
SHAARPY_NAME=Shaarpy
SHAARPY_DESCRIPTION=Share thoughts, links ideas, notes
SHAARPY_AUTHOR=FoxMaSk
SHAARPY_ROBOT=index, follow
# for MD generation, set a path eg /home/foxmask/MesNotes/links or leave it empty to not use this feature
SHAARPY_LOCALSTORAGE_MD=
SHAARPY_STYLE=blue

SECRET=!DONTFORGETTOCHANGETHISVALUE!

# for production environment, set it to the URL of your 'ShaarPy'
# 1 set it to False
DEBUG=False
# 2 set it to the URL of your 'ShaarPy'
ALLOWED_HOSTS='127.0.0.1,localhost'
# 3 set it to your own domain hosting shaarpy
CSRF_TRUSTED_ORIGINS=https://*.mydomain.com

# for database
DB_ENGINE='django.db.backends.sqlite3'
DB_NAME='db.sqlite3'
DB_USER=''
DB_PASSWORD=''
DB_HOST=''
DB_PORT=''

# i18n/l10n
TIME_ZONE='Europe/Paris'
LANGUAGE_CODE='en-en'
USE_I18N=True
USE_TZ=True
```

## :dvd: Database

setup the database

```bash
cd shaarpy
python manage.py migrate
python manage.py createsuperuser
python manage.py loaddata shaarpy/fixtures/my_shaarpy_data.json
```

## :mega: Running the Server

### start the project

```bash
python manage.py runserver localhost:8001
```

then, access the project with your browser http://127.0.0.1:8001/

### Test

```bash
python manage.py test
```

or

```bash
pytest
```
or

```bash
coverage run --source='.' -m pytest
coverage report -m
```


## DOCKER

build the image and run the container

```bash
sudo docker compose up --build -d
```

then, the first installation, do:

```bash
sudo docker compose exec web python manage.py migrate --noinput
sudo docker compose exec web python manage.py createsuperuser
```


## Logo

(logo, thanks to [https://pixabay.com/fr/users/clker-free-vector-images-3736/](https://pixabay.com/fr/vectors/serpent-python-vert-reptile-faune-312561/) )

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/foxmask/shaarpy/",
    "name": "shaarpy",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.11",
    "maintainer_email": null,
    "keywords": "python django shaarli",
    "author": "\ud3ed\uc2a4\ub9c8\uc2a4\ud06c",
    "author_email": "\ud3ed\uc2a4\ub9c8\uc2a4\ud06c <foxmask+git@pm.me>",
    "download_url": "https://files.pythonhosted.org/packages/81/4f/50baa9f2f3c3a572eef35f98cd57ae7be0394bae8fac2286aa529ceef1e7/shaarpy-1.2.0.tar.gz",
    "platform": null,
    "description": "# ShaarPy\n\n<img src=\"https://github.com/foxmask/shaarpy/blob/main/docs/shaarpy.png\" height=\"179\" width=\"200\"/>\n\nShare Thoughts, Ideas, Links, Notes.\n\na 'Shaarli cloned' in Python made with Django\n\n![Main page](https://github.com/foxmask/shaarpy/blob/main/docs/shaarpy_home.png)\n\n## Features\n\n* bookmarking\n* microblogging\n\n### Notes\n\n- Create *notes* in **Markdown**\n\n### Links\n\n- Drop a URL and ShaarPy will grab the article page with **image** and **video** if the source website provides ones\n<a href=\"https://github.com/foxmask/shaarpy/blob/main/docs/shaarpy_article.png\"><img src=\"https://github.com/foxmask/shaarpy/blob/main/docs/shaarpy_article.png\" alt=\"article with image\" width=\"400\"/></a>\n\n### Tags\n\n- Manage tags\n- Tag Cloud\n\n<a href=\"https://github.com/foxmask/shaarpy/blob/main/docs/tags_list.png\"><img src=\"https://github.com/foxmask/shaarpy/blob/main/docs/tags_list.png\" alt=\"tag cloud\" width=\"400\"/></a>\n\n### Daily links history\n\n- See the links of the day and navigate throw the calendar to go back to your old links\n\n<a href=\"https://github.com/foxmask/shaarpy/blob/main/docs/daily.png\"><img src=\"https://github.com/foxmask/shaarpy/blob/main/docs/daily.png\" alt=\"daily links\" width=\"400\"/></a>\n\n### Tools\n\n- for each link added, a markdown file can be create in a folder that will be sync on your mobile with the help of \"[syncthing](https://syncthing.net/)\"\n- Import of  **Shaarli** exported bookmark, or even **FireFox** bookmarks\n- you can export/import your data in **json**\n- Import your Pelican blog markdown files\n\n**export**\n\n```bash\npython manage.py dumpdata --format json --indent 2 > fixtures/my_shaarpy_dump.json\n```\n\n**import**\n\n```bash\npython manage.py loaddata --format json  fixtures/my_shaarpy_dump.json\n```\n\n### Bookmarklet\n\nDrag the link you'll find under your profile, to the bookmark of the browser\n\n![Bookmarklet](https://github.com/foxmask/shaarpy/blob/main/docs/bookmarklet.png)\n\nNow you'are able to post a new link just be clicking this bookmarklet wherever you are on the web\n\n## Links sync on mobile\n\nIf you don't host ShaarPy on a dedicated server, you can run it locally and sync the links in markdown file and sync them on mobile.\n\nThen files are generated, you may found them on your mobile (thanks to syncthing for managing that task)\n\n\n### original webpage\n\n![Link of the website](https://github.com/foxmask/shaarpy/blob/main/docs/shaarpy_article_website.png)\n\n### shaarpy grabbed link\n\n![Link in shaarpy](https://github.com/foxmask/shaarpy/blob/main/docs/shaarpy_article.png)\n\n### shaarpy link on mobile\n\n![Shaarpy link on mobile](https://github.com/foxmask/shaarpy/blob/main/docs/article_mobile.png)\n\n(I use \"Epsilon Notes\" for that)\n\n\n## Installation\n\n## :package: Installation\n\n### Requirements\n\n* Python from 3.11 3.12 3.13\n* Django from 5.1+\n\n### Installation\n\ncreate a virtualenv\n\n```bash\npython3 -m venv shaarpy\ncd shaarpy\nsource bin/activate\n```\n\ninstall the project\n\n```bash\ngit clone https://github.com/foxmask/shaarpy.git\ncd shaarpy\n```\n\n##  :wrench: Settings\n\ncopy the sample config file\n\n```bash\ncp env.sample .env\n```\n\nand set the following values, for examples\n\n```ini\n# for meta\nSHAARPY_NAME=Shaarpy\nSHAARPY_DESCRIPTION=Share thoughts, links ideas, notes\nSHAARPY_AUTHOR=FoxMaSk\nSHAARPY_ROBOT=index, follow\n# for MD generation, set a path eg /home/foxmask/MesNotes/links or leave it empty to not use this feature\nSHAARPY_LOCALSTORAGE_MD=\nSHAARPY_STYLE=blue\n\nSECRET=!DONTFORGETTOCHANGETHISVALUE!\n\n# for production environment, set it to the URL of your 'ShaarPy'\n# 1 set it to False\nDEBUG=False\n# 2 set it to the URL of your 'ShaarPy'\nALLOWED_HOSTS='127.0.0.1,localhost'\n# 3 set it to your own domain hosting shaarpy\nCSRF_TRUSTED_ORIGINS=https://*.mydomain.com\n\n# for database\nDB_ENGINE='django.db.backends.sqlite3'\nDB_NAME='db.sqlite3'\nDB_USER=''\nDB_PASSWORD=''\nDB_HOST=''\nDB_PORT=''\n\n# i18n/l10n\nTIME_ZONE='Europe/Paris'\nLANGUAGE_CODE='en-en'\nUSE_I18N=True\nUSE_TZ=True\n```\n\n## :dvd: Database\n\nsetup the database\n\n```bash\ncd shaarpy\npython manage.py migrate\npython manage.py createsuperuser\npython manage.py loaddata shaarpy/fixtures/my_shaarpy_data.json\n```\n\n## :mega: Running the Server\n\n### start the project\n\n```bash\npython manage.py runserver localhost:8001\n```\n\nthen, access the project with your browser http://127.0.0.1:8001/\n\n### Test\n\n```bash\npython manage.py test\n```\n\nor\n\n```bash\npytest\n```\nor\n\n```bash\ncoverage run --source='.' -m pytest\ncoverage report -m\n```\n\n\n## DOCKER\n\nbuild the image and run the container\n\n```bash\nsudo docker compose up --build -d\n```\n\nthen, the first installation, do:\n\n```bash\nsudo docker compose exec web python manage.py migrate --noinput\nsudo docker compose exec web python manage.py createsuperuser\n```\n\n\n## Logo\n\n(logo, thanks to [https://pixabay.com/fr/users/clker-free-vector-images-3736/](https://pixabay.com/fr/vectors/serpent-python-vert-reptile-faune-312561/) )\n",
    "bugtrack_url": null,
    "license": "DO WHAT THE FUCK YOU WANT TO PUBLIC LICENSE Version 2, December 2004  Copyright (C) 2022 FoxMaSk <foxmask+wtfpl@pm.me>  Everyone is permitted to copy and distribute verbatim or modified copies of this license document, and changing it is allowed as long as the name is changed.  DO WHAT THE FUCK YOU WANT TO PUBLIC LICENSE TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION  0. You just DO WHAT THE FUCK YOU WANT TO. ",
    "summary": "ShaarPy: Share your thoughts, links, ideas, notes. self-hosting bookmarks and micro blogging. If you ever wanted Shaarli in python, that's it ^_*",
    "version": "1.2.0",
    "project_urls": {
        "Documentation": "https://github.com/foxmask/shaarpy/blob/main/README.md",
        "Homepage": "https://github.com/foxmask/shaarpy/",
        "Source": "https://github.com/foxmask/shaarpy/"
    },
    "split_keywords": [
        "python",
        "django",
        "shaarli"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "1c7699e0c9faf822470f76fbf572e732073b6babf4672e800394f10e4a6d7661",
                "md5": "0dce30bc92722ae0e8ef6f600d65e513",
                "sha256": "ad331b4e018802709a81dc4f60b1f9f65f640bba002923f07f896385f0bd5152"
            },
            "downloads": -1,
            "filename": "shaarpy-1.2.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "0dce30bc92722ae0e8ef6f600d65e513",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.11",
            "size": 192904,
            "upload_time": "2025-01-05T15:37:02",
            "upload_time_iso_8601": "2025-01-05T15:37:02.038513Z",
            "url": "https://files.pythonhosted.org/packages/1c/76/99e0c9faf822470f76fbf572e732073b6babf4672e800394f10e4a6d7661/shaarpy-1.2.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "814f50baa9f2f3c3a572eef35f98cd57ae7be0394bae8fac2286aa529ceef1e7",
                "md5": "fa55727ae92dc537cb0d5523953e9006",
                "sha256": "f1c5f65ab2879e01ffac41f89b55eeb1262962dfce2055323e12303937b5f6eb"
            },
            "downloads": -1,
            "filename": "shaarpy-1.2.0.tar.gz",
            "has_sig": false,
            "md5_digest": "fa55727ae92dc537cb0d5523953e9006",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.11",
            "size": 296397,
            "upload_time": "2025-01-05T15:37:05",
            "upload_time_iso_8601": "2025-01-05T15:37:05.484184Z",
            "url": "https://files.pythonhosted.org/packages/81/4f/50baa9f2f3c3a572eef35f98cd57ae7be0394bae8fac2286aa529ceef1e7/shaarpy-1.2.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2025-01-05 15:37:05",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "foxmask",
    "github_project": "shaarpy",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "requirements": [
        {
            "name": "Django",
            "specs": [
                [
                    "~=",
                    "5.1"
                ]
            ]
        },
        {
            "name": "django-environ",
            "specs": [
                [
                    "==",
                    "0.11.2"
                ]
            ]
        },
        {
            "name": "django-simple-search",
            "specs": [
                [
                    "==",
                    "1.0.2"
                ]
            ]
        },
        {
            "name": "Markdown",
            "specs": [
                [
                    "==",
                    "3.7"
                ]
            ]
        },
        {
            "name": "rich",
            "specs": [
                [
                    "==",
                    "13.9.4"
                ]
            ]
        },
        {
            "name": "pytz",
            "specs": [
                [
                    "==",
                    "2024.2"
                ]
            ]
        },
        {
            "name": "python-slugify",
            "specs": [
                [
                    "==",
                    "8.0.4"
                ]
            ]
        },
        {
            "name": "Jinja2",
            "specs": [
                [
                    "==",
                    "3.1.4"
                ]
            ]
        }
    ],
    "tox": true,
    "lcname": "shaarpy"
}
        
Elapsed time: 5.86136s