LoginSignup
1
2

More than 1 year has passed since last update.

djangoとwagtailのfile・folder構成の差分・違いを明確にする

Last updated at Posted at 2021-11-04

 背景

pythonのフルスタックフレームワーク「Django」とDjangoをベースとしたCMS※1「Wagtail」があります。
元々、Wagtailで開発したprojectがあったのですが、サードパーティ連携の非簡便さや参考資料がdjangoに比べて少ない点を鑑みて、wagtailのprojectをDjangoに書き換えようと思います。

そこで、各ファイルのどこがdjangoとwagtailで違うのか、一度ここでハッキリさせようと思います。

※1 : CMS(コンテンツマネジメントシステム) は、ウェブコンテンツを構成するテキストや画像などのデジタルコンテンツを統合・体系的に管理し、配信など必要な処理を行うシステムの総称。有名なのは、WordPress等。

セットアップ

1.1 ライブラリのインストール

djangoとwagtailのインストールを行います。

pip install django==3.2.9
pip install wagtail==2.14.2

1.2 プロジェクトのstart

django,wagtailそれぞれでプロジェクトをスタートします。
はじめに、djangoから、

django-admin startproject django_proj

続いて、wagtail

wagtail start wagtail_proj

ファイル構成

以下に、djangoとwagtailのファイル構成を示します。重複しているファイルは、(※)で表記します。

django
django_proj/
 ├ django_proj/
 │ ├ __init__.py
 │ ├ asgi.py
 │ ├ settings.py - (※)
 │ ├ urls.py - (※)
 │ └ wsgi.py - (※)
 └ manage.py - (※)
wagtail_proj
django_proj/
 ├ home/
 │  ├ migrations/
 │  │   ├ __init__.py
 │  │   ├ 0001_initial.py
 │  │   └ 0002_create_homepage.py
 │  ├ static/
 │  │   └ css/
 │  │      └ welcome_page.css
 │  ├ templates/
 │  │   └ home/
 │  │      ├ home_page.html
 │  │      └ welcome_page.html
 │  ├ __init__.py
 │  └ models.py
 ├ search/
 │ ├ templates/
 │ │  ├ templates/
 │ │      └ search/
 │ │          └ search.html
 │ ├ __init__.py
 │ └ views.py
 ├ wagtail_proj/
 │ ├ settings/
 │ │  ├ __init__.py
 │ │  ├ base.py - (※)
 │ │  ├ dev.py
 │ │  └ production.py
 │ ├ static/
 │ │  └ css/
 │ │    └ wagtail_proj.css
 │ │  └ js/
 │ │    └ wagtail_proj.js
 │ ├ templates/
 │ │  ├ 404.html
 │ │  ├ 500.html
 │ │  └ base.html
 │ ├ __init__.py
 │ ├ urls.py - (※)
 │ └ wsgi.py - (※)
 └ .dockerifnore
 └ Dockerfile
 └ manage.py - (※)
 └ requirements.txt

ファイルごとの違い

django・wagtailに共通するファイルにおいて、ファイルごとの違いを示していきます。
尚、コメント部分は省略します。

urls.py

django/urls.pywagtail/urls.pyより、django/urls.pyをベースとして示します。

urls.py
from django.contrib import admin
from django.urls import path
# ↓ --only wagtail--
from django.urls import include 
from django.conf import settings
from wagtail.admin import urls as wagtailadmin_urls
from wagtail.core import urls as wagtail_urls
from wagtail.documents import urls as wagtaildocs_urls
from search import views as search_views
# ↑ --only wagtail--

urlpatterns = [
    path('admin/', admin.site.urls),
    # ↓ --only wagtail--
    path('django-admin/', admin.site.urls),
    path('documents/', include(wagtaildocs_urls)),
    path('search/', search_views.search, name='search'),
    # ↑ --only wagtail--
]
# ↓ --only wagtail--
if settings.DEBUG:
    from django.conf.urls.static import static
    from django.contrib.staticfiles.urls import staticfiles_urlpatterns
    urlpatterns += staticfiles_urlpatterns()
    urlpatterns += static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)

urlpatterns = urlpatterns + [
    path("", include(wagtail_urls)),
]
# ↑ --only wagtail--

manage.py

manage.py
import os
import sys

if __name__ == "__main__":
    os.environ.setdefault("DJANGO_SETTINGS_MODULE", "wagtail_proj.settings.dev") # wagtailの場合
    os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'django_proj.settings')# djangoの場合
    # wagtailの場合
    from django.core.management import execute_from_command_line
    # djangoの場合
    try:
        from django.core.management import execute_from_command_line
    except ImportError as exc:
        raise ImportError(
            "Couldn't import Django. Are you sure it's installed and "
            "available on your PYTHONPATH environment variable? Did you "
            "forget to activate a virtual environment?"
        ) from exc
    execute_from_command_line(sys.argv)

# djangoの場合
if __name__ == '__main__':
    main()

settings.py

結構違いがあるので、上から部分部分で示していきます。

manage.py
# about import 
## djangoの場合
from pathlib import Path
## wagtailの場合
import os

# about DIR
## djangoの場合
BASE_DIR = Path(__file__).resolve().parent.parent
## wagtailの場合
PROJECT_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
BASE_DIR = os.path.dirname(PROJECT_DIR)

# 共通部分
SECRET_KEY = '*********************************'
DEBUG = True
ALLOWED_HOSTS = []

# about INSTALLED_APPS
INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    # ↓ --only wagtail--
    'home',
    'search',
    'wagtail.contrib.forms',
    'wagtail.contrib.redirects',
    'wagtail.embeds',
    'wagtail.sites',
    'wagtail.users',
    'wagtail.snippets',
    'wagtail.documents',
    'wagtail.images',
    'wagtail.search',
    'wagtail.admin',
    'wagtail.core'
    'modelcluster',
    'taggit',
    # ↑ --only wagtail--
]

# about MIDDLEWARE
MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
    'wagtail.contrib.redirects.middleware.RedirectMiddleware', ## wagtailの場合
]

# 共通部分
ROOT_URLCONF = '<your project name>.urls'

# about TEMPLATES
TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [], ## djangoの場合
        'DIRS': [os.path.join(PROJECT_DIR, 'templates'),], ## wagtailの場合
        'APP_DIRS': True,
        'OPTIONS': {
            'context_processors': [
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',
            ],
        },
    },
]

# 共通部分
WSGI_APPLICATION = '<your project name>.wsgi.application'

# about DATABASES
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': BASE_DIR / 'db.sqlite3',## djangoの場合
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),## wagtailの場合
    }
}

# 共通部分
AUTH_PASSWORD_VALIDATORS = [
    {
        'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
    },
]

LANGUAGE_CODE = 'en-us'

TIME_ZONE = 'UTC'

USE_I18N = True

USE_L10N = True

USE_TZ = True

# about static files
## djangoの場合
STATIC_URL = '/static/'
DEFAULT_AUTO_FIELD = 'django.db.models.BigAutoField'

## wagtailの場合
STATICFILES_FINDERS = [
    'django.contrib.staticfiles.finders.FileSystemFinder',
    'django.contrib.staticfiles.finders.AppDirectoriesFinder',
]

STATICFILES_DIRS = [
    os.path.join(PROJECT_DIR, 'static'),
]

STATICFILES_STORAGE = 'django.contrib.staticfiles.storage.ManifestStaticFilesStorage'

STATIC_ROOT = os.path.join(BASE_DIR, 'static')
STATIC_URL = '/static/'

MEDIA_ROOT = os.path.join(BASE_DIR, 'media')
MEDIA_URL = '/media/'

WAGTAIL_SITE_NAME = "wagtail_proj"

BASE_URL = 'http://example.com'

wsgi.py

違いはなし

1
2
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
2