Я пытаюсь написать собственный загрузчик шаблонов в django, который обслуживает index.html, который присутствует в корзине s3. Ниже мой файл загрузчика
from django.conf import settings
from django.template import Origin, Engine
from django.template.loader import TemplateDoesNotExist
from django.template.loaders.base import Loader
from boto3.session import Session
ACCESS_KEY_NAME = getattr(settings, 'AWS_TEMPLATE_LOADING_ACCESS_KEY_ID', getattr(settings, 'AWS_TEMPLATE_LOADING_ACCESS_KEY_ID', None))
SECRET_KEY_NAME = getattr(settings, 'AWS_TEMPLATE_LOADING_SECRET_ACCESS_KEY', getattr(settings, 'AWS_TEMPLATE_LOADING_SECRET_ACCESS_KEY', None))
TEMPLATE_BUCKET = getattr(settings, 'AWS_TEMPLATE_BUCKET_NAME')
class Loader(Loader):
is_usable = True
def __init__(self, *args, **kwargs):
params = args[0]
options = params.pop('OPTIONS').copy()
options.setdefault('autoescape', True)
options.setdefault('debug', settings.DEBUG)
options.setdefault('file_charset', settings.FILE_CHARSET)
libraries = options.get('libraries', {})
session = Session(aws_access_key_id=ACCESS_KEY_NAME,
aws_secret_access_key=SECRET_KEY_NAME)
s3 = session.resource('s3')
self.bucket = s3.Bucket(TEMPLATE_BUCKET)
super(Loader, self).__init__(*args, **kwargs)
self.engine = Engine(dirs=params['DIRS'], context_processors=options, loaders=Loader)
def getKeys(self):
keys_objects = []
for obj in self.bucket.objects.all():
key = obj.key
keys_objects.append({
'key': key,
'object': obj
})
return keys_objects
def get_contents(self, origin):
try:
keys_objects = self.getKeys()
for key_object in keys_objects:
if key_object['key'] == origin:
return key_object['object'].get()['Body'].read()
except FileNotFoundError:
raise TemplateDoesNotExist(origin)
def get_template_sources(self, template_name, template_dirs=None):
tried = []
yield Origin(
name=template_name,
template_name=template_name,
loader=self,
)
tried.append('/index.html')
if tried:
error_msg = "Tried Keys %s" % tried
else:
error_msg = "Your TEMPLATE_DIRS setting is empty. Change it to point to at least one template directory."
raise TemplateDoesNotExist(error_msg)
get_template_sources.is_usable = True
и в своих настройках я установил настройки шаблона следующим образом.
TEMPLATES = [
{
'BACKEND': 'app.s3template_loader.Loader',
'DIRS': [
'index.html'
],
'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',
],
},
}
]
и мое мнение следующее
from django.shortcuts import render
from django.views.generic import TemplateView
# Create your views here.
class AngularAppView(TemplateView):
template_name = 'index.html'
но когда я пытаюсь получить доступ к своей конечной точке, я получаю
Внутренняя ошибка сервера: / Traceback (последний вызов был последним): файл
"/Usr/local/lib/python3.6/site-packages/django/core/handlers/exception.py",
линия 41, во внутренней
response = get_response (запрос) Файл "/usr/local/lib/python3.6/site-packages/django/core/handlers/base.py",
строка 217, в _get_response
response = self.process_exception_by_middleware (e, запрос) Файл "/usr/local/lib/python3.6/site-packages/django/core/handlers/base.py",
строка 215, в _get_response
файл response = response.render () "/usr/local/lib/python3.6/site-packages/django/template/response.py",
строка 107, в рендере
self.content = self.rendered_content File "/usr/local/lib/python3.6/site-packages/django/template/response.py",
строка 84, в rendered_content
content = template.render (context, self._request) TypeError: render () принимает 2 позиционных аргумента, но 3 получили
Я не могу понять, что я делаю неправильно. любая помощь приветствуется.