telegram_bots/config/utils.py

82 lines
2.8 KiB
Python
Raw Normal View History

2019-01-11 19:16:01 +00:00
from urllib.parse import urlparse
2019-11-12 17:13:56 +00:00
from django.forms import ModelForm
2019-01-11 19:16:01 +00:00
from django.http import HttpRequest, HttpResponse, HttpResponseForbidden
2021-03-11 20:43:54 +00:00
from pyrogram.types import Chat as PyrogramChat
from pyrogram.raw.types.chat import Chat as MTProtoChat
from pyrogram.raw.types.user import User as MTProtoUser
from pyrogram.raw.types.channel import Channel as MTProtoChannel
2019-01-27 21:20:09 +00:00
def parse_mtproto_chat(client, chat):
if isinstance(chat, MTProtoChat):
return PyrogramChat._parse_chat_chat(client, chat)
elif isinstance(chat, MTProtoUser):
return PyrogramChat._parse_user_chat(client, chat)
return PyrogramChat._parse_channel_chat(client, chat)
2019-01-11 19:16:01 +00:00
def same_origin(current_uri, redirect_uri):
a = urlparse(current_uri)
if not a.scheme:
return True
b = urlparse(redirect_uri)
return (a.scheme, a.hostname, a.port) == (b.scheme, b.hostname, b.port)
def turbolinks(request: HttpRequest):
ctx = {}
if request.META.get('HTTP_TURBOLINKS_REFERRER') is not None:
ctx['is_turbolinks'] = True
return ctx
class TurbolinksMiddleware:
def process_request(self, request: HttpRequest):
referrer = request.META.get('HTTP_TURBOLINKS_REFERRER')
if referrer:
request.META['HTTP_REFERER'] = referrer
return
def process_response(self, request: HttpRequest, response: HttpResponse):
referrer = request.META.get('HTTP_TURBOLINKS_REFERRER')
if referrer is None:
return response
if response.has_header('Location'):
loc = response['Location']
request.session['_turbolinks_redirect_to'] = loc
if referrer and not same_origin(loc, referrer):
return HttpResponseForbidden()
else:
if request.session.get('_turbolinks_redirect_to'):
loc = request.session.pop('_turbolinks_redirect_to')
response['Turbolinks-Location'] = loc
return response
2019-11-12 17:13:56 +00:00
def get_config_form(mdl):
2020-02-10 15:57:55 +00:00
class ConfigForm(mdl.CONFIG_FORM_CLASS if hasattr(mdl, 'CONFIG_FORM_CLASS') else ModelForm):
2019-11-12 17:13:56 +00:00
prefix = 'config'
class Meta:
model = mdl
2019-11-27 21:09:49 +00:00
exclude = mdl.EXCLUDE_FIELDS if hasattr(mdl, 'EXCLUDE_FIELDS') else ()
2019-11-27 18:21:24 +00:00
widgets = mdl.CUSTOM_WIDGETS if hasattr(mdl, 'CUSTOM_WIDGETS') else {}
2019-11-12 17:13:56 +00:00
return ConfigForm
class AllowCORSMixin(object):
def add_access_control_headers(self, response):
response["Access-Control-Allow-Origin"] = "*"
response["Access-Control-Allow-Methods"] = "GET, OPTIONS"
response["Access-Control-Max-Age"] = "1000"
response["Access-Control-Allow-Headers"] = "X-Requested-With, Content-Type"
def options(self, request, *args, **kwargs):
response = HttpResponse()
self.add_access_control_headers(response)
return response