mirror of
https://github.com/nottinghamtec/PyRIGS.git
synced 2026-01-17 13:32:15 +00:00
Compare commits
5 Commits
bs4
...
assets_emb
| Author | SHA1 | Date | |
|---|---|---|---|
| aaaa9fc742 | |||
| 6aba0478f0 | |||
| dfb612367b | |||
| 4fb0a0ffe7 | |||
| 7361605ffa |
@@ -6,6 +6,34 @@ from django.urls import reverse
|
|||||||
from RIGS import models
|
from RIGS import models
|
||||||
|
|
||||||
|
|
||||||
|
def get_oembed(login_url, request, oembed_view, kwargs):
|
||||||
|
context = {}
|
||||||
|
context['oembed_url'] = "{0}://{1}{2}".format(request.scheme, request.META['HTTP_HOST'], reverse(oembed_view, kwargs=kwargs))
|
||||||
|
context['login_url'] = "{0}?{1}={2}".format(login_url, REDIRECT_FIELD_NAME, request.get_full_path())
|
||||||
|
resp = render(request, 'login_redirect.html', context=context)
|
||||||
|
return resp
|
||||||
|
|
||||||
|
|
||||||
|
def has_oembed(oembed_view, login_url=None):
|
||||||
|
if not login_url:
|
||||||
|
from django.conf import settings
|
||||||
|
login_url = settings.LOGIN_URL
|
||||||
|
|
||||||
|
def _dec(view_func):
|
||||||
|
def _checklogin(request, *args, **kwargs):
|
||||||
|
if request.user.is_authenticated:
|
||||||
|
return view_func(request, *args, **kwargs)
|
||||||
|
else:
|
||||||
|
if oembed_view is not None:
|
||||||
|
return get_oembed(login_url, request, oembed_view, kwargs)
|
||||||
|
else:
|
||||||
|
return HttpResponseRedirect('%s?%s=%s' % (login_url, REDIRECT_FIELD_NAME, request.get_full_path()))
|
||||||
|
_checklogin.__doc__ = view_func.__doc__
|
||||||
|
_checklogin.__dict__ = view_func.__dict__
|
||||||
|
return _checklogin
|
||||||
|
return _dec
|
||||||
|
|
||||||
|
|
||||||
def user_passes_test_with_403(test_func, login_url=None, oembed_view=None):
|
def user_passes_test_with_403(test_func, login_url=None, oembed_view=None):
|
||||||
"""
|
"""
|
||||||
Decorator for views that checks that the user passes the given test.
|
Decorator for views that checks that the user passes the given test.
|
||||||
@@ -25,11 +53,7 @@ def user_passes_test_with_403(test_func, login_url=None, oembed_view=None):
|
|||||||
return view_func(request, *args, **kwargs)
|
return view_func(request, *args, **kwargs)
|
||||||
elif not request.user.is_authenticated:
|
elif not request.user.is_authenticated:
|
||||||
if oembed_view is not None:
|
if oembed_view is not None:
|
||||||
context = {}
|
return get_oembed(login_url, request, oembed_view, kwargs)
|
||||||
context['oembed_url'] = "{0}://{1}{2}".format(request.scheme, request.META['HTTP_HOST'], reverse(oembed_view, kwargs=kwargs))
|
|
||||||
context['login_url'] = "{0}?{1}={2}".format(login_url, REDIRECT_FIELD_NAME, request.get_full_path())
|
|
||||||
resp = render(request, 'login_redirect.html', context=context)
|
|
||||||
return resp
|
|
||||||
else:
|
else:
|
||||||
return HttpResponseRedirect('%s?%s=%s' % (login_url, REDIRECT_FIELD_NAME, request.get_full_path()))
|
return HttpResponseRedirect('%s?%s=%s' % (login_url, REDIRECT_FIELD_NAME, request.get_full_path()))
|
||||||
else:
|
else:
|
||||||
|
|||||||
45
assets/templates/asset_embed.html
Normal file
45
assets/templates/asset_embed.html
Normal file
@@ -0,0 +1,45 @@
|
|||||||
|
{% extends 'base_embed.html' %}
|
||||||
|
{% load static from staticfiles %}
|
||||||
|
|
||||||
|
{% block content %}
|
||||||
|
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-sm-12">
|
||||||
|
<a href="/assets">
|
||||||
|
<span class="source"> TEC Asset Database</span>
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="col-sm-12">
|
||||||
|
<h3>
|
||||||
|
<a href="{% url 'asset_detail' object.asset_id %}">Asset: {{ object.asset_id }} | {{ object.description }} </a>
|
||||||
|
<small class="label label-default">
|
||||||
|
<strong>Category:</strong>
|
||||||
|
{{ object.category }}
|
||||||
|
</small>
|
||||||
|
|
||||||
|
<small class="label label-{{ object.status.display_class|default:'default' }}">
|
||||||
|
<strong>Status:</strong>
|
||||||
|
{{ object.status }}
|
||||||
|
</small>
|
||||||
|
</h3>
|
||||||
|
<br>
|
||||||
|
{% if object.serial_number %}
|
||||||
|
<p>
|
||||||
|
<strong>Serial Number: </strong>
|
||||||
|
{{ object.serial_number }}
|
||||||
|
</p>
|
||||||
|
{% endif %}
|
||||||
|
{% if object.comments %}
|
||||||
|
<p>
|
||||||
|
<strong>Comments: </strong>
|
||||||
|
{{ object.comments|linebreaksbr }}
|
||||||
|
</p>
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
{% endblock %}
|
||||||
@@ -3,12 +3,15 @@ from django.urls import path
|
|||||||
from assets import views, models
|
from assets import views, models
|
||||||
from RIGS import versioning
|
from RIGS import versioning
|
||||||
|
|
||||||
from PyRIGS.decorators import permission_required_with_403
|
from django.contrib.auth.decorators import login_required
|
||||||
|
from django.views.decorators.clickjacking import xframe_options_exempt
|
||||||
|
from PyRIGS.decorators import has_oembed, permission_required_with_403
|
||||||
|
|
||||||
urlpatterns = [
|
urlpatterns = [
|
||||||
path('', views.AssetList.as_view(), name='asset_index'),
|
path('', views.AssetList.as_view(), name='asset_index'),
|
||||||
path('asset/list/', views.AssetList.as_view(), name='asset_list'),
|
path('asset/list/', views.AssetList.as_view(), name='asset_list'),
|
||||||
path('asset/id/<str:pk>/', views.AssetDetail.as_view(), name='asset_detail'),
|
# Lazy way to enable the oembed redirect...
|
||||||
|
path('asset/id/<str:pk>/', has_oembed(oembed_view="asset_oembed")(views.AssetDetail.as_view()), name='asset_detail'),
|
||||||
path('asset/create/', permission_required_with_403('assets.add_asset')
|
path('asset/create/', permission_required_with_403('assets.add_asset')
|
||||||
(views.AssetCreate.as_view()), name='asset_create'),
|
(views.AssetCreate.as_view()), name='asset_create'),
|
||||||
path('asset/id/<str:pk>/edit/', permission_required_with_403('assets.change_asset')
|
path('asset/id/<str:pk>/edit/', permission_required_with_403('assets.change_asset')
|
||||||
@@ -21,6 +24,13 @@ urlpatterns = [
|
|||||||
(views.ActivityTable.as_view()), name='asset_activity_table'),
|
(views.ActivityTable.as_view()), name='asset_activity_table'),
|
||||||
|
|
||||||
path('asset/search/', views.AssetSearch.as_view(), name='asset_search_json'),
|
path('asset/search/', views.AssetSearch.as_view(), name='asset_search_json'),
|
||||||
|
path('asset/id/<str:pk>/embed/',
|
||||||
|
xframe_options_exempt(
|
||||||
|
login_required(login_url='/user/login/embed/')(views.AssetEmbed.as_view())),
|
||||||
|
name='asset_embed'),
|
||||||
|
path('asset/id/<str:pk>/oembed_json/',
|
||||||
|
views.AssetOembed.as_view(),
|
||||||
|
name='asset_oembed'),
|
||||||
|
|
||||||
path('supplier/list', views.SupplierList.as_view(), name='supplier_list'),
|
path('supplier/list', views.SupplierList.as_view(), name='supplier_list'),
|
||||||
path('supplier/<int:pk>', views.SupplierDetail.as_view(), name='supplier_detail'),
|
path('supplier/<int:pk>', views.SupplierDetail.as_view(), name='supplier_detail'),
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
from django.contrib.auth.mixins import LoginRequiredMixin
|
from django.contrib.auth.mixins import LoginRequiredMixin
|
||||||
from django.http import JsonResponse
|
from django.http import JsonResponse
|
||||||
|
from django.http import HttpResponse
|
||||||
from django.views import generic
|
from django.views import generic
|
||||||
from django.views.decorators.csrf import csrf_exempt
|
from django.views.decorators.csrf import csrf_exempt
|
||||||
from django.utils.decorators import method_decorator
|
from django.utils.decorators import method_decorator
|
||||||
@@ -9,6 +10,8 @@ from django.shortcuts import get_object_or_404
|
|||||||
from assets import models, forms
|
from assets import models, forms
|
||||||
from RIGS import versioning
|
from RIGS import versioning
|
||||||
|
|
||||||
|
import simplejson
|
||||||
|
|
||||||
|
|
||||||
@method_decorator(csrf_exempt, name='dispatch')
|
@method_decorator(csrf_exempt, name='dispatch')
|
||||||
class AssetList(LoginRequiredMixin, generic.ListView):
|
class AssetList(LoginRequiredMixin, generic.ListView):
|
||||||
@@ -149,6 +152,28 @@ class AssetDuplicate(DuplicateMixin, AssetIDUrlMixin, AssetCreate):
|
|||||||
return context
|
return context
|
||||||
|
|
||||||
|
|
||||||
|
class AssetOembed(generic.View):
|
||||||
|
model = models.Asset
|
||||||
|
|
||||||
|
def get(self, request, pk=None):
|
||||||
|
embed_url = reverse('asset_embed', args=[pk])
|
||||||
|
full_url = "{0}://{1}{2}".format(request.scheme, request.META['HTTP_HOST'], embed_url)
|
||||||
|
|
||||||
|
data = {
|
||||||
|
'html': '<iframe src="{0}" frameborder="0" width="100%" height="250"></iframe>'.format(full_url),
|
||||||
|
'version': '1.0',
|
||||||
|
'type': 'rich',
|
||||||
|
'height': '250'
|
||||||
|
}
|
||||||
|
|
||||||
|
json = simplejson.JSONEncoderForHTML().encode(data)
|
||||||
|
return HttpResponse(json, content_type="application/json")
|
||||||
|
|
||||||
|
|
||||||
|
class AssetEmbed(AssetDetail):
|
||||||
|
template_name = 'asset_embed.html'
|
||||||
|
|
||||||
|
|
||||||
class SupplierList(generic.ListView):
|
class SupplierList(generic.ListView):
|
||||||
model = models.Supplier
|
model = models.Supplier
|
||||||
template_name = 'supplier_list.html'
|
template_name = 'supplier_list.html'
|
||||||
|
|||||||
Reference in New Issue
Block a user