1
Fork 0
mirror of https://github.com/Steffo99/sophon.git synced 2025-01-09 07:19:46 +00:00

📔 It keeps going and going and going

This commit is contained in:
Steffo 2021-11-04 05:23:23 +01:00
parent d2f0a1c161
commit 1f83a41e3f
5 changed files with 106 additions and 14 deletions
docs/source
1_user/2_concepts/3_researchgroups
2_admin/1_installation
3_dev/2_structure
conf.py

View file

@ -64,6 +64,6 @@ Il creatore di un gruppo è l'unico utente in grado di **cancellare** il gruppo
Gruppi nell'interfaccia web Gruppi nell'interfaccia web
--------------------------- ---------------------------
Dopo aver effettuato l'accesso come :ref:`utente` o :ref:`ospite`, l'interfaccia utente di Sophon visualizza l'elenco di gruppi di ricerca disponibili nell':ref:`instanza`, permettendo agli utenti di unirsi ad essi, lasciarli, oppure eliminarli. Dopo aver effettuato l'accesso come :ref:`utente` o :ref:`ospite`, l'interfaccia utente di Sophon visualizza l'elenco di gruppi di ricerca disponibili nell':ref:`istanza`, permettendo agli utenti di unirsi ad essi, lasciarli, oppure eliminarli.
.. image:: list.png .. image:: list.png

View file

@ -15,7 +15,7 @@ In particolare, tutte le impostazioni precedute da ``# INSTALL`` vanno obbligato
Specifica la chiave segreta da usare per i cookie di sessione. Specifica la chiave segreta da usare per i cookie di sessione.
.. code-block:: yml .. code-block:: yaml
- DJANGO_SECRET_KEY=do-not-use-this-key-in-production-or-you-will-get-hacked - DJANGO_SECRET_KEY=do-not-use-this-key-in-production-or-you-will-get-hacked
@ -41,7 +41,7 @@ Specifica la chiave segreta da usare per i cookie di sessione.
Specifica il dominio che dovrà essere usato come radice per il proxy, ovvero il dominio per il quale si è configurato il DNS in precedenza. Specifica il dominio che dovrà essere usato come radice per il proxy, ovvero il dominio per il quale si è configurato il DNS in precedenza.
.. code-block:: yml .. code-block:: yaml
- DJANGO_PROXY_BASE_DOMAIN=ilmiosophon.it - DJANGO_PROXY_BASE_DOMAIN=ilmiosophon.it
@ -61,7 +61,7 @@ Specifica il protocollo che dovrà essere usato nei mapping del proxy.
Si consiglia vivamente di utilizzare ``https``, ma è un valore valido anche ``http``. Si consiglia vivamente di utilizzare ``https``, ma è un valore valido anche ``http``.
.. code-block:: yml .. code-block:: yaml
- DJANGO_PROXY_PROTOCOL=https - DJANGO_PROXY_PROTOCOL=https
@ -75,7 +75,7 @@ Per specificare più domini, è necessario separarli con dei pipe ``|`` .
Eccetto in configurazioni speciali, deve essere uguale al dominio prefisso da ``api.``. Eccetto in configurazioni speciali, deve essere uguale al dominio prefisso da ``api.``.
.. code-block:: yml .. code-block:: yaml
- DJANGO_ALLOWED_HOSTS=api.ilmiosophon.it - DJANGO_ALLOWED_HOSTS=api.ilmiosophon.it
@ -93,7 +93,7 @@ Per specificare più domini, è necessario separarli con dei pipe ``|`` .
Eccetto in configurazioni speciali, deve contenere il proprio dominio prefisso dal protocollo, e in aggiunta il dominio speciale ``https://sophon.steffo.eu``, necessario per permettere l'accesso dall'interfaccia web "universale" di Sophon. Eccetto in configurazioni speciali, deve contenere il proprio dominio prefisso dal protocollo, e in aggiunta il dominio speciale ``https://sophon.steffo.eu``, necessario per permettere l'accesso dall'interfaccia web "universale" di Sophon.
.. code-block:: yml .. code-block:: yaml
- DJANGO_ALLOWED_ORIGINS=https://ilmiosophon.it|https://sophon.steffo.eu - DJANGO_ALLOWED_ORIGINS=https://ilmiosophon.it|https://sophon.steffo.eu
@ -109,7 +109,7 @@ Specifica l'URL a cui saranno accessibili i file statici di Sophon.
Eccetto in configurazioni speciali, deve essere uguale alla seguente stringa, con le parole in maiuscolo sostituite rispettivamente dal protocollo e dal dominio selezionato: ``PROTOCOLLO://static.DOMINIO/django-static/``. Eccetto in configurazioni speciali, deve essere uguale alla seguente stringa, con le parole in maiuscolo sostituite rispettivamente dal protocollo e dal dominio selezionato: ``PROTOCOLLO://static.DOMINIO/django-static/``.
.. code-block:: yml .. code-block:: yaml
- DJANGO_ALLOWED_ORIGINS=http://static.ilmiosophon.it/django-static/ - DJANGO_ALLOWED_ORIGINS=http://static.ilmiosophon.it/django-static/
@ -129,7 +129,7 @@ Specifica la lingua che deve usare Sophon nei messaggi di errore.
Usa il formato `language code`_ di Django. Usa il formato `language code`_ di Django.
.. code-block:: yml .. code-block:: yaml
- DJANGO_LANGUAGE_CODE=en-us - DJANGO_LANGUAGE_CODE=en-us
@ -147,7 +147,7 @@ Specifica il fuso orario che deve usare Sophon nell'interfaccia di amministrazio
Usa il formato `tzdata`_. Usa il formato `tzdata`_.
.. code-block:: yml .. code-block:: yaml
- DJANGO_TIME_ZONE=Europe/Paris - DJANGO_TIME_ZONE=Europe/Paris
@ -163,7 +163,7 @@ Usa il formato `tzdata`_.
Specifica il nome del :ref:`superutente` che verrà automaticamente creato qualora il database non contenga altri utenti. Specifica il nome del :ref:`superutente` che verrà automaticamente creato qualora il database non contenga altri utenti.
.. code-block:: yml .. code-block:: yaml
- DJANGO_SU_USERNAME=root - DJANGO_SU_USERNAME=root
@ -173,7 +173,7 @@ Specifica il nome del :ref:`superutente` che verrà automaticamente creato qualo
Specifica l'email del :ref:`superutente` che verrà automaticamente creato qualora il database non contenga altri utenti. Specifica l'email del :ref:`superutente` che verrà automaticamente creato qualora il database non contenga altri utenti.
.. code-block:: yml .. code-block:: yaml
- DJANGO_SU_USERNAME=bot@steffo.eu - DJANGO_SU_USERNAME=bot@steffo.eu
@ -187,7 +187,7 @@ Specifica l'email del :ref:`superutente` che verrà automaticamente creato qualo
Specifica la password del :ref:`superutente` che verrà automaticamente creato qualora il database non contenga altri utenti. Specifica la password del :ref:`superutente` che verrà automaticamente creato qualora il database non contenga altri utenti.
.. code-block:: yml .. code-block:: yaml
- DJANGO_SU_PASSWORD=square - DJANGO_SU_PASSWORD=square
@ -203,7 +203,7 @@ Specifica il valore con cui precompilare il campo "selezione istanza" dell'inter
Eccetto in configurazioni speciali, deve essere uguale al dominio prefisso dal protocollo e da ``api.``. Eccetto in configurazioni speciali, deve essere uguale al dominio prefisso dal protocollo e da ``api.``.
.. code-block:: yml .. code-block:: yaml
- REACT_APP_DEFAULT_INSTANCE=https://api.ilmiosophon.it - REACT_APP_DEFAULT_INSTANCE=https://api.ilmiosophon.it
@ -213,7 +213,7 @@ Eccetto in configurazioni speciali, deve essere uguale al dominio prefisso dal p
Specifica il dominio che dovrà essere usato come radice per il proxy, ovvero il ``DOMINIO`` per il quale si è configurato il DNS in precedenza. Specifica il dominio che dovrà essere usato come radice per il proxy, ovvero il ``DOMINIO`` per il quale si è configurato il DNS in precedenza.
.. code-block:: yml .. code-block:: yaml
- APACHE_PROXY_BASE_DOMAIN=dev.sophon.steffo.eu - APACHE_PROXY_BASE_DOMAIN=dev.sophon.steffo.eu

View file

@ -45,10 +45,100 @@ Struttura del modulo
Il modulo consiste nel package Python :mod:`sophon`, che contiene al suo interno un progetto Django, che a sua volta contiene tre app Django. Il modulo consiste nel package Python :mod:`sophon`, che contiene al suo interno un progetto Django, che a sua volta contiene tre app Django.
Il progetto `sophon` Il progetto `sophon`
^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^
.. module:: sophon .. module:: sophon
Il progetto Django Sophon aggiunge varie funzionalità al template base dei progetti Django.
Pagina di amministrazione personalizzata
""""""""""""""""""""""""""""""""""""""""
.. module:: sophon.admin
.. class:: SophonAdminSite(django.contrib.admin.AdminSite)
La pagina di amministrazione viene personalizzata con la classe `SophonAdminSite`, che sovrascrive alcuni parametri della classe di default.
Inoltre, il template predefinito viene sovrascritto da quello all'interno del file ``templates/admin/base.html``, che sostituisce il foglio di stile con uno personalizzato per Sophon.
.. attribute:: site_header = "Sophon Server Administration"
Il nome della pagina nell'header viene modificato a *Sophon Server Administration*.
.. attribute:: site_title = "Sophon Server Administration"
Il titolo della pagina nell'header viene anch'esso modificato a *Sophon Server Administration*.
.. attribute:: site_url = None
Il collegamento *View Site* viene rimosso, in quanto è possibile accedere all'interfaccia web di Sophon da più domini contemporaneamente.
.. attribute:: index_title = "Resources Administration"
Il titolo dell'indice viene modificato a *Resources Administration*.
.. class:: SophonAdminConfig(django.contrib.admin.apps.AdminConfig)
La configurazione di default della pagina di amministrazione viene sovrascritta da questa classe.
.. attribute:: default_site = "sophon.admin.SophonAdminSite"
`.SophonAdminSite` è selezionata come classe predefinita.
Impostazioni dinamiche
""""""""""""""""""""""
.. module:: sophon.settings
Il file di impostazioni viene modificato per **permettere la configurazione attraverso variabili di ambiente** invece che attraverso il file ``settings.py``, rendendo il deployment con Docker molto più semplice.
.. code-block:: python
try:
DATABASE_ENGINE = os.environ["DJANGO_DATABASE_ENGINE"]
except KeyError:
log.warning("DJANGO_DATABASE_ENGINE was not set, defaulting to PostgreSQL")
DATABASE_ENGINE = "django.db.backends.postgresql"
log.debug(f"{DATABASE_ENGINE = }")
Inoltre, viene configurato il modulo `logging` per emettere testo colorato di più facile comprensione usando il package `coloredlogs`.
.. code-block:: python
"detail": {
"()": coloredlogs.ColoredFormatter,
"format": "{asctime:>19} | {name:<24} | {levelname:>8} | {message}",
"style": "{",
}
Autenticazione migliorata
"""""""""""""""""""""""""
.. module:: sophon.auth1
.. class:: BearerTokenAuthentication(rest_framework.authentication.TokenAuthentication)
La classe `rest_framework.authentication.TokenAuthentication` viene modificata per ottenere un comportamento conforme agli standard del web.
.. attribute:: keyword = "Bearer"
Si configura `rest_framework` per accettare header di autenticazione nella forma ``Bearer <token>``, invece che ``Token <token>``.
.. module:: sophon.auth2
.. class:: CustomObtainAuthToken(rest_framework.authtoken.views.ObtainAuthToken)
La view `rest_framework.authtoken.views.ObtainAuthToken` viene estesa per aggiungere dati alla risposta di autenticazione riuscita.
.. method:: post(self, request, *args, **kwargs)
In particolare, viene aggiunta una chiave ``user``, che contiene i dettagli sull'utente che ha effettuato il login.
.. todo: whoa ma io mi ero scordato di sta cosa
L'app `sophon.core` L'app `sophon.core`
^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^

View file

@ -4,6 +4,7 @@ Struttura del progetto
Sophon è composto da quattro moduli, *backend*, *frontend*, *proxy* e *jupyter*, che interagiscono tra loro per fornire agli utenti tutti i servizi necessari. Sophon è composto da quattro moduli, *backend*, *frontend*, *proxy* e *jupyter*, che interagiscono tra loro per fornire agli utenti tutti i servizi necessari.
.. toctree:: .. toctree::
:maxdepth: 2
1_backend/index 1_backend/index
2_frontend/index 2_frontend/index

View file

@ -64,6 +64,7 @@ intersphinx_mapping = {
"python": ("https://docs.python.org/3.8", None), "python": ("https://docs.python.org/3.8", None),
"django": ("http://docs.djangoproject.com/en/3.2/", "http://docs.djangoproject.com/en/3.2/_objects/"), "django": ("http://docs.djangoproject.com/en/3.2/", "http://docs.djangoproject.com/en/3.2/_objects/"),
"docker": ("https://docker-py.readthedocs.io/en/stable/", None), "docker": ("https://docker-py.readthedocs.io/en/stable/", None),
"coloredlogs": ("https://coloredlogs.readthedocs.io/en/latest/", None),
} }
# -- Automodule options ------------------------------------------------------ # -- Automodule options ------------------------------------------------------