diff --git a/.gitignore b/.gitignore index a1195c0..2d1bab8 100644 --- a/.gitignore +++ b/.gitignore @@ -31,7 +31,6 @@ logs/ .Python build/ develop-eggs/ -dist/ downloads/ eggs/ .eggs/ diff --git a/README.md b/README.md index cca37dd..154ca60 100644 --- a/README.md +++ b/README.md @@ -39,17 +39,20 @@ ## Quickstart +Перед запуском требуется неообходимо `.env` файл. +```bash +cp .env.example .env +``` +Заменить переменные в `.env` на актуальные. ```bash sudo apt install make pip install --upgrade pip pip install -r requirements/dev.txt -./manage.py migrate -./manage.py loaddata data.json -./manage.py runserver +(set -a && source .env && ./manage.py migrate) +(set -a && source .env && ./manage.py loaddata data.json) +(set -a && source .env && ./manage.py runserver) ``` -## ZenDesk Access Controller instruction for eng - ## Перед запуском для тестирования: Убедитесь, что вы зарегистрированы в песочнице ZenDesk, у вас назначена организация `SYSTEM` diff --git a/access_controller/urls.py b/access_controller/urls.py index f6a6754..63dc19f 100644 --- a/access_controller/urls.py +++ b/access_controller/urls.py @@ -14,6 +14,7 @@ Including another URLconf 2. Add a URL to urlpatterns: path('blog/', include('blog.urls')) """ from django.contrib import admin +from django.contrib.auth import views from django.urls import path, include from main.views import main_page, profile_page, CustomRegistrationView, CustomLoginView, registration_error @@ -36,8 +37,7 @@ urlpatterns = [ path('accounts/', include('django_registration.backends.activation.urls')), path('control/', AdminPageView.as_view(), name='control'), path('statistic/', statistic_page, name='statistic'), - ] - +] # Django REST urlpatterns += [ diff --git a/main/templates/pages/adm_ruleset.html b/main/templates/pages/adm_ruleset.html index dd077c4..dc3cf54 100644 --- a/main/templates/pages/adm_ruleset.html +++ b/main/templates/pages/adm_ruleset.html @@ -29,7 +29,7 @@ {% for message in messages %} - + {% endfor %} {% block form %} diff --git a/main/templates/pages/profile.html b/main/templates/pages/profile.html index 1dd6005..5cd8420 100644 --- a/main/templates/pages/profile.html +++ b/main/templates/pages/profile.html @@ -31,6 +31,7 @@ alt="Нет изображения" > + Сменить пароль
Имя пользователя {{ profile.name }}
diff --git a/main/templates/pages/work.html b/main/templates/pages/work.html index 57c6cab..cb07b6d 100644 --- a/main/templates/pages/work.html +++ b/main/templates/pages/work.html @@ -72,7 +72,7 @@
{% for message in messages %} - + {% endfor %} diff --git a/main/templates/registration/password_change_done.html b/main/templates/registration/password_change_done.html new file mode 100644 index 0000000..59870fb --- /dev/null +++ b/main/templates/registration/password_change_done.html @@ -0,0 +1,12 @@ +{% extends "base/base.html" %} +{% load static %} + +{% block title %}Пароль успешно изменен{% endblock title %} + +{% block heading %}Пароль успешно изменен{% endblock %} + +{% block content %} +
+

Ваш пароль был изменен.

+
+{% endblock content %} diff --git a/main/templates/registration/password_change_form.html b/main/templates/registration/password_change_form.html new file mode 100644 index 0000000..5348ed9 --- /dev/null +++ b/main/templates/registration/password_change_form.html @@ -0,0 +1,14 @@ +{% extends "base/base.html" %} +{% load static %} + +{% block title %}Изменение пароля{% endblock title %} + +{% block heading %}Сменить пароль{% endblock %} + +{% block content %} +
+ {% csrf_token %} + {{ form.as_p }} + +
+{% endblock content %} diff --git a/main/tests.py b/main/tests.py index 7ce503c..b733ed1 100644 --- a/main/tests.py +++ b/main/tests.py @@ -1,3 +1,2 @@ -from django.test import TestCase - -# Create your tests here. +from django.test import TestCase, Client +import access_controller.settings as sets diff --git a/media/.gitkeep b/media/.gitkeep deleted file mode 100644 index e69de29..0000000 diff --git a/static/main/js/control.js b/static/main/js/control.js index 0215b05..ee62c5c 100644 --- a/static/main/js/control.js +++ b/static/main/js/control.js @@ -1,4 +1,6 @@ "use strict"; +import React from "react"; +import ReactDOM from "react-dom"; function head_checkbox() { let head_checkbox = document.getElementById("head-checkbox"); @@ -45,13 +47,19 @@ class ModelUserTableRows extends React.Component { class ZendeskUserTableRow extends React.Component { render() { return ( - + - {this.props.user.name} + + {this.props.user.name} + + + + {this.props.user.email} + + + {this.props.user.zendesk_role} - {this.props.user.email} - {this.props.user.zendesk_role} ); } diff --git a/static/modules/notifications/dist/notifications.css b/static/modules/notifications/dist/notifications.css new file mode 100644 index 0000000..90d9e61 --- /dev/null +++ b/static/modules/notifications/dist/notifications.css @@ -0,0 +1 @@ +.ncf-container{font-size:14px;box-sizing:border-box;position:fixed;z-index:999999}.ncf-container.nfc-top-left{top:12px;left:12px}.ncf-container.nfc-top-right{top:12px;right:12px}.ncf-container.nfc-bottom-right{bottom:12px;right:12px}.ncf-container.nfc-bottom-left{bottom:12px;left:12px}@media (max-width:767px){.ncf-container{left:0;right:0}}.ncf-container .ncf{background:#fff;transition:.3s ease;position:relative;pointer-events:auto;overflow:hidden;margin:0 0 6px;padding:30px;width:300px;border-radius:3px 3px 3px 3px;box-shadow:0 0 12px #999;color:#000;opacity:.9;-ms-filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=90);filter:alpha(opacity=90);background-position:15px!important;background-repeat:no-repeat!important;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.ncf-container .ncf:hover{box-shadow:0 0 12px #000;opacity:1;cursor:pointer}.ncf-container .ncf .ncf-title{font-weight:700;font-size:16px;text-align:left;margin-top:0;margin-bottom:6px;word-wrap:break-word}.ncf-container .ncf .nfc-message{margin:0;text-align:left;word-wrap:break-word}.ncf-container .success{background:#51a351;color:#fff;padding:15px 15px 15px 50px;background-image:url("")}.ncf-container .info{background:#2f96b4;color:#fff;padding:15px 15px 15px 50px;background-image:url("")}.ncf-container .warning{background:#f87400;color:#fff;padding:15px 15px 15px 50px;background-image:url("")}.ncf-container .error{background:#bd362f;color:#fff;padding:15px 15px 15px 50px;background-image:url("")!important}.ncf-container button{position:relative;right:-.3em;top:-.3em;float:right;font-weight:700;color:#fff;text-shadow:0 1px 0 #fff;opacity:.8;line-height:1;font-size:16px;padding:0;cursor:pointer;background:transparent;border:0}.ncf-container button:hover{opacity:1} \ No newline at end of file diff --git a/static/modules/notifications/dist/notifications.js b/static/modules/notifications/dist/notifications.js new file mode 100644 index 0000000..34b339e --- /dev/null +++ b/static/modules/notifications/dist/notifications.js @@ -0,0 +1 @@ +!function(t){function n(i){if(e[i])return e[i].exports;var o=e[i]={i:i,l:!1,exports:{}};return t[i].call(o.exports,o,o.exports,n),o.l=!0,o.exports}var e={};n.m=t,n.c=e,n.d=function(t,e,i){n.o(t,e)||Object.defineProperty(t,e,{configurable:!1,enumerable:!0,get:i})},n.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return n.d(e,"a",e),e},n.o=function(t,n){return Object.prototype.hasOwnProperty.call(t,n)},n.p="",n(n.s=0)}([function(t,n,e){e(1),t.exports=e(4)},function(t,n,e){"use strict";var i=Object.assign||function(t){for(var n=1;n-1}(t.positionClass)||(console.warn("An invalid notification position class has been specified."),t.positionClass=c.positionClass),t.onclick&&"function"!=typeof t.onclick&&(console.warn("Notification on click must be a function."),t.onclick=c.onclick),"number"!=typeof t.showDuration&&(t.showDuration=c.showDuration),(0,o.isString)(t.theme)&&0!==t.theme.length||(console.warn("Notification theme must be a string with length"),t.theme=c.theme),t}function e(t){return t=n(t),function(){var n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e=n.title,i=n.message,c=r(t.positionClass);if(!e&&!i)return console.warn("Notification must contain a title or a message!");var a=(0,o.createElement)("div","ncf",t.theme);if(!0===t.closeOnClick&&a.addEventListener("click",function(){return c.removeChild(a)}),t.onclick&&a.addEventListener("click",function(n){return t.onclick(n)}),t.displayCloseButton){var s=(0,o.createElement)("button");s.innerText="X",!1===t.closeOnClick&&s.addEventListener("click",function(){return c.removeChild(a)}),(0,o.append)(a,s)}if((0,o.isString)(e)&&e.length&&(0,o.append)(a,(0,o.createParagraph)("ncf-title")(e)),(0,o.isString)(i)&&i.length&&(0,o.append)(a,(0,o.createParagraph)("nfc-message")(i)),(0,o.append)(c,a),t.showDuration&&t.showDuration>0){var l=setTimeout(function(){c.removeChild(a),0===c.querySelectorAll(".ncf").length&&document.body.removeChild(c)},t.showDuration);(t.closeOnClick||t.displayCloseButton)&&a.addEventListener("click",function(){return clearTimeout(l)})}}}function r(t){var n=document.querySelector("."+t);return n||(n=(0,o.createElement)("div","ncf-container",t),(0,o.append)(document.body,n)),n}var c={closeOnClick:!0,displayCloseButton:!1,positionClass:"nfc-top-right",onclick:!1,showDuration:3500,theme:"success"};t.createNotification?console.warn("Window already contains a create notification function. Have you included the script twice?"):t.createNotification=e}(window)},function(t,n,e){"use strict";!function(){function t(t){this.el=t;for(var n=t.className.replace(/^\s+|\s+$/g,"").split(/\s+/),i=0;i1?n-1:0),i=1;i1?n-1:0),i=1;i1?n-1:0),i=1;i1?n-1:0),c=1;c