mirror of
https://github.com/nottinghamtec/PyRIGS.git
synced 2026-03-06 03:58:23 +00:00
Compare commits
4 Commits
heroku-upg
...
embed_impr
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
d881ce3a96 | ||
|
|
e3fd84c1b6 | ||
|
|
7683dc37ff | ||
|
|
85a835ed0d |
12
Dockerfile
12
Dockerfile
@@ -1,12 +0,0 @@
|
|||||||
FROM python:3.6
|
|
||||||
|
|
||||||
WORKDIR /app
|
|
||||||
|
|
||||||
ADD . /app
|
|
||||||
|
|
||||||
RUN pip install -r requirements.txt && \
|
|
||||||
python manage.py collectstatic --noinput
|
|
||||||
|
|
||||||
EXPOSE 8000
|
|
||||||
|
|
||||||
CMD ["python", "manage.py", "runserver", "0.0.0.0:8000"]
|
|
||||||
@@ -11,7 +11,6 @@ https://docs.djangoproject.com/en/1.7/ref/settings/
|
|||||||
# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
|
# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
|
||||||
import os
|
import os
|
||||||
import raven
|
import raven
|
||||||
import secrets
|
|
||||||
|
|
||||||
BASE_DIR = os.path.dirname(os.path.dirname(__file__))
|
BASE_DIR = os.path.dirname(os.path.dirname(__file__))
|
||||||
|
|
||||||
@@ -234,7 +233,3 @@ USE_GRAVATAR = True
|
|||||||
|
|
||||||
TERMS_OF_HIRE_URL = "http://www.nottinghamtec.co.uk/terms.pdf"
|
TERMS_OF_HIRE_URL = "http://www.nottinghamtec.co.uk/terms.pdf"
|
||||||
AUTHORISATION_NOTIFICATION_ADDRESS = 'productions@nottinghamtec.co.uk'
|
AUTHORISATION_NOTIFICATION_ADDRESS = 'productions@nottinghamtec.co.uk'
|
||||||
RISK_ASSESSMENT_URL = os.environ.get('RISK_ASSESSMENT_URL') if os.environ.get(
|
|
||||||
'RISK_ASSESSMENT_URL') else "http://example.com"
|
|
||||||
RISK_ASSESSMENT_SECRET = os.environ.get('RISK_ASSESSMENT_SECRET') if os.environ.get(
|
|
||||||
'RISK_ASSESSMENT_SECRET') else secrets.token_hex(15)
|
|
||||||
|
|||||||
@@ -77,13 +77,6 @@ python manage.py runserver
|
|||||||
```
|
```
|
||||||
Please refer to Django documentation for a full list of options available here.
|
Please refer to Django documentation for a full list of options available here.
|
||||||
|
|
||||||
### Development using docker
|
|
||||||
|
|
||||||
```
|
|
||||||
docker build . -t pyrigs
|
|
||||||
docker run -it --rm -p=8000:8000 -v $(pwd):/app pyrigs
|
|
||||||
```
|
|
||||||
|
|
||||||
### Sample Data ###
|
### Sample Data ###
|
||||||
Sample data is available to aid local development and user acceptance testing. To load this data into your local database, first ensure the database is empty:
|
Sample data is available to aid local development and user acceptance testing. To load this data into your local database, first ensure the database is empty:
|
||||||
```
|
```
|
||||||
|
|||||||
@@ -33,12 +33,7 @@ class ProfileRegistrationFormUniqueEmail(RegistrationFormUniqueEmail):
|
|||||||
return self.cleaned_data['initials']
|
return self.cleaned_data['initials']
|
||||||
|
|
||||||
|
|
||||||
# Embedded Login form - remove the autofocus
|
# Login form
|
||||||
class EmbeddedAuthenticationForm(AuthenticationForm):
|
|
||||||
def __init__(self, *args, **kwargs):
|
|
||||||
super().__init__(*args, **kwargs)
|
|
||||||
self.fields['username'].widget.attrs.pop('autofocus', None)
|
|
||||||
|
|
||||||
class PasswordReset(PasswordResetForm):
|
class PasswordReset(PasswordResetForm):
|
||||||
captcha = ReCaptchaField(label='Captcha')
|
captcha = ReCaptchaField(label='Captcha')
|
||||||
|
|
||||||
|
|||||||
@@ -1,18 +0,0 @@
|
|||||||
# Generated by Django 2.0.5 on 2019-07-28 21:28
|
|
||||||
|
|
||||||
from django.db import migrations, models
|
|
||||||
|
|
||||||
|
|
||||||
class Migration(migrations.Migration):
|
|
||||||
|
|
||||||
dependencies = [
|
|
||||||
('RIGS', '0033_auto_20180325_0016'),
|
|
||||||
]
|
|
||||||
|
|
||||||
operations = [
|
|
||||||
migrations.AddField(
|
|
||||||
model_name='event',
|
|
||||||
name='risk_assessment_edit_url',
|
|
||||||
field=models.CharField(blank=True, max_length=255, null=True),
|
|
||||||
),
|
|
||||||
]
|
|
||||||
@@ -338,9 +338,6 @@ class Event(models.Model, RevisionMixin):
|
|||||||
auth_request_at = models.DateTimeField(null=True, blank=True)
|
auth_request_at = models.DateTimeField(null=True, blank=True)
|
||||||
auth_request_to = models.EmailField(null=True, blank=True)
|
auth_request_to = models.EmailField(null=True, blank=True)
|
||||||
|
|
||||||
# Risk assessment info
|
|
||||||
risk_assessment_edit_url = models.CharField(verbose_name="risk assessment", max_length=255, blank=True, null=True)
|
|
||||||
|
|
||||||
# Calculated values
|
# Calculated values
|
||||||
"""
|
"""
|
||||||
EX Vat
|
EX Vat
|
||||||
|
|||||||
@@ -18,7 +18,6 @@ from django.core.exceptions import SuspiciousOperation
|
|||||||
from django.db.models import Q
|
from django.db.models import Q
|
||||||
from django.contrib import messages
|
from django.contrib import messages
|
||||||
from django.utils.decorators import method_decorator
|
from django.utils.decorators import method_decorator
|
||||||
from django.views.decorators.csrf import csrf_exempt
|
|
||||||
from z3c.rml import rml2pdf
|
from z3c.rml import rml2pdf
|
||||||
from PyPDF2 import PdfFileMerger, PdfFileReader
|
from PyPDF2 import PdfFileMerger, PdfFileReader
|
||||||
import simplejson
|
import simplejson
|
||||||
@@ -67,10 +66,10 @@ class EventOembed(generic.View):
|
|||||||
full_url = "{0}://{1}{2}".format(request.scheme, request.META['HTTP_HOST'], embed_url)
|
full_url = "{0}://{1}{2}".format(request.scheme, request.META['HTTP_HOST'], embed_url)
|
||||||
|
|
||||||
data = {
|
data = {
|
||||||
'html': '<iframe src="{0}" frameborder="0" width="100%" height="250"></iframe>'.format(full_url),
|
'html': '<iframe src="{0}" frameborder="0" width="100%" height="350"></iframe>'.format(full_url),
|
||||||
'version': '1.0',
|
'version': '1.0',
|
||||||
'type': 'rich',
|
'type': 'rich',
|
||||||
'height': '250'
|
'height': '350'
|
||||||
}
|
}
|
||||||
|
|
||||||
json = simplejson.JSONEncoderForHTML().encode(data)
|
json = simplejson.JSONEncoderForHTML().encode(data)
|
||||||
@@ -81,24 +80,6 @@ class EventEmbed(EventDetail):
|
|||||||
template_name = 'RIGS/event_embed.html'
|
template_name = 'RIGS/event_embed.html'
|
||||||
|
|
||||||
|
|
||||||
class EventRA(generic.base.RedirectView):
|
|
||||||
permanent = False
|
|
||||||
def get_redirect_url(self, *args, **kwargs):
|
|
||||||
event = get_object_or_404(models.Event, pk=kwargs['pk'])
|
|
||||||
|
|
||||||
if event.risk_assessment_edit_url:
|
|
||||||
return event.risk_assessment_edit_url
|
|
||||||
|
|
||||||
params = {
|
|
||||||
'entry.708610078': f'N{event.pk:05}',
|
|
||||||
'entry.905899507': event.name,
|
|
||||||
'entry.139491562': event.venue.name if event.venue else '',
|
|
||||||
'entry.1689826056': event.start_date.strftime('%Y-%m-%d') + ((' - ' + event.end_date.strftime('%Y-%m-%d')) if event.end_date else ''),
|
|
||||||
'entry.902421165': event.mic.name if event.mic else ''
|
|
||||||
}
|
|
||||||
return settings.RISK_ASSESSMENT_URL + "?" + urllib.parse.urlencode(params)
|
|
||||||
|
|
||||||
|
|
||||||
class EventCreate(generic.CreateView):
|
class EventCreate(generic.CreateView):
|
||||||
model = models.Event
|
model = models.Event
|
||||||
form_class = forms.EventForm
|
form_class = forms.EventForm
|
||||||
@@ -405,26 +386,3 @@ class EventAuthoriseRequestEmailPreview(generic.DetailView):
|
|||||||
})
|
})
|
||||||
context['to_name'] = self.request.GET.get('to_name', None)
|
context['to_name'] = self.request.GET.get('to_name', None)
|
||||||
return context
|
return context
|
||||||
|
|
||||||
@method_decorator(csrf_exempt, name='dispatch')
|
|
||||||
class LogRiskAssessment(generic.View):
|
|
||||||
http_method_names = ["post"]
|
|
||||||
|
|
||||||
def post(self, request, **kwargs):
|
|
||||||
data = request.POST
|
|
||||||
shared_secret = data.get("secret")
|
|
||||||
edit_url = data.get("editUrl")
|
|
||||||
rig_number = data.get("rigNum")
|
|
||||||
if shared_secret is None or edit_url is None or rig_number is None:
|
|
||||||
return HttpResponse(status=422)
|
|
||||||
|
|
||||||
if shared_secret != settings.RISK_ASSESSMENT_SECRET:
|
|
||||||
return HttpResponse(status=403)
|
|
||||||
|
|
||||||
rig_number = int(re.sub("[^0-9]", "", rig_number))
|
|
||||||
|
|
||||||
event = get_object_or_404(models.Event, pk=rig_number)
|
|
||||||
event.risk_assessment_edit_url = edit_url
|
|
||||||
event.save()
|
|
||||||
|
|
||||||
return HttpResponse(status=200)
|
|
||||||
|
|||||||
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
@@ -149,19 +149,16 @@ ins {
|
|||||||
}
|
}
|
||||||
|
|
||||||
html.embedded{
|
html.embedded{
|
||||||
display: flex;
|
min-height:100%;
|
||||||
flex-direction: column;
|
display: table;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
height: 100%;
|
|
||||||
max-height: 100%;
|
|
||||||
overflow: hidden;
|
|
||||||
justify-content: center;
|
|
||||||
|
|
||||||
body{
|
body{
|
||||||
padding:0;
|
padding:0;
|
||||||
|
display: table-cell;
|
||||||
|
vertical-align: middle;
|
||||||
width:100%;
|
width:100%;
|
||||||
background:none;
|
background:none;
|
||||||
overflow: scroll;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.embed_container{
|
.embed_container{
|
||||||
|
|||||||
@@ -3,17 +3,6 @@
|
|||||||
class="glyphicon glyphicon-edit"></span> <span
|
class="glyphicon glyphicon-edit"></span> <span
|
||||||
class="hidden-xs">Edit</span></a>
|
class="hidden-xs">Edit</span></a>
|
||||||
{% if event.is_rig %}
|
{% if event.is_rig %}
|
||||||
{% if not event.dry_hire %}
|
|
||||||
<a href="{% url 'event_ra' event.pk %}" class="btn btn-default
|
|
||||||
{% if event.risk_assessment_edit_url %}
|
|
||||||
btn-success
|
|
||||||
{% else %}
|
|
||||||
btn-warning
|
|
||||||
{% endif %}
|
|
||||||
"><span
|
|
||||||
class="glyphicon glyphicon-paperclip"></span> <span
|
|
||||||
class="hidden-xs">RA</span></a>
|
|
||||||
{% endif %}
|
|
||||||
<a href="{% url 'event_print' event.pk %}" target="_blank" class="btn btn-default"><span
|
<a href="{% url 'event_print' event.pk %}" target="_blank" class="btn btn-default"><span
|
||||||
class="glyphicon glyphicon-print"></span> <span
|
class="glyphicon glyphicon-print"></span> <span
|
||||||
class="hidden-xs">Print</span></a>
|
class="hidden-xs">Print</span></a>
|
||||||
|
|||||||
@@ -101,9 +101,6 @@ urlpatterns = [
|
|||||||
url(r'^event/(?P<pk>\d+)/print/$',
|
url(r'^event/(?P<pk>\d+)/print/$',
|
||||||
permission_required_with_403('RIGS.view_event')(rigboard.EventPrint.as_view()),
|
permission_required_with_403('RIGS.view_event')(rigboard.EventPrint.as_view()),
|
||||||
name='event_print'),
|
name='event_print'),
|
||||||
url(r'^event/(?P<pk>\d+)/ra/$',
|
|
||||||
permission_required_with_403('RIGS.change_event')(rigboard.EventRA.as_view()),
|
|
||||||
name='event_ra'),
|
|
||||||
url(r'^event/create/$',
|
url(r'^event/create/$',
|
||||||
permission_required_with_403('RIGS.add_event')(rigboard.EventCreate.as_view()),
|
permission_required_with_403('RIGS.add_event')(rigboard.EventCreate.as_view()),
|
||||||
name='event_create'),
|
name='event_create'),
|
||||||
@@ -188,9 +185,6 @@ urlpatterns = [
|
|||||||
url(r'^api/(?P<model>\w+)/(?P<pk>\d+)/$', login_required(views.SecureAPIRequest.as_view()),
|
url(r'^api/(?P<model>\w+)/(?P<pk>\d+)/$', login_required(views.SecureAPIRequest.as_view()),
|
||||||
name="api_secure"),
|
name="api_secure"),
|
||||||
|
|
||||||
# Risk assessment API
|
|
||||||
url(r'^log_risk_assessment/$', rigboard.LogRiskAssessment.as_view(), name='log_risk_assessment'),
|
|
||||||
|
|
||||||
# Legacy URL's
|
# Legacy URL's
|
||||||
url(r'^rig/show/(?P<pk>\d+)/$',
|
url(r'^rig/show/(?P<pk>\d+)/$',
|
||||||
RedirectView.as_view(permanent=True, pattern_name='event_detail')),
|
RedirectView.as_view(permanent=True, pattern_name='event_detail')),
|
||||||
|
|||||||
@@ -27,8 +27,6 @@ class FieldComparison(object):
|
|||||||
def display_value(self, value):
|
def display_value(self, value):
|
||||||
if isinstance(self.field, IntegerField) and len(self.field.choices) > 0:
|
if isinstance(self.field, IntegerField) and len(self.field.choices) > 0:
|
||||||
return [x[1] for x in self.field.choices if x[0] == value][0]
|
return [x[1] for x in self.field.choices if x[0] == value][0]
|
||||||
if self.field.name == "risk_assessment_edit_url":
|
|
||||||
return "completed" if value else ""
|
|
||||||
return value
|
return value
|
||||||
|
|
||||||
@property
|
@property
|
||||||
|
|||||||
@@ -62,7 +62,7 @@ def login_embed(request, **kwargs):
|
|||||||
messages.warning(request, 'Cookies do not seem to be enabled. Try logging in using a new tab.')
|
messages.warning(request, 'Cookies do not seem to be enabled. Try logging in using a new tab.')
|
||||||
request.method = 'GET' # Render the page without trying to login
|
request.method = 'GET' # Render the page without trying to login
|
||||||
|
|
||||||
return login(request, template_name="registration/login_embed.html", authentication_form=forms.EmbeddedAuthenticationForm)
|
return login(request, template_name="registration/login_embed.html")
|
||||||
|
|
||||||
|
|
||||||
"""
|
"""
|
||||||
|
|||||||
3
app.json
3
app.json
@@ -49,6 +49,5 @@
|
|||||||
{
|
{
|
||||||
"url": "heroku/python"
|
"url": "heroku/python"
|
||||||
}
|
}
|
||||||
],
|
]
|
||||||
"stack": "heroku-18"
|
|
||||||
}
|
}
|
||||||
@@ -3,7 +3,7 @@ contextlib2==0.5.5
|
|||||||
diff-match-patch==20121119
|
diff-match-patch==20121119
|
||||||
dj-database-url==0.5.0
|
dj-database-url==0.5.0
|
||||||
dj-static==0.0.6
|
dj-static==0.0.6
|
||||||
Django==2.0.13
|
Django==2.0.5
|
||||||
django-debug-toolbar==1.9.1
|
django-debug-toolbar==1.9.1
|
||||||
django-ical==1.4
|
django-ical==1.4
|
||||||
django-recaptcha==1.4.0
|
django-recaptcha==1.4.0
|
||||||
|
|||||||
@@ -17,11 +17,11 @@
|
|||||||
<form id="loginForm" action="" method="post" role="form" target="_self">{% csrf_token %}
|
<form id="loginForm" action="" method="post" role="form" target="_self">{% csrf_token %}
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label for="id_username">{{ form.username.label }}</label>
|
<label for="id_username">{{ form.username.label }}</label>
|
||||||
{% render_field form.username class+="form-control" placeholder=form.username.label %}
|
{{ form.username }}
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label for="{{ form.password.id_for_label }}">{{ form.password.label }}</label>
|
<label for="{{ form.password.id_for_label }}">{{ form.password.label }}</label>
|
||||||
{% render_field form.password class+="form-control" placeholder=form.password.label %}
|
{{ form.password }}
|
||||||
</div>
|
</div>
|
||||||
<div class="text-right">
|
<div class="text-right">
|
||||||
<input type="submit" value="Login" class="btn btn-primary"/>
|
<input type="submit" value="Login" class="btn btn-primary"/>
|
||||||
|
|||||||
Reference in New Issue
Block a user