Hyppää sisältöön

Palvelimen konfigurointi

Oletusarvoista Docker-kuvaa käyttäen kaikki tarvittava konfigurointi voidaan tehdä selaimesta. Kuitenkin, riippuen käyttöönotosta, voi olla tarpeen mukauttaa palvelimen konfigurointia.

Tällä sivulla luetellaan kaikki menetelmät konfiguroinnin muuttamiseksi ja kaikki olemassa olevat konfigurointivaihtoehdot.

Konfigurointitiedosto vs. ympäristömuuttujat

Asetusten osalta voit käyttää joko konfigurointitiedostoa tai ympäristömuuttujia.

Kun käytät Docker Compose -pohjaista asetusta, voit sisällyttää konfigurointitiedoston lisäämällä seuraavan luettelokohdan volumes:-avaimen alle grampsweb:-lohkoon:

      - /path/to/config.cfg:/app/config/config.cfg
missä /path/to/config.cfg on polku konfigurointitiedostoon palvelimesi tiedostojärjestelmässä (oikealla puolella viitataan polkuun säiliössä, eikä sitä saa muuttaa).

Ympäristömuuttujia käytettäessä,

  • etuliite jokaisen asetuksen nimen eteen on GRAMPSWEB_ saadaksesi ympäristömuuttujan nimen
  • Käytä kaksoisalaviivoja sisäkkäisille sanakirja-asetuksille, esim. GRAMPSWEB_THUMBNAIL_CACHE_CONFIG__CACHE_DEFAULT_TIMEOUT asettaa arvon THUMBNAIL_CACHE_CONFIG['CACHE_DEFAULT_TIMEOUT'] konfigurointivaihtoehdolle

Huomaa, että ympäristön kautta asetetut konfigurointivaihtoehdot ovat etusijalla konfigurointitiedostossa oleviin verrattuna. Jos molemmat ovat läsnä, ympäristömuuttuja "voittaa".

Olemassa olevat konfigurointiasetukset

Seuraavat konfigurointivaihtoehdot ovat olemassa.

Pakolliset asetukset

Avain Kuvaus
TREE Käytettävän sukupuun tietokannan nimi. Näytä käytettävissä olevat puut komennolla gramps -l. Jos puuta tällä nimellä ei ole, uusi tyhjää puuta luodaan.
SECRET_KEY Salainen avain flaskille. Salaisuutta ei saa jakaa julkisesti. Sen muuttaminen mitätöi kaikki pääsytunnukset.
USER_DB_URI Käyttäjä tietokannan URL-osoite. Mikä tahansa SQLAlchemyn kanssa yhteensopiva URL-osoite on sallittu.

Info

Voit luoda turvallisen salaisen avaimen esim. komennolla

python3 -c "import secrets;print(secrets.token_urlsafe(32))"

Valinnaiset asetukset

Avain Kuvaus
MEDIA_BASE_DIR Polku, jota käytetään media-tiedostojen perusdirektorina, ohittaen Grampsissa asetetun media-perusdirektorin. Kun käytetään S3, sen on oltava muotoa s3://<bucket_name>
SEARCH_INDEX_DB_URI Hakemiston tietokannan URL-osoite. Vain sqlite tai postgresql ovat sallittuja taustajärjestelmiä. Oletusarvo on sqlite:///indexdir/search_index.db, joka luo SQLite-tiedoston indexdir-kansioon suhteessa polkuun, jossa skripti ajetaan
STATIC_PATH Polku, josta staattisia tiedostoja tarjoillaan (esim. staattinen verkkosivuston etupää)
BASE_URL Perus URL-osoite, josta API on saavutettavissa (esim. https://mygramps.mydomain.com/). Tämä on tarpeen esim. oikeiden salasanan palautuslinkkien rakentamiseksi
CORS_ORIGINS Alkuperät, joista CORS-pyynnöt ovat sallittuja. Oletusarvoisesti kaikki on estetty. Käytä "*" sallimaan pyynnöt mistä tahansa verkkotunnuksesta.
EMAIL_HOST SMTP-palvelimen isäntä (esim. salasanan palautus sähköpostien lähettämiseen)
EMAIL_PORT SMTP-palvelimen portti. oletusarvo on 465
EMAIL_HOST_USER SMTP-palvelimen käyttäjänimi
EMAIL_HOST_PASSWORD SMTP-palvelimen salasana
EMAIL_USE_TLS Poistettu käytöstä (käytä sen sijaan EMAIL_USE_SSL tai EMAIL_USE_STARTTLS). Boolean, käytetäänkö TLS:ää sähköpostien lähettämiseen. Oletusarvo on True. Käytettäessä STARTTLS:ää, aseta tämä False ja käytä eri porttia kuin 25.
EMAIL_USE_SSL Boolean, käytetäänkö implisiittistä SSL/TLS:ää SMTP:lle (v3.6.0+). Oletusarvo on True, jos EMAIL_USE_TLS ei ole nimenomaisesti asetettu. Tyypillisesti käytetään portilla 465.
EMAIL_USE_STARTTLS Boolean, käytetäänkö eksplisiittistä STARTTLS:ää SMTP:lle (v3.6.0+). Oletusarvo on False. Tyypillisesti käytetään portilla 587 tai 25.
DEFAULT_FROM_EMAIL "From" osoite automatisoiduille sähköposteille
THUMBNAIL_CACHE_CONFIG Sanakirja, jossa on asetuksia pikkukuvien välimuistille. Katso Flask-Caching mahdollisista asetuksista.
REQUEST_CACHE_CONFIG Sanakirja, jossa on asetuksia pyyntövälimuistille. Katso Flask-Caching mahdollisista asetuksista.
PERSISTENT_CACHE_CONFIG Sanakirja, jossa on asetuksia pysyvälle välimuistille, jota käytetään esim. telemetriassa. Katso Flask-Caching mahdollisista asetuksista.
CELERY_CONFIG Asetukset Celery-taustatehtäväjonolle. Katso Celery mahdollisista asetuksista.
REPORT_DIR Väliaikainen hakemisto, johon Grampsin raporttien suorittamisen tulokset tallennetaan
EXPORT_DIR Väliaikainen hakemisto, johon Gramps-tietokannan vientitulokset tallennetaan
REGISTRATION_DISABLED Jos True, estä uusien käyttäjien rekisteröinti (oletusarvo False)
DISABLE_TELEMETRY Jos True, poista käytöstä tilastollinen telemetria (oletusarvo False). Katso telemetria lisätietoja varten.

Info

Kun käytetään ympäristömuuttujia konfiguroinnissa, boolean-vaihtoehtojen kuten EMAIL_USE_TLS on oltava joko merkkijono true tai false (kirjainten koko on tärkeä!).

Asetukset vain PostgreSQL-taustatietokannalle

Tämä on tarpeen, jos olet konfiguroinut Gramps-tietokannan toimimaan PostgreSQL-lisäosan kanssa.

Avain Kuvaus
POSTGRES_USER Tietokantayhteyden käyttäjänimi
POSTGRES_PASSWORD Tietokantakäyttäjän salasana

Asetukset useiden puiden isännöimiseen liittyen

Seuraavat asetukset ovat tärkeitä, kun isännöidään useita puita.

Avain Kuvaus
MEDIA_PREFIX_TREE Boolean, käytetäänkö erillistä alikansiota jokaisen puun media-tiedostoille. Oletusarvo on False, mutta suositellaan vahvasti käytettäväksi True usean puun asetuksessa
NEW_DB_BACKEND Tietokanta-taustajärjestelmä, jota käytetään uusille sukupuulle. Sen on oltava yksi seuraavista: sqlite, postgresql tai sharedpostgresql. Oletusarvo on sqlite.
POSTGRES_HOST PostgreSQL-palvelimen isäntänimi, jota käytetään uusien puiden luomiseen, kun käytetään usean puun asetusta SharedPostgreSQL-taustajärjestelmällä
POSTGRES_PORT PostgreSQL-palvelimen portti, jota käytetään uusien puiden luomiseen, kun käytetään usean puun asetusta SharedPostgreSQL-taustajärjestelmällä

Asetukset OIDC-todennusta varten

Nämä asetukset ovat tarpeen, jos haluat käyttää OpenID Connect (OIDC) -todennusta ulkoisten tarjoajien kanssa. Yksityiskohtaisia asennusohjeita ja esimerkkejä varten katso OIDC-todennus.

Avain Kuvaus
OIDC_ENABLED Boolean, otetaanko OIDC-todennus käyttöön. Oletusarvo on False.
OIDC_ISSUER OIDC-palveluntarjoajan myöntäjä-URL (räätälöidyille OIDC-palveluntarjoajille)
OIDC_CLIENT_ID OAuth-asiakastunnus (räätälöidyille OIDC-palveluntarjoajille)
OIDC_CLIENT_SECRET OAuth-asiakassalaisuus (räätälöidyille OIDC-palveluntarjoajille)
OIDC_NAME Räätälöity näyttönimi palveluntarjoajalle. Oletusarvo on "OIDC"
OIDC_SCOPES OAuth-alueet. Oletusarvo on "openid email profile"
OIDC_USERNAME_CLAIM Väite, jota käytetään käyttäjänimenä. Oletusarvo on "preferred_username"
OIDC_OPENID_CONFIG_URL Valinnainen: URL OpenID Connect -konfiguraatiopisteeseen (jos ei käytetä standardia /.well-known/openid-configuration)
OIDC_DISABLE_LOCAL_AUTH Boolean, estetäänkö paikallinen käyttäjänimi/salasana-todennus. Oletusarvo on False
OIDC_AUTO_REDIRECT Boolean, ohjataanko automaattisesti OIDC:hen, kun vain yksi palveluntarjoaja on konfiguroitu. Oletusarvo on False

Sisäänrakennetut OIDC-palveluntarjoajat

Sisäänrakennettuja palveluntarjoajia (Google, Microsoft, GitHub) varten käytä näitä asetuksia:

Avain Kuvaus
OIDC_GOOGLE_CLIENT_ID Asiakastunnus Google OAuth:lle
OIDC_GOOGLE_CLIENT_SECRET Asiakassalaisuus Google OAuth:lle
OIDC_MICROSOFT_CLIENT_ID Asiakastunnus Microsoft OAuth:lle
OIDC_MICROSOFT_CLIENT_SECRET Asiakassalaisuus Microsoft OAuth:lle
OIDC_GITHUB_CLIENT_ID Asiakastunnus GitHub OAuth:lle
OIDC_GITHUB_CLIENT_SECRET Asiakassalaisuus GitHub OAuth:lle

OIDC-roolien kartoitus

Nämä asetukset mahdollistavat OIDC-ryhmien/roolien kartoituksen identiteettipalveluntarjoajastasi Gramps Web -käyttäjärooleihin:

Avain Kuvaus
OIDC_ROLE_CLAIM Väite, joka sisältää käyttäjän ryhmät/roolit OIDC-tunnuksessa. Oletusarvo on "groups"
OIDC_GROUP_ADMIN Ryhmän/roolin nimi OIDC-palveluntarjoajastasi, joka vastaa Grampsin "Admin" -roolia
OIDC_GROUP_OWNER Ryhmän/roolin nimi OIDC-palveluntarjoajastasi, joka vastaa Grampsin "Owner" -roolia
OIDC_GROUP_EDITOR Ryhmän/roolin nimi OIDC-palveluntarjoajastasi, joka vastaa Grampsin "Editor" -roolia
OIDC_GROUP_CONTRIBUTOR Ryhmän/roolin nimi OIDC-palveluntarjoajastasi, joka vastaa Grampsin "Contributor" -roolia
OIDC_GROUP_MEMBER Ryhmän/roolin nimi OIDC-palveluntarjoajastasi, joka vastaa Grampsin "Member" -roolia
OIDC_GROUP_GUEST Ryhmän/roolin nimi OIDC-palveluntarjoajastasi, joka vastaa Grampsin "Guest" -roolia

Asetukset vain AI-ominaisuuksia varten

Nämä asetukset ovat tarpeen, jos haluat käyttää tekoälypohjaisia ominaisuuksia, kuten keskustelua tai semanttista hakua.

Avain Kuvaus
LLM_BASE_URL Perus URL-osoite OpenAI-yhteensopivalle keskustelu-API:lle. Oletusarvo on None, joka käyttää OpenAI API:ta.
LLM_MODEL Malli, jota käytetään OpenAI-yhteensopivassa keskustelu-API:ssa. Jos ei asetettu (oletusarvo), keskustelu on pois käytöstä. Versiosta v3.6.0 alkaen tekoälyassistentti käyttää Pydantic AI:ta työkalukutsumahdollisuuksilla.
VECTOR_EMBEDDING_MODEL Sentence Transformers -malli, jota käytetään semanttisen haun vektoriupotuksiin. Jos ei asetettu (oletusarvo), semanttinen haku ja keskustelu ovat pois käytöstä.
LLM_MAX_CONTEXT_LENGTH Merkkiraja sukupuun kontekstille, joka annetaan LLM:lle. Oletusarvo on 50000.
LLM_SYSTEM_PROMPT Räätälöity järjestelmäkehotus LLM-keskusteluassistentille (v3.6.0+). Jos ei asetettu, käytetään oletusarvoista sukututkimukseen optimoitua kehotusta.

Esimerkkikonfigurointitiedosto

Minimalistinen konfigurointitiedosto tuotantoa varten voisi näyttää tältä: ```python TREE="My Family Tree" BASE_URL="https://mytree.example.com" SECRET_KEY="..." # salainen avain USER_DB_URI="sqlite:////path/to/users.sqlite" EMAIL_HOST="mail.example.com" EMAIL_PORT=465 EMAIL_USE_SSL=True # Käytä implisiittistä SSL:ää portilla 465 EMAIL_HOST_USER="gramps@example.com" EMAIL_HOST_PASSWORD="..." # SMTP-salasana DEFAULT_FROM_EMAIL="gramps@example.com"