コンテンツにスキップ

サーバー構成

デフォルトのDockerイメージを使用すると、すべての必要な構成をブラウザから行うことができます。ただし、デプロイメントによっては、サーバー構成をカスタマイズする必要がある場合があります。

このページでは、構成を変更するためのすべての方法と、すべての既存の構成オプションをリストします。

構成ファイルと環境変数

設定には、構成ファイルまたは環境変数のいずれかを使用できます。

Docker Composeベースのセットアップを使用する場合、grampsweb:ブロックのvolumes:キーの下に次のリスト項目を追加することで構成ファイルを含めることができます。

      - /path/to/config.cfg:/app/config/config.cfg
ここで、/path/to/config.cfgはサーバーのファイルシステム内の構成ファイルへのパスです(右側はコンテナ内のパスを指し、変更してはいけません)。

環境変数を使用する場合、

  • 各設定名の前にGRAMPSWEB_を付けて環境変数の名前を取得します
  • ネストされた辞書設定には二重アンダースコアを使用します。例えば、GRAMPSWEB_THUMBNAIL_CACHE_CONFIG__CACHE_DEFAULT_TIMEOUTは、THUMBNAIL_CACHE_CONFIG['CACHE_DEFAULT_TIMEOUT']構成オプションの値を設定します

環境を介して設定された構成オプションは、構成ファイル内のものよりも優先されることに注意してください。両方が存在する場合、環境変数が「勝ちます」。

既存の構成設定

以下の構成オプションが存在します。

必須設定

キー 説明
TREE 使用するファミリーツリーのデータベース名。利用可能なツリーはgramps -lで表示します。この名前のツリーが存在しない場合、新しい空のツリーが作成されます。
SECRET_KEY Flask用の秘密鍵。秘密は公開されてはいけません。これを変更すると、すべてのアクセストークンが無効になります。
USER_DB_URI ユーザーデータベースのデータベースURL。SQLAlchemyに互換性のある任意のURLが許可されます。

Info

安全な秘密鍵を生成するには、次のコマンドを使用できます

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

オプション設定

キー 説明
MEDIA_BASE_DIR メディアファイルのベースディレクトリとして使用するパス。Grampsで設定されたメディアベースディレクトリを上書きします。S3を使用する場合、s3://<bucket_name>の形式である必要があります。
SEARCH_INDEX_DB_URI 検索インデックス用のデータベースURL。バックエンドとしてはsqliteまたはpostgresqlのみが許可されます。デフォルトはsqlite:///indexdir/search_index.dbで、スクリプトが実行されるパスに対してindexdirフォルダ内にSQLiteファイルを作成します。
STATIC_PATH 静的ファイルを提供するためのパス(例:静的ウェブフロントエンド)
BASE_URL APIにアクセスできるベースURL(例:https://mygramps.mydomain.com/)。これは、正しいパスワードリセットリンクを構築するために必要です。
CORS_ORIGINS CORSリクエストが許可されるオリジン。デフォルトでは、すべてが拒否されます。任意のドメインからのリクエストを許可するには、"*"を使用します。
EMAIL_HOST SMTPサーバーホスト(例:パスワードリセットメールを送信するため)
EMAIL_PORT SMTPサーバーポート。デフォルトは465です。
EMAIL_HOST_USER SMTPサーバーユーザー名
EMAIL_HOST_PASSWORD SMTPサーバーパスワード
EMAIL_USE_TLS 非推奨(代わりにEMAIL_USE_SSLまたはEMAIL_USE_STARTTLSを使用してください)。ブール値、メール送信にTLSを使用するかどうか。デフォルトはTrueです。STARTTLSを使用する場合は、これをFalseに設定し、ポート25とは異なるポートを使用します。
EMAIL_USE_SSL ブール値、SMTPに対して暗黙のSSL/TLSを使用するかどうか(v3.6.0+)。EMAIL_USE_TLSが明示的に設定されていない場合、デフォルトはTrueです。通常、ポート465で使用されます。
EMAIL_USE_STARTTLS ブール値、SMTPに対して明示的なSTARTTLSを使用するかどうか(v3.6.0+)。デフォルトはFalseです。通常、ポート587または25で使用されます。
DEFAULT_FROM_EMAIL 自動メールの「From」アドレス
THUMBNAIL_CACHE_CONFIG サムネイルキャッシュの設定を持つ辞書。可能な設定についてはFlask-Cachingを参照してください。
REQUEST_CACHE_CONFIG リクエストキャッシュの設定を持つ辞書。可能な設定についてはFlask-Cachingを参照してください。
PERSISTENT_CACHE_CONFIG 永続キャッシュの設定を持つ辞書。テレメトリなどに使用されます。可能な設定についてはFlask-Cachingを参照してください。
CELERY_CONFIG Celeryバックグラウンドタスクキューの設定。可能な設定についてはCeleryを参照してください。
REPORT_DIR Grampsレポートの出力が保存される一時ディレクトリ
EXPORT_DIR Grampsデータベースのエクスポート出力が保存される一時ディレクトリ
REGISTRATION_DISABLED Trueの場合、新しいユーザー登録を禁止します(デフォルトはFalse)。
DISABLE_TELEMETRY Trueの場合、統計テレメトリを無効にします(デフォルトはFalse)。詳細についてはtelemetryを参照してください。

Info

構成のために環境変数を使用する場合、EMAIL_USE_TLSのようなブールオプションは、trueまたはfalseのいずれかの文字列でなければなりません(大文字と小文字が区別されます!)。

PostgreSQLバックエンドデータベース専用の設定

これは、GrampsデータベースをPostgreSQLアドオンで動作するように構成した場合に必要です。

キー 説明
POSTGRES_USER データベース接続のためのユーザー名
POSTGRES_PASSWORD データベースユーザーのパスワード

複数のツリーをホスティングするための設定

以下の設定は、複数のツリーをホスティングする場合に関連します。

キー 説明
MEDIA_PREFIX_TREE 各ツリーのメディアファイル用に別のサブフォルダーを使用するかどうかのブール値。デフォルトはFalseですが、マルチツリーセットアップではTrueを使用することを強く推奨します。
NEW_DB_BACKEND 新しく作成されたファミリーツリーに使用するデータベースバックエンド。sqlitepostgresql、またはsharedpostgresqlのいずれかでなければなりません。デフォルトはsqliteです。
POSTGRES_HOST SharedPostgreSQLバックエンドを使用してマルチツリーセットアップで新しいツリーを作成するために使用されるPostgreSQLサーバーのホスト名
POSTGRES_PORT SharedPostgreSQLバックエンドを使用してマルチツリーセットアップで新しいツリーを作成するために使用されるPostgreSQLサーバーのポート

OIDC認証のための設定

これらの設定は、外部プロバイダーとのOpenID Connect (OIDC) 認証を使用する場合に必要です。詳細なセットアップ手順と例については、OIDC認証を参照してください。

キー 説明
OIDC_ENABLED OIDC認証を有効にするかどうかのブール値。デフォルトはFalseです。
OIDC_ISSUER OIDCプロバイダーの発行者URL(カスタムOIDCプロバイダー用)
OIDC_CLIENT_ID OAuthクライアントID(カスタムOIDCプロバイダー用)
OIDC_CLIENT_SECRET OAuthクライアントシークレット(カスタムOIDCプロバイダー用)
OIDC_NAME プロバイダーのカスタム表示名。デフォルトは「OIDC」です。
OIDC_SCOPES OAuthスコープ。デフォルトは「openid email profile」です。
OIDC_USERNAME_CLAIM ユーザー名に使用するクレーム。デフォルトは「preferred_username」です。
OIDC_OPENID_CONFIG_URL オプション:OpenID Connect構成エンドポイントへのURL(標準/.well-known/openid-configurationを使用しない場合)
OIDC_DISABLE_LOCAL_AUTH ローカルのユーザー名/パスワード認証を無効にするかどうかのブール値。デフォルトはFalseです。
OIDC_AUTO_REDIRECT プロバイダーが1つだけ構成されている場合に自動的にOIDCにリダイレクトするかどうかのブール値。デフォルトはFalseです。

組み込みOIDCプロバイダー

組み込みプロバイダー(Google、Microsoft、GitHub)を使用する場合は、次の設定を使用します。

キー 説明
OIDC_GOOGLE_CLIENT_ID Google OAuthのクライアントID
OIDC_GOOGLE_CLIENT_SECRET Google OAuthのクライアントシークレット
OIDC_MICROSOFT_CLIENT_ID Microsoft OAuthのクライアントID
OIDC_MICROSOFT_CLIENT_SECRET Microsoft OAuthのクライアントシークレット
OIDC_GITHUB_CLIENT_ID GitHub OAuthのクライアントID
OIDC_GITHUB_CLIENT_SECRET GitHub OAuthのクライアントシークレット

OIDCロールマッピング

これらの設定を使用すると、アイデンティティプロバイダーからGramps WebユーザーロールへのOIDCグループ/ロールをマッピングできます。

キー 説明
OIDC_ROLE_CLAIM ユーザーのグループ/ロールを含むOIDCトークン内のクレーム名。デフォルトは「groups」です。
OIDC_GROUP_ADMIN Grampsの「Admin」ロールにマッピングされるOIDCプロバイダーからのグループ/ロール名
OIDC_GROUP_OWNER Grampsの「Owner」ロールにマッピングされるOIDCプロバイダーからのグループ/ロール名
OIDC_GROUP_EDITOR Grampsの「Editor」ロールにマッピングされるOIDCプロバイダーからのグループ/ロール名
OIDC_GROUP_CONTRIBUTOR Grampsの「Contributor」ロールにマッピングされるOIDCプロバイダーからのグループ/ロール名
OIDC_GROUP_MEMBER Grampsの「Member」ロールにマッピングされるOIDCプロバイダーからのグループ/ロール名
OIDC_GROUP_GUEST Grampsの「Guest」ロールにマッピングされるOIDCプロバイダーからのグループ/ロール名

AI機能専用の設定

これらの設定は、チャットやセマンティック検索などのAI駆動機能を使用する場合に必要です。

キー 説明
LLM_BASE_URL OpenAI互換のチャットAPIのベースURL。デフォルトはNoneで、OpenAI APIを使用します。
LLM_MODEL OpenAI互換のチャットAPIで使用するモデル。未設定の場合(デフォルト)、チャットは無効になります。v3.6.0以降、AIアシスタントはツール呼び出し機能を持つPydantic AIを使用します。
VECTOR_EMBEDDING_MODEL セマンティック検索ベクトル埋め込みに使用するSentence Transformersモデル。未設定の場合(デフォルト)、セマンティック検索とチャットは無効になります。
LLM_MAX_CONTEXT_LENGTH LLMに提供されるファミリーツリーコンテキストの文字制限。デフォルトは50000です。
LLM_SYSTEM_PROMPT LLMチャットアシスタントのカスタムシステムプロンプト(v3.6.0+)。未設定の場合、デフォルトの系譜最適化プロンプトを使用します。

例の構成ファイル

本番用の最小構成ファイルは次のようになります: ```python TREE="My Family Tree" BASE_URL="https://mytree.example.com" SECRET_KEY="..." # あなたの秘密鍵 USER_DB_URI="sqlite:////path/to/users.sqlite" EMAIL_HOST="mail.example.com" EMAIL_PORT=465 EMAIL_USE_SSL=True # ポート465用に暗黙のSSLを使用 EMAIL_HOST_USER="gramps@example.com" EMAIL_HOST_PASSWORD="..." # あなたのSMTPパスワード DEFAULT_FROM_EMAIL="gramps@example.com"