incline 0.1.5
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.gitignore +13 -0
- data/Gemfile +17 -0
- data/Gemfile.lock +186 -0
- data/MIT-LICENSE +20 -0
- data/README.rdoc +208 -0
- data/Rakefile +37 -0
- data/app/assets/fonts/incline/.keep +0 -0
- data/app/assets/images/incline/.keep +0 -0
- data/app/assets/images/incline/barcode-B.svg +181 -0
- data/app/assets/javascripts/incline/activate_classed_items.js +11 -0
- data/app/assets/javascripts/incline/application.js +30 -0
- data/app/assets/javascripts/incline/bootstrap-datepicker.js +1800 -0
- data/app/assets/javascripts/incline/datatables.js +22193 -0
- data/app/assets/javascripts/incline/escapeHtml.js +10 -0
- data/app/assets/javascripts/incline/inline_actions.js +479 -0
- data/app/assets/javascripts/incline/jquery.doubleScroll.js +112 -0
- data/app/assets/javascripts/incline/jquery.number.js +764 -0
- data/app/assets/javascripts/incline/regexMask.js +27 -0
- data/app/assets/javascripts/incline/select2/i18n/en.js +3 -0
- data/app/assets/javascripts/incline/select2/select2.full.js +6436 -0
- data/app/assets/stylesheets/incline/application.css +18 -0
- data/app/assets/stylesheets/incline/bootstrap-theme.min.css +5 -0
- data/app/assets/stylesheets/incline/custom.scss +279 -0
- data/app/assets/stylesheets/incline/datatables.css +494 -0
- data/app/assets/stylesheets/incline/datepicker3.css +790 -0
- data/app/assets/stylesheets/incline/select2.css +484 -0
- data/app/controllers/incline/access_groups_controller.rb +127 -0
- data/app/controllers/incline/access_test_controller.rb +30 -0
- data/app/controllers/incline/account_activations_controller.rb +28 -0
- data/app/controllers/incline/application_controller.rb +11 -0
- data/app/controllers/incline/contact_controller.rb +34 -0
- data/app/controllers/incline/password_resets_controller.rb +113 -0
- data/app/controllers/incline/security_controller.rb +100 -0
- data/app/controllers/incline/sessions_controller.rb +50 -0
- data/app/controllers/incline/users_controller.rb +304 -0
- data/app/controllers/incline/welcome_controller.rb +19 -0
- data/app/helpers/incline/.keep +0 -0
- data/app/mailers/incline/application_mailer_base.rb +11 -0
- data/app/mailers/incline/contact_form.rb +19 -0
- data/app/mailers/incline/user_mailer.rb +45 -0
- data/app/models/incline/access_group.rb +121 -0
- data/app/models/incline/access_group_group_member.rb +12 -0
- data/app/models/incline/access_group_user_member.rb +10 -0
- data/app/models/incline/action_group.rb +12 -0
- data/app/models/incline/action_security.rb +222 -0
- data/app/models/incline/contact_message.rb +37 -0
- data/app/models/incline/disable_info.rb +20 -0
- data/app/models/incline/password_reset.rb +14 -0
- data/app/models/incline/password_reset_request.rb +14 -0
- data/app/models/incline/user.rb +437 -0
- data/app/models/incline/user_login_history.rb +30 -0
- data/app/views/incline/access_groups/_details.json.jbuilder +10 -0
- data/app/views/incline/access_groups/_form.html.erb +19 -0
- data/app/views/incline/access_groups/_list.html.erb +60 -0
- data/app/views/incline/access_groups/_messages.json.jbuilder +6 -0
- data/app/views/incline/access_groups/edit.html.erb +2 -0
- data/app/views/incline/access_groups/index.html.erb +6 -0
- data/app/views/incline/access_groups/index.json.jbuilder +16 -0
- data/app/views/incline/access_groups/new.html.erb +2 -0
- data/app/views/incline/access_groups/show.html.erb +9 -0
- data/app/views/incline/access_groups/show.json.jbuilder +11 -0
- data/app/views/incline/contact/new.html.erb +22 -0
- data/app/views/incline/contact_form/contact.html.erb +16 -0
- data/app/views/incline/contact_form/contact.text.erb +13 -0
- data/app/views/incline/password_resets/edit.html.erb +16 -0
- data/app/views/incline/password_resets/new.html.erb +12 -0
- data/app/views/incline/security/_details.json.jbuilder +7 -0
- data/app/views/incline/security/_form.html.erb +20 -0
- data/app/views/incline/security/_list.html.erb +89 -0
- data/app/views/incline/security/_messages.json.jbuilder +6 -0
- data/app/views/incline/security/edit.html.erb +2 -0
- data/app/views/incline/security/index.html.erb +6 -0
- data/app/views/incline/security/index.json.jbuilder +16 -0
- data/app/views/incline/security/show.html.erb +31 -0
- data/app/views/incline/security/show.json.jbuilder +11 -0
- data/app/views/incline/sessions/new.html.erb +26 -0
- data/app/views/incline/user_mailer/account_activation.html.erb +7 -0
- data/app/views/incline/user_mailer/account_activation.text.erb +6 -0
- data/app/views/incline/user_mailer/invalid_password_reset.html.erb +3 -0
- data/app/views/incline/user_mailer/invalid_password_reset.text.erb +5 -0
- data/app/views/incline/user_mailer/password_reset.html.erb +8 -0
- data/app/views/incline/user_mailer/password_reset.text.erb +7 -0
- data/app/views/incline/users/_details.json.jbuilder +32 -0
- data/app/views/incline/users/_form.html.erb +21 -0
- data/app/views/incline/users/_list.html.erb +102 -0
- data/app/views/incline/users/_messages.json.jbuilder +6 -0
- data/app/views/incline/users/disable_confirm.html.erb +19 -0
- data/app/views/incline/users/edit.html.erb +5 -0
- data/app/views/incline/users/index.html.erb +6 -0
- data/app/views/incline/users/index.json.jbuilder +16 -0
- data/app/views/incline/users/new.html.erb +5 -0
- data/app/views/incline/users/show.html.erb +12 -0
- data/app/views/incline/users/show.json.jbuilder +11 -0
- data/app/views/incline/welcome/home.html.erb +5 -0
- data/app/views/layouts/application.html.erb +1 -0
- data/app/views/layouts/incline/_account_menu.html.erb +18 -0
- data/app/views/layouts/incline/_app_menu_anon.html.erb +1 -0
- data/app/views/layouts/incline/_app_menu_authenticated.html.erb +1 -0
- data/app/views/layouts/incline/_footer.html.erb +13 -0
- data/app/views/layouts/incline/_header.html.erb +21 -0
- data/app/views/layouts/incline/_html_mailer.html.erb +5 -0
- data/app/views/layouts/incline/_incline_app.html.erb +25 -0
- data/app/views/layouts/incline/_messages.html.erb +3 -0
- data/app/views/layouts/incline/_shim.html.erb +3 -0
- data/app/views/layouts/incline/_text_mailer.text.erb +1 -0
- data/app/views/layouts/incline/application.html.erb +1 -0
- data/app/views/layouts/mailer.html.erb +2 -0
- data/app/views/layouts/mailer.text.erb +2 -0
- data/bin/rails +12 -0
- data/bin/test_scaffold.sh +10 -0
- data/config/routes.rb +61 -0
- data/db/migrate/20170511230126_create_incline_users.rb +26 -0
- data/db/migrate/20170515003052_create_incline_access_groups.rb +10 -0
- data/db/migrate/20170515003221_create_incline_user_login_histories.rb +12 -0
- data/db/migrate/20170515150908_create_incline_access_group_user_members.rb +11 -0
- data/db/migrate/20170515151058_create_incline_access_group_group_members.rb +11 -0
- data/db/migrate/20170517193432_add_comments_to_incline_user.rb +5 -0
- data/db/migrate/20170622132700_create_incline_action_securities.rb +16 -0
- data/db/migrate/20170622172712_create_incline_action_groups.rb +11 -0
- data/db/migrate/20170622195742_add_non_standard_to_action_security.rb +5 -0
- data/db/migrate/20170622230422_add_visible_to_action_security.rb +5 -0
- data/db/seeds.rb +81 -0
- data/exe/new_incline_app +42 -0
- data/lib/generators/incline/install_generator.rb +259 -0
- data/lib/generators/incline/templates/_app_menu_anon.html.erb +1 -0
- data/lib/generators/incline/templates/_app_menu_authenticated.html.erb +1 -0
- data/lib/generators/incline/templates/incline_application.css +17 -0
- data/lib/generators/incline/templates/incline_application.html.erb +1 -0
- data/lib/generators/incline/templates/incline_application.js +12 -0
- data/lib/generators/incline/templates/incline_database.yml +25 -0
- data/lib/generators/incline/templates/incline_email.yml +20 -0
- data/lib/generators/incline/templates/incline_mailer.html.erb +2 -0
- data/lib/generators/incline/templates/incline_mailer.text.erb +2 -0
- data/lib/generators/incline/templates/incline_users.yml +64 -0
- data/lib/generators/incline/templates/incline_version.rb +3 -0
- data/lib/incline/auth_engine_base.rb +52 -0
- data/lib/incline/data_tables_request.rb +336 -0
- data/lib/incline/date_time_formats.rb +6 -0
- data/lib/incline/engine.rb +212 -0
- data/lib/incline/errors.rb +15 -0
- data/lib/incline/extensions/action_controller_base.rb +526 -0
- data/lib/incline/extensions/action_mailer_base.rb +66 -0
- data/lib/incline/extensions/action_view_base.rb +489 -0
- data/lib/incline/extensions/active_record_base.rb +308 -0
- data/lib/incline/extensions/application.rb +137 -0
- data/lib/incline/extensions/application_configuration.rb +50 -0
- data/lib/incline/extensions/connection_adapter.rb +55 -0
- data/lib/incline/extensions/date_time_value.rb +123 -0
- data/lib/incline/extensions/date_value.rb +77 -0
- data/lib/incline/extensions/decimal_value.rb +55 -0
- data/lib/incline/extensions/erb_scaffold_generator.rb +31 -0
- data/lib/incline/extensions/float_value.rb +59 -0
- data/lib/incline/extensions/form_builder.rb +617 -0
- data/lib/incline/extensions/integer_value.rb +54 -0
- data/lib/incline/extensions/jbuilder_generator.rb +38 -0
- data/lib/incline/extensions/jbuilder_template.rb +39 -0
- data/lib/incline/extensions/main_app.rb +40 -0
- data/lib/incline/extensions/numeric.rb +63 -0
- data/lib/incline/extensions/object.rb +31 -0
- data/lib/incline/extensions/resource_route_generator.rb +53 -0
- data/lib/incline/extensions/session.rb +113 -0
- data/lib/incline/extensions/string.rb +50 -0
- data/lib/incline/extensions/test_case.rb +764 -0
- data/lib/incline/extensions/time_zone_converter.rb +40 -0
- data/lib/incline/global_status.rb +236 -0
- data/lib/incline/helpers/route_hash_formatter.rb +46 -0
- data/lib/incline/json_log_formatter.rb +96 -0
- data/lib/incline/json_logger.rb +17 -0
- data/lib/incline/log.rb +153 -0
- data/lib/incline/number_formats.rb +17 -0
- data/lib/incline/recaptcha.rb +346 -0
- data/lib/incline/user_manager.rb +212 -0
- data/lib/incline/validators/email_validator.rb +45 -0
- data/lib/incline/validators/ip_address_validator.rb +32 -0
- data/lib/incline/validators/recaptcha_validator.rb +37 -0
- data/lib/incline/validators/safe_name_validator.rb +31 -0
- data/lib/incline/version.rb +3 -0
- data/lib/incline/work_path.rb +75 -0
- data/lib/incline.rb +197 -0
- data/lib/tasks/incline_tasks.rake +4 -0
- data/lib/templates/erb/scaffold/_form.html.erb +43 -0
- data/lib/templates/erb/scaffold/_list.html.erb +81 -0
- data/lib/templates/erb/scaffold/edit.html.erb +1 -0
- data/lib/templates/erb/scaffold/index.html.erb +6 -0
- data/lib/templates/erb/scaffold/new.html.erb +1 -0
- data/lib/templates/erb/scaffold/show.html.erb +34 -0
- data/lib/templates/jbuilder/scaffold/_details.json.jbuilder +20 -0
- data/lib/templates/jbuilder/scaffold/index.json.jbuilder +16 -0
- data/lib/templates/jbuilder/scaffold/show.json.jbuilder +16 -0
- data/lib/templates/rails/scaffold_controller/controller.rb +128 -0
- data/test/controllers/incline/access_groups_controller_test.rb +65 -0
- data/test/controllers/incline/access_test_controller_test.rb +53 -0
- data/test/controllers/incline/contact_controller_test.rb +32 -0
- data/test/controllers/incline/security_controller_test.rb +39 -0
- data/test/controllers/incline/welcome_controller_test.rb +16 -0
- data/test/dummy/README.rdoc +28 -0
- data/test/dummy/Rakefile +6 -0
- data/test/dummy/app/assets/images/.keep +0 -0
- data/test/dummy/app/assets/javascripts/application.js +12 -0
- data/test/dummy/app/assets/stylesheets/application.css +17 -0
- data/test/dummy/app/controllers/application_controller.rb +5 -0
- data/test/dummy/app/controllers/concerns/.keep +0 -0
- data/test/dummy/app/helpers/application_helper.rb +2 -0
- data/test/dummy/app/mailers/.keep +0 -0
- data/test/dummy/app/models/.keep +0 -0
- data/test/dummy/app/models/concerns/.keep +0 -0
- data/test/dummy/app/views/layouts/application.html.erb +1 -0
- data/test/dummy/app/views/layouts/incline/_app_menu_anon.html.erb +1 -0
- data/test/dummy/app/views/layouts/incline/_app_menu_authenticated.html.erb +1 -0
- data/test/dummy/app/views/layouts/mailer.html.erb +2 -0
- data/test/dummy/app/views/layouts/mailer.text.erb +2 -0
- data/test/dummy/bin/bundle +3 -0
- data/test/dummy/bin/rails +4 -0
- data/test/dummy/bin/rake +4 -0
- data/test/dummy/bin/setup +29 -0
- data/test/dummy/config/application.rb +38 -0
- data/test/dummy/config/boot.rb +5 -0
- data/test/dummy/config/database.yml +34 -0
- data/test/dummy/config/email.yml +24 -0
- data/test/dummy/config/environment.rb +5 -0
- data/test/dummy/config/environments/development.rb +45 -0
- data/test/dummy/config/environments/production.rb +85 -0
- data/test/dummy/config/environments/test.rb +44 -0
- data/test/dummy/config/initializers/assets.rb +11 -0
- data/test/dummy/config/initializers/backtrace_silencers.rb +7 -0
- data/test/dummy/config/initializers/cookies_serializer.rb +3 -0
- data/test/dummy/config/initializers/filter_parameter_logging.rb +4 -0
- data/test/dummy/config/initializers/inflections.rb +16 -0
- data/test/dummy/config/initializers/mime_types.rb +4 -0
- data/test/dummy/config/initializers/session_store.rb +3 -0
- data/test/dummy/config/initializers/to_time_preserves_timezone.rb +10 -0
- data/test/dummy/config/initializers/wrap_parameters.rb +14 -0
- data/test/dummy/config/locales/en.yml +23 -0
- data/test/dummy/config/routes.rb +6 -0
- data/test/dummy/config.ru +4 -0
- data/test/dummy/db/schema.rb +108 -0
- data/test/dummy/lib/assets/.keep +0 -0
- data/test/dummy/log/.keep +0 -0
- data/test/dummy/public/404.html +67 -0
- data/test/dummy/public/422.html +67 -0
- data/test/dummy/public/500.html +66 -0
- data/test/dummy/public/favicon.ico +0 -0
- data/test/extensions/action_controller_base_extensions_test.rb +21 -0
- data/test/extensions/action_mailer_base_extensions_test.rb +20 -0
- data/test/extensions/action_view_base_extensions_test.rb +267 -0
- data/test/extensions/active_record_extensions_test.rb +173 -0
- data/test/extensions/application_configuration_extensions_test.rb +46 -0
- data/test/extensions/application_extensions_test.rb +23 -0
- data/test/extensions/connection_adapter_extensions_test.rb +54 -0
- data/test/extensions/date_time_value_extensions_test.rb +104 -0
- data/test/extensions/date_value_extensions_test.rb +102 -0
- data/test/extensions/decimal_value_extensions_test.rb +85 -0
- data/test/extensions/erb_scaffold_generator_extensions_test.rb +17 -0
- data/test/extensions/float_value_extensions_test.rb +78 -0
- data/test/extensions/form_builder_extensions_test.rb +28 -0
- data/test/extensions/integer_value_extensions_test.rb +78 -0
- data/test/extensions/jbuilder_generator_extensions_test.rb +21 -0
- data/test/extensions/jbuilder_template_extensions_test.rb +47 -0
- data/test/extensions/main_app_extensions_test.rb +55 -0
- data/test/extensions/numeric_extensions_test.rb +76 -0
- data/test/extensions/object_extensions_test.rb +104 -0
- data/test/extensions/session_extensions_test.rb +69 -0
- data/test/extensions/string_extensions_test.rb +32 -0
- data/test/extensions/test_case_extensions_test.rb +538 -0
- data/test/extensions/time_zone_converter_extensions_test.rb +10 -0
- data/test/fixtures/incline/access_group_group_members.yml +1 -0
- data/test/fixtures/incline/access_group_user_members.yml +1 -0
- data/test/fixtures/incline/access_groups.yml +13 -0
- data/test/fixtures/incline/action_groups.yml +6 -0
- data/test/fixtures/incline/action_securities.yml +18 -0
- data/test/fixtures/incline/user_login_histories.yml +1 -0
- data/test/fixtures/incline/users.yml +64 -0
- data/test/incline_test.rb +63 -0
- data/test/integration/incline/users_edit_test.rb +180 -0
- data/test/integration/incline/users_login_test.rb +105 -0
- data/test/integration/incline/users_signup_test.rb +147 -0
- data/test/integration/navigation_test.rb +11 -0
- data/test/lib/data_tables_request_test.rb +245 -0
- data/test/lib/date_time_formats_test.rb +111 -0
- data/test/lib/global_status_test.rb +89 -0
- data/test/lib/json_log_formatter_test.rb +43 -0
- data/test/lib/log_test.rb +36 -0
- data/test/lib/recaptcha_test.rb +75 -0
- data/test/lib/user_manager_test.rb +47 -0
- data/test/lib/work_path_test.rb +18 -0
- data/test/models/incline/access_group_group_member_test.rb +30 -0
- data/test/models/incline/access_group_test.rb +60 -0
- data/test/models/incline/access_group_user_member_test.rb +29 -0
- data/test/models/incline/action_group_test.rb +27 -0
- data/test/models/incline/action_security_test.rb +176 -0
- data/test/models/incline/contact_message_test.rb +66 -0
- data/test/models/incline/disable_info_test.rb +29 -0
- data/test/models/incline/password_reset_request_test.rb +35 -0
- data/test/models/incline/password_reset_test.rb +51 -0
- data/test/models/incline/user_login_history_test.rb +31 -0
- data/test/models/incline/user_test.rb +91 -0
- data/test/test_helper.rb +42 -0
- data/test/validators/email_validator_test.rb +102 -0
- data/test/validators/ip_address_validator_test.rb +107 -0
- data/test/validators/recaptcha_validator_test.rb +57 -0
- data/test/validators/safe_name_validator_test.rb +101 -0
- metadata +584 -0
@@ -0,0 +1,16 @@
|
|
1
|
+
<% provide(:title, 'Reset password') %>
|
2
|
+
<h1>Reset password</h1>
|
3
|
+
|
4
|
+
<%= error_summary(@user) %>
|
5
|
+
|
6
|
+
<div class="row">
|
7
|
+
<div class="col-md-4 col-md-offset-4">
|
8
|
+
<%= form_for(@user, url: password_reset_path(params[:id])) do |f| %>
|
9
|
+
<%= f.hidden_field :email %>
|
10
|
+
<%= f.text_form_group :password, field_type: 'password' %>
|
11
|
+
<%= f.text_form_group :password_confirmation, field_type: 'password' %>
|
12
|
+
<%= f.recaptcha :recaptcha %>
|
13
|
+
<%= f.submit 'Update password', class: 'btn btn-primary' %>
|
14
|
+
<% end %>
|
15
|
+
</div>
|
16
|
+
</div>
|
@@ -0,0 +1,12 @@
|
|
1
|
+
<% provide(:title, 'Forgot password') %>
|
2
|
+
<h1>Forgot password</h1>
|
3
|
+
|
4
|
+
<div class="row">
|
5
|
+
<div class="col-md-4 col-md-offset-4">
|
6
|
+
<%= form_for(:password_reset, url: password_resets_path) do |f| %>
|
7
|
+
<%= f.text_form_group :email, field_type: 'email' %>
|
8
|
+
<%= f.recaptcha :recaptcha %>
|
9
|
+
<%= f.submit 'Submit', class: 'btn btn-primary' %>
|
10
|
+
<% end %>
|
11
|
+
</div>
|
12
|
+
</div>
|
@@ -0,0 +1,7 @@
|
|
1
|
+
json.set! 'DT_RowId', "security_#{security.id}"
|
2
|
+
json.set! 'DT_Path', security_path(security)
|
3
|
+
json.set! 'path', h(security.path)
|
4
|
+
json.set! 'controller_name', h(security.controller_name)
|
5
|
+
json.set! 'action_name', h(security.action_name)
|
6
|
+
json.set! 'short_permitted', h(security.short_permitted)
|
7
|
+
json.set! 'updated_at', security.updated_at
|
@@ -0,0 +1,20 @@
|
|
1
|
+
<%= error_summary(@security) %>
|
2
|
+
<div class="col-md-4 col-md-offset-4">
|
3
|
+
<div class="panel panel-primary">
|
4
|
+
<div class="panel-heading">
|
5
|
+
<h4 class="panel-title">Update Action Security</h4>
|
6
|
+
</div>
|
7
|
+
<div class="panel-body">
|
8
|
+
<%= form_for(@security, url: security_path(@security), method: :patch) do |f| %>
|
9
|
+
<%= f.static_form_group :path %>
|
10
|
+
<%= f.static_form_group :controller_name %>
|
11
|
+
<%= f.static_form_group :action_name %>
|
12
|
+
<%= f.select_form_group :group_ids, Incline::AccessGroup.sorted, :id, :to_s, label_text: 'Groups authorized for this action', field_class: 'form-control select2', field_multiple: true %>
|
13
|
+
|
14
|
+
<%= f.submit class: 'btn btn-primary' %>
|
15
|
+
<%= link_to 'Cancel', index_security_path, class: 'btn btn-default' %>
|
16
|
+
<% end %>
|
17
|
+
|
18
|
+
</div>
|
19
|
+
</div>
|
20
|
+
</div>
|
@@ -0,0 +1,89 @@
|
|
1
|
+
<table id="dt-security" class="table" style="width: 100%;">
|
2
|
+
<thead>
|
3
|
+
<tr>
|
4
|
+
<th>Path</th>
|
5
|
+
<th>
|
6
|
+
<%= dt_header_filter 'Controller name', 1, @lists[:controller_name] %>
|
7
|
+
</th>
|
8
|
+
<th>
|
9
|
+
<%= dt_header_filter 'Action name', 2, @lists[:action_name] %>
|
10
|
+
</th>
|
11
|
+
<th>
|
12
|
+
<%= dt_header_filter 'Permitted', 3, @lists[:short_permitted] %>
|
13
|
+
</th>
|
14
|
+
<th class="text-right"></th>
|
15
|
+
</tr>
|
16
|
+
</thead>
|
17
|
+
</table>
|
18
|
+
|
19
|
+
|
20
|
+
<% provide :scripts do %>
|
21
|
+
<script type="text/javascript">
|
22
|
+
//<![CDATA[
|
23
|
+
|
24
|
+
function filter_column(column, text) {
|
25
|
+
var dt = $('#dt-security').dataTable().api();
|
26
|
+
var col = dt.column(column);
|
27
|
+
|
28
|
+
if (col.search() !== text) {
|
29
|
+
col.search(text).draw();
|
30
|
+
}
|
31
|
+
}
|
32
|
+
|
33
|
+
$(function() {
|
34
|
+
$('#dt-security').DataTable({
|
35
|
+
dom: '<"panel-body"<"col-sm-6 col-sm-offset-6"fr>>t<"panel-body"<"col-sm-6"i><"col-sm-6"p>>',
|
36
|
+
ajax: {
|
37
|
+
url: '<%= api_path %>',
|
38
|
+
type: 'POST'
|
39
|
+
},
|
40
|
+
columns: [
|
41
|
+
{
|
42
|
+
data: 'path',
|
43
|
+
orderable: true,
|
44
|
+
searchable: true
|
45
|
+
},
|
46
|
+
{
|
47
|
+
data: 'controller_name',
|
48
|
+
orderable: false,
|
49
|
+
searchable: true
|
50
|
+
},
|
51
|
+
{
|
52
|
+
data: 'action_name',
|
53
|
+
orderable: false,
|
54
|
+
searchable: true
|
55
|
+
},
|
56
|
+
{
|
57
|
+
data: 'short_permitted',
|
58
|
+
orderable: false,
|
59
|
+
searchable: true
|
60
|
+
},
|
61
|
+
{
|
62
|
+
orderable: false,
|
63
|
+
searchable: false,
|
64
|
+
data: function (row, type, set, meta) {
|
65
|
+
if (type === 'display') {
|
66
|
+
var ret = '<div class="text-right">';
|
67
|
+
|
68
|
+
// the show icon.
|
69
|
+
ret += '<a href="javascript:inlineForm(\'' + row.DT_Path + '\')" title="Details" class="btn btn-default btn-xs"><i class="glyphicon glyphicon-zoom-in"></i></a>';
|
70
|
+
|
71
|
+
// the edit icon.
|
72
|
+
ret += '<a href="javascript:inlineForm(\'' + row.DT_Path + '/edit\')" title="Edit" class="btn btn-default btn-xs"><i class="glyphicon glyphicon-pencil"></i></a>';
|
73
|
+
|
74
|
+
ret += '</div>';
|
75
|
+
return ret;
|
76
|
+
} else {
|
77
|
+
return row.DT_Path;
|
78
|
+
}
|
79
|
+
}
|
80
|
+
}
|
81
|
+
],
|
82
|
+
responsive: true,
|
83
|
+
serverSide: true
|
84
|
+
});
|
85
|
+
|
86
|
+
});
|
87
|
+
//]]>
|
88
|
+
</script>
|
89
|
+
<% end %>
|
@@ -0,0 +1,16 @@
|
|
1
|
+
if @dt_request&.provided?
|
2
|
+
json.set! 'draw', @dt_request.draw
|
3
|
+
json.set! 'recordsTotal', @dt_request.records_total
|
4
|
+
json.set! 'recordsFiltered', @dt_request.records_filtered
|
5
|
+
json.data do
|
6
|
+
json.array!(@dt_request.records) do |security|
|
7
|
+
json.partial! 'details', locals: { security: security }
|
8
|
+
end
|
9
|
+
end
|
10
|
+
if @dt_request.error?
|
11
|
+
json.set! 'error', @dt_request.error
|
12
|
+
end
|
13
|
+
else
|
14
|
+
json.set! 'error', 'No data tables request received.'
|
15
|
+
end
|
16
|
+
json.set! 'appInfo', h(Rails.application.app_info)
|
@@ -0,0 +1,31 @@
|
|
1
|
+
<div class="row">
|
2
|
+
<div class="col-sm-8 col-md-6 col-sm-offset-2 col-md-offset-3">
|
3
|
+
<div class="panel panel-primary">
|
4
|
+
<div class="panel-heading">
|
5
|
+
<h4 class="panel-title">Action Security</h4>
|
6
|
+
</div>
|
7
|
+
<div class="panel-body">
|
8
|
+
<div class="form-group">
|
9
|
+
<label>Path</label>
|
10
|
+
<span class="form-control"><%= @security.path %></span>
|
11
|
+
</div>
|
12
|
+
<div class="form-group">
|
13
|
+
<label>Controller name</label>
|
14
|
+
<span class="form-control"><%= @security.controller_name %></span>
|
15
|
+
</div>
|
16
|
+
<div class="form-group">
|
17
|
+
<label>Action name</label>
|
18
|
+
<span class="form-control"><%= @security.action_name %></span>
|
19
|
+
</div>
|
20
|
+
<div class="form-group">
|
21
|
+
<label>Permitted</label>
|
22
|
+
<div class="form-control auto-height"><%= @security.permitted %></div>
|
23
|
+
</div>
|
24
|
+
|
25
|
+
<%= link_to 'Cancel', index_security_path, class: 'btn btn-default' %>
|
26
|
+
</div>
|
27
|
+
</div>
|
28
|
+
</div>
|
29
|
+
</div>
|
30
|
+
|
31
|
+
|
@@ -0,0 +1,26 @@
|
|
1
|
+
|
2
|
+
<% provide(:title, 'Log in') %>
|
3
|
+
<h1>Log in</h1>
|
4
|
+
|
5
|
+
<div class="row">
|
6
|
+
<div class="col-md-4 col-md-offset-4">
|
7
|
+
<%= form_for(:session, url: incline.login_path) do |f| %>
|
8
|
+
<%= f.text_form_group :email, field_type: 'email' %>
|
9
|
+
<div class="form-group">
|
10
|
+
<%= f.label :password %> <small><%= link_to '(forgot password)', incline.new_password_reset_path %></small>
|
11
|
+
<%= f.password_field :password, class: 'form-control' %>
|
12
|
+
</div>
|
13
|
+
|
14
|
+
<%= f.label :remember_me, class: 'checkbox inline' do %>
|
15
|
+
<%= f.check_box :remember_me %>
|
16
|
+
<span>Remember me on this computer</span>
|
17
|
+
<% end %>
|
18
|
+
|
19
|
+
<%= f.submit 'Log in', class: 'btn btn-primary' %>
|
20
|
+
<% end %>
|
21
|
+
<br/>
|
22
|
+
<p>
|
23
|
+
New user? <%= link_to 'Sign up now!', incline.signup_path %>
|
24
|
+
</p>
|
25
|
+
</div>
|
26
|
+
</div>
|
@@ -0,0 +1,7 @@
|
|
1
|
+
<p>Hello <%= @data[:user].name %>,</p>
|
2
|
+
|
3
|
+
<p>Welcome to <%= Rails.application.app_name %>! Before you can begin to use the site, you need to click on the link below to activate your account.</p>
|
4
|
+
|
5
|
+
<p><%= link_to 'Activate', edit_account_activation_url(@data[:user].activation_token, email: @data[:user].email) %></p>
|
6
|
+
<br>
|
7
|
+
|
@@ -0,0 +1,6 @@
|
|
1
|
+
Hello <%= @data[:user].name %>,
|
2
|
+
|
3
|
+
Welcome to <%= Rails.application.app_name %>! Before you can begin to use the site, you need to click on the link below to activate your account.
|
4
|
+
|
5
|
+
<%= edit_account_activation_url(@data[:user].activation_token, email: @data[:user].email) %>
|
6
|
+
|
@@ -0,0 +1,8 @@
|
|
1
|
+
<p>To reset your password, click the link below:</p>
|
2
|
+
|
3
|
+
<p><%= link_to 'Reset password', edit_password_reset_url(id: @data[:user].reset_token, email: @data[:user].email) %></p>
|
4
|
+
|
5
|
+
<p>This link will expire in two hours.</p>
|
6
|
+
|
7
|
+
<p>If you did not request your password to be reset, please ignore this email and your password will stay as it is.</p>
|
8
|
+
|
@@ -0,0 +1,7 @@
|
|
1
|
+
To reset your password, click the link below:
|
2
|
+
|
3
|
+
<%= edit_password_reset_url(id: @data[:user].reset_token, email: @data[:user].email) %>
|
4
|
+
|
5
|
+
This link will expire in two hours.
|
6
|
+
|
7
|
+
If you did not request your password to be reset, please ignore this email and your password will stay as it is.
|
@@ -0,0 +1,32 @@
|
|
1
|
+
unless user.new_record?
|
2
|
+
json.set! 'DT_RowId', "user_#{user.id}"
|
3
|
+
json.set! 'DT_Path', user_path(user)
|
4
|
+
if user.destroyed?
|
5
|
+
json.set! 'DT_RowAction', 'remove'
|
6
|
+
end
|
7
|
+
if user.enabled?
|
8
|
+
if user.failed_login_streak.count > 5
|
9
|
+
json.set! 'DT_RowClass', 'cell-danger'
|
10
|
+
else
|
11
|
+
unless user.activated?
|
12
|
+
json.set! 'DT_RowClass', 'cell-info'
|
13
|
+
end
|
14
|
+
end
|
15
|
+
else
|
16
|
+
json.set! 'DT_RowClass', 'cell-warning'
|
17
|
+
end
|
18
|
+
end
|
19
|
+
json.set! 'name', h(user.name)
|
20
|
+
json.set! 'email', h(user.email)
|
21
|
+
json.set! 'created_at', user.created_at
|
22
|
+
json.set! 'updated_at', user.updated_at
|
23
|
+
json.set! 'activated', user.activated?
|
24
|
+
json.set! 'system_admin', user.system_admin?
|
25
|
+
json.set! 'enabled', user.enabled?
|
26
|
+
json.set! 'comments', h(user.comments).gsub("\n", "<br>\n")
|
27
|
+
json.set! 'show_edit', current_user?(user) || system_admin?
|
28
|
+
json.set! 'show_disable', !current_user?(user) && system_admin? && user.enabled?
|
29
|
+
json.set! 'show_enable', !current_user?(user) && system_admin? && !user.enabled?
|
30
|
+
json.set! 'show_delete', !current_user?(user) && system_admin? && !user.enabled? && user.disabled_at < 7.days.ago
|
31
|
+
json.set! 'show_promote', !current_user?(user) && system_admin? && !user.system_admin?
|
32
|
+
json.set! 'show_demote', !current_user?(user) && system_admin? && user.system_admin?
|
@@ -0,0 +1,21 @@
|
|
1
|
+
<%= error_summary(user) %>
|
2
|
+
|
3
|
+
<div class="row">
|
4
|
+
<div class="col-md-4 col-md-offset-4">
|
5
|
+
<%= form_for(user, url: user.new_record? ? signup_path : user_path(user), method: user.new_record? ? 'post' : 'patch') do |f| %>
|
6
|
+
<%= f.text_form_group :name, field_maxlength: 100 %>
|
7
|
+
<%= f.text_form_group :email, field_type: 'email', field_maxlength: 250 %>
|
8
|
+
<%= f.text_form_group :password, field_type: 'password' %>
|
9
|
+
<%= f.text_form_group :password_confirmation, field_type: 'password' %>
|
10
|
+
<% if system_admin? && !current_user?(user) %>
|
11
|
+
<%= f.select_form_group :group_ids, Incline::AccessGroup.all.sorted, :id, :to_s, label_text: 'Group memberships', field_class: 'form-control select2', field_multiple: true %>
|
12
|
+
<% end %>
|
13
|
+
<% unless system_admin? %>
|
14
|
+
<%= f.recaptcha :recaptcha if user.new_record? %>
|
15
|
+
<% end %>
|
16
|
+
|
17
|
+
<%= f.submit user.new_record? ? 'Create account' : 'Update account', class: 'btn btn-primary' %>
|
18
|
+
<%= link_to 'Cancel', root_url, class: 'btn btn-default' %>
|
19
|
+
<% end %>
|
20
|
+
</div>
|
21
|
+
</div>
|
@@ -0,0 +1,102 @@
|
|
1
|
+
<table id="dt-users" class="table" style="width: 100%;">
|
2
|
+
<thead>
|
3
|
+
<tr>
|
4
|
+
<th>Name</th>
|
5
|
+
<th>Email</th>
|
6
|
+
<th>Created</th>
|
7
|
+
<th>Comments</th>
|
8
|
+
<th><%= link_to 'New', signup_path, class: 'btn btn-default btn-xs inline_form' %></th>
|
9
|
+
</tr>
|
10
|
+
</thead>
|
11
|
+
</table>
|
12
|
+
|
13
|
+
<% provide :scripts do %>
|
14
|
+
<script type="text/javascript">
|
15
|
+
//<![CDATA[
|
16
|
+
$(function() {
|
17
|
+
$('#dt-users').DataTable({
|
18
|
+
dom: '<"panel-body"<"col-sm-6 col-sm-offset-6"fr>>t<"panel-body"<"col-sm-6"i><"col-sm-6"p>>',
|
19
|
+
ajax: {
|
20
|
+
url: '<%= api_path %>',
|
21
|
+
type: 'POST'
|
22
|
+
},
|
23
|
+
columns: [
|
24
|
+
{
|
25
|
+
data: 'name',
|
26
|
+
orderable: true,
|
27
|
+
searchable: true
|
28
|
+
},
|
29
|
+
{
|
30
|
+
data: 'email',
|
31
|
+
orderable: true,
|
32
|
+
searchable: true
|
33
|
+
},
|
34
|
+
{
|
35
|
+
data: 'created_at',
|
36
|
+
orderable: true,
|
37
|
+
searchable: true
|
38
|
+
},
|
39
|
+
{
|
40
|
+
data: 'comments',
|
41
|
+
orderable: false,
|
42
|
+
searchable: true
|
43
|
+
},
|
44
|
+
{
|
45
|
+
orderable: false,
|
46
|
+
searchable: false,
|
47
|
+
data: function (row, type, set, meta) {
|
48
|
+
if (type === 'display')
|
49
|
+
{
|
50
|
+
var ret = '<div class="text-right">';
|
51
|
+
var drop = row.show_disable || row.show_enable || row.show_promote || row.show_demote || row.show_delete;
|
52
|
+
|
53
|
+
ret += '<a href="javascript:inlineForm(\'' + row.DT_Path + '\')" title="Details" class="btn btn-default btn-xs"><i class="glyphicon glyphicon-zoom-in"></i></a>';
|
54
|
+
|
55
|
+
if (drop) {
|
56
|
+
ret += ' <div class="btn-group">';
|
57
|
+
if (row.show_edit) {
|
58
|
+
ret += '<a href="javascript:inlineForm(\'' + row.DT_Path + '/edit\')" title="Edit" class="btn btn-default btn-xs"><i class="glyphicon glyphicon-pencil"></i></a>';
|
59
|
+
} else {
|
60
|
+
ret += '<a href="javascript:void(0)" title="Options" class="btn btn-default btn-xs"><i class="glyphicon glyphicon-star"></i></a>';
|
61
|
+
}
|
62
|
+
ret += '<button type="button" class="btn btn-default btn-xs dropdown-toggle" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false"><span class="caret"></span><span class="sr-only">Toggle Dropdown</span></button><ul class="dropdown-menu">'
|
63
|
+
|
64
|
+
if (row.show_promote) {
|
65
|
+
ret += '<li><a href="javascript:inlineAction(\'' + row.DT_Path + '/promote\',\'patch\')" title="Promote to administrator">Promote</a></li>';
|
66
|
+
} else if (row.show_demote) {
|
67
|
+
ret += '<li><a href="javascript:inlineAction(\'' + row.DT_Path + '/demote\',\'patch\')" title="Demote from administrator">Demote</a></li>';
|
68
|
+
}
|
69
|
+
|
70
|
+
if (row.show_disable) {
|
71
|
+
ret += '<li><a href="javascript:inlineForm(\'' + row.DT_Path + '/disable\')" title="Disable">Disable</a></li>';
|
72
|
+
} else if (row.show_enable) {
|
73
|
+
ret += '<li><a href="javascript:inlineAction(\'' + row.DT_Path + '/enable\',\'patch\')" title="Enable">Enable</a></li>';
|
74
|
+
}
|
75
|
+
|
76
|
+
if (row.show_delete) {
|
77
|
+
ret += '<li role="separator" class="divider"></li><li><a href="javascript:inlineAction(\'' + row.DT_Path + '\',\'delete\')" title="Remove" data-confirm="Are you sure you want to remove this user?">Remove</a></li>';
|
78
|
+
}
|
79
|
+
|
80
|
+
ret += '</ul></div>';
|
81
|
+
} else {
|
82
|
+
if (row.show_edit) {
|
83
|
+
ret += ' <a href="javascript:inlineForm(\'' + row.DT_Path + '/edit\')" title="Edit" class="btn btn-default btn-xs"><i class="glyphicon glyphicon-pencil"></i></a>';
|
84
|
+
}
|
85
|
+
}
|
86
|
+
|
87
|
+
ret += '</div>';
|
88
|
+
|
89
|
+
return ret;
|
90
|
+
} else {
|
91
|
+
return row.DT_Path;
|
92
|
+
}
|
93
|
+
}
|
94
|
+
}
|
95
|
+
],
|
96
|
+
responsive: true,
|
97
|
+
serverSide: true
|
98
|
+
});
|
99
|
+
});
|
100
|
+
//]]>
|
101
|
+
</script>
|
102
|
+
<% end %>
|
@@ -0,0 +1,19 @@
|
|
1
|
+
<% provide(:title, 'Disable user') %>
|
2
|
+
<%= error_summary @disable_info %>
|
3
|
+
<div class="row">
|
4
|
+
<div class="col-md-4 col-md-offset-4">
|
5
|
+
<div class="panel panel-default">
|
6
|
+
<div class="panel-heading">
|
7
|
+
<h4 class="panel-title">Disable <%= @user.name %></h4>
|
8
|
+
</div>
|
9
|
+
<div class="panel-body">
|
10
|
+
<%= form_for @disable_info, url: disable_user_path(@user), method: :patch do |f| %>
|
11
|
+
<%= f.textarea_form_group :reason %>
|
12
|
+
|
13
|
+
<%= f.submit 'Disable', class: 'btn btn-danger' %>
|
14
|
+
<%= link_to 'Cancel', users_path, class: 'btn btn-default' %>
|
15
|
+
<% end %>
|
16
|
+
</div>
|
17
|
+
</div>
|
18
|
+
</div>
|
19
|
+
</div>
|
@@ -0,0 +1,16 @@
|
|
1
|
+
if @dt_request&.provided?
|
2
|
+
json.set! 'draw', @dt_request.draw
|
3
|
+
json.set! 'recordsTotal', @dt_request.records_total
|
4
|
+
json.set! 'recordsFiltered', @dt_request.records_filtered
|
5
|
+
json.data do
|
6
|
+
json.array!(@dt_request.records) do |user|
|
7
|
+
json.partial! 'details', locals: { user: user }
|
8
|
+
end
|
9
|
+
end
|
10
|
+
if @dt_request.error?
|
11
|
+
json.set! 'error', @dt_request.error
|
12
|
+
end
|
13
|
+
else
|
14
|
+
json.set! 'error', 'No data tables request received.'
|
15
|
+
end
|
16
|
+
json.set! 'appInfo', h(Rails.application.app_info)
|
@@ -0,0 +1 @@
|
|
1
|
+
<%= render 'layouts/incline/incline_app' %>
|
@@ -0,0 +1,18 @@
|
|
1
|
+
<% if logged_in? -%>
|
2
|
+
<li class="dropdown">
|
3
|
+
<a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button"><%= current_user.name %></a>
|
4
|
+
<ul class="dropdown-menu">
|
5
|
+
<li><%= link_to 'My Account', incline.user_path(current_user) %></li>
|
6
|
+
<li class="divider"></li>
|
7
|
+
<% if current_user.system_admin? %>
|
8
|
+
<li><%= link_to 'All Users', incline.users_path %></li>
|
9
|
+
<li><%= link_to 'Access Groups', incline.access_groups_path %></li>
|
10
|
+
<li><%= link_to 'Action Security', incline.index_security_path %></li>
|
11
|
+
<li class="divider"></li>
|
12
|
+
<% end %>
|
13
|
+
<li><%= link_to 'Log out', incline.logout_path, method: :delete %></li>
|
14
|
+
</ul>
|
15
|
+
</li>
|
16
|
+
<% else -%>
|
17
|
+
<li><%= link_to 'Log in', incline.login_path %></li>
|
18
|
+
<% end -%>
|
@@ -0,0 +1 @@
|
|
1
|
+
<!-- fill in the application menu for everybody including non-authenticated visitors in 'layouts/incline/_app_menu_anon.html.erb' file -->
|
@@ -0,0 +1 @@
|
|
1
|
+
<!-- fill in the application menu for authenticated users in 'layouts/incline/_app_menu_authenticated.html.erb' file -->
|
@@ -0,0 +1,13 @@
|
|
1
|
+
<div class="container">
|
2
|
+
<footer>
|
3
|
+
<small>
|
4
|
+
<%= Rails.application.app_info %>
|
5
|
+
</small>
|
6
|
+
<nav>
|
7
|
+
<ul>
|
8
|
+
<li><%= link_to 'Contact', incline.contact_path %></li>
|
9
|
+
</ul>
|
10
|
+
</nav>
|
11
|
+
</footer>
|
12
|
+
<%= debug(params) if Rails.env.development? %>
|
13
|
+
</div>
|
@@ -0,0 +1,21 @@
|
|
1
|
+
<nav class="navbar navbar-default navbar-fixed-top">
|
2
|
+
<div class="container">
|
3
|
+
<div class="navbar-header">
|
4
|
+
<button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false" aria-controls="navbar">
|
5
|
+
<span class="sr-only">Toggle navigation</span>
|
6
|
+
<span class="icon-bar"></span>
|
7
|
+
<span class="icon-bar"></span>
|
8
|
+
<span class="icon-bar"></span>
|
9
|
+
</button>
|
10
|
+
<%= link_to image_tag('incline/barcode-B.svg', alt: 'BarkerEST'), root_path, id: 'logo' %>
|
11
|
+
</div>
|
12
|
+
<div id="navbar" class="collapse navbar-collapse">
|
13
|
+
<ul class="nav navbar-nav navbar-right">
|
14
|
+
<li><%= link_to 'Home', root_path %></li>
|
15
|
+
<%= render 'layouts/incline/app_menu_anon' %>
|
16
|
+
<%= render 'layouts/incline/app_menu_authenticated' if logged_in? %>
|
17
|
+
<%= render 'layouts/incline/account_menu' %>
|
18
|
+
</ul>
|
19
|
+
</div>
|
20
|
+
</div>
|
21
|
+
</nav>
|