mirror of
https://github.com/GSA/notifications-admin.git
synced 2026-02-05 02:42:26 -05:00
Fix missing CSRF token on send SMS page
As part of https://github.com/alphagov/notifications-admin/pull/187 the file upload pattern was changed to auto-submit once a file had been picked. The form that was submitted was, however, missing a CSRF token, as well as a submit button for non-JS users. This commit makes the file upload pattern self-contained, so that it will always include a form with a CSRF token in a hidden input and a submit button, which is then hidden when Javascript loads.
This commit is contained in:
@@ -3,20 +3,16 @@
|
||||
|
||||
Modules.FileUpload = function() {
|
||||
|
||||
let $field;
|
||||
let $form;
|
||||
|
||||
this.submit = function() {
|
||||
|
||||
$field.parents('form').trigger('submit');
|
||||
|
||||
};
|
||||
this.submit = () => $form.trigger('submit');
|
||||
|
||||
this.start = function(component) {
|
||||
|
||||
$field = $('.file-upload-field', component);
|
||||
$form = $(component);
|
||||
|
||||
// Need to put the event on the container, not the input for it to work properly
|
||||
$(component).on('change', '.file-upload-field', this.submit);
|
||||
$form.on('change', '.file-upload-field', this.submit);
|
||||
|
||||
};
|
||||
|
||||
|
||||
@@ -3,9 +3,15 @@
|
||||
.file-upload {
|
||||
|
||||
&-label {
|
||||
|
||||
@include bold-19;
|
||||
display: block;
|
||||
margin: 0 0 10px 0;
|
||||
|
||||
.error-message {
|
||||
padding: 0;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
&-field {
|
||||
@@ -33,6 +39,10 @@
|
||||
padding-left: $gutter-half;
|
||||
}
|
||||
|
||||
&-submit {
|
||||
display: none;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
{% macro file_upload(field, button_text="Choose file") %}
|
||||
<div class="form-group{% if field.errors %} error{% endif %}" data-module="file-upload">
|
||||
<form method="post" enctype="multipart/form-data" class="form-group{% if field.errors %} error{% endif %}" data-module="file-upload">
|
||||
<label class="file-upload-label" for="{{ field.name }}">
|
||||
<span class="visually-hidden">{{ field.label }}</span>
|
||||
{% if hint %}
|
||||
@@ -20,5 +20,7 @@
|
||||
{{ button_text }}
|
||||
</label>
|
||||
<label class="file-upload-filename" for="{{ field.name }}"></label>
|
||||
</div>
|
||||
<input type="hidden" name="csrf_token" value="{{ csrf_token() }}" />
|
||||
<input type="submit" class="file-upload-submit" value="Submit" />
|
||||
</form>
|
||||
{% endmacro %}
|
||||
|
||||
@@ -45,12 +45,7 @@
|
||||
<a href="{{url_for('.send_sms', service_id=service_id, template_id=template.id)}}" class="page-footer-back-link">Back</a>
|
||||
</form>
|
||||
{% else %}
|
||||
<form method="post" action="{{ url_for('.send_sms', service_id=service_id, template_id=template.id) }}" enctype="multipart/form-data">
|
||||
{{file_upload(form.file, button_text='Choose a CSV file')}}
|
||||
{{ page_footer(
|
||||
"Upload"
|
||||
) }}
|
||||
</form>
|
||||
{{file_upload(form.file, button_text='Upload a CSV file')}}
|
||||
{% endif %}
|
||||
|
||||
{% call(item) list_table(
|
||||
|
||||
@@ -12,19 +12,16 @@
|
||||
|
||||
<h1 class="heading-large">Add recipients</h1>
|
||||
|
||||
<form method="POST" enctype="multipart/form-data">
|
||||
|
||||
<div class="grid-row">
|
||||
<div class="column-two-thirds">
|
||||
{{ sms_message(template.formatted_as_markup) }}
|
||||
</div>
|
||||
<div class="grid-row">
|
||||
<div class="column-two-thirds">
|
||||
{{ sms_message(template.formatted_as_markup) }}
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<p>
|
||||
<a href="{{ url_for('.get_example_csv', service_id=service_id, template_id=template.id) }}">Download an example CSV file</a>
|
||||
</p>
|
||||
<p>
|
||||
<a href="{{ url_for('.get_example_csv', service_id=service_id, template_id=template.id) }}">Download an example CSV file</a>
|
||||
</p>
|
||||
|
||||
{{file_upload(form.file, button_text='Upload a CSV file')}}
|
||||
{{file_upload(form.file, button_text='Upload a CSV file')}}
|
||||
|
||||
</form>
|
||||
{% endblock %}
|
||||
|
||||
@@ -66,7 +66,7 @@ def test_upload_csvfile_with_invalid_phone_shows_check_page_with_errors(app_,
|
||||
assert 'Your CSV file contained missing or invalid data' in content
|
||||
assert '+44 123' in content
|
||||
assert '+44 456' in content
|
||||
assert 'Choose a CSV file' in content
|
||||
assert 'Upload a CSV file' in content
|
||||
|
||||
|
||||
@moto.mock_s3
|
||||
|
||||
Reference in New Issue
Block a user