foreman_patch 1.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/LICENSE +619 -0
- data/README.md +38 -0
- data/Rakefile +53 -0
- data/app/assets/javascript/foreman_patch/plan_edit_windows.js +9 -0
- data/app/assets/stylesheets/foreman_patch/cycle_plans.scss +6 -0
- data/app/assets/stylesheets/foreman_patch/foreman_patch.css +4 -0
- data/app/controllers/concerns/foreman_patch/parameters/ticket_field.rb +26 -0
- data/app/controllers/foreman_patch/api/v2/base_controller.rb +12 -0
- data/app/controllers/foreman_patch/api/v2/cycles_controller.rb +78 -0
- data/app/controllers/foreman_patch/api/v2/groups_controller.rb +70 -0
- data/app/controllers/foreman_patch/api/v2/host_groups_controller.rb +13 -0
- data/app/controllers/foreman_patch/api/v2/invocations_controller.rb +70 -0
- data/app/controllers/foreman_patch/api/v2/plans_controller.rb +79 -0
- data/app/controllers/foreman_patch/api/v2/rounds_controller.rb +77 -0
- data/app/controllers/foreman_patch/api/v2/window_plans_controller.rb +73 -0
- data/app/controllers/foreman_patch/api/v2/windows_controller.rb +85 -0
- data/app/controllers/foreman_patch/concerns/api/v2/hosts_controller_extensions.rb +21 -0
- data/app/controllers/foreman_patch/concerns/hosts_controller_extensions.rb +61 -0
- data/app/controllers/foreman_patch/cycles_controller.rb +34 -0
- data/app/controllers/foreman_patch/groups_controller.rb +68 -0
- data/app/controllers/foreman_patch/invocations_controller.rb +51 -0
- data/app/controllers/foreman_patch/plans_controller.rb +59 -0
- data/app/controllers/foreman_patch/rounds_controller.rb +18 -0
- data/app/controllers/foreman_patch/ticket_fields_controller.rb +37 -0
- data/app/controllers/foreman_patch/window_plans_controller.rb +60 -0
- data/app/controllers/foreman_patch/windows_controller.rb +58 -0
- data/app/helpers/concerns/foreman_patch/hosts_helper_extensions.rb +13 -0
- data/app/helpers/foreman_patch/cycles_helper.rb +19 -0
- data/app/helpers/foreman_patch/hosts_helper.rb +52 -0
- data/app/helpers/foreman_patch/patching_helper.rb +116 -0
- data/app/helpers/foreman_patch/plans_helper.rb +45 -0
- data/app/helpers/foreman_patch/ticket_helper.rb +11 -0
- data/app/helpers/foreman_patch/window_patching_helper.rb +20 -0
- data/app/helpers/foreman_patch/window_plans_helper.rb +13 -0
- data/app/helpers/foreman_patch/windows_helper.rb +17 -0
- data/app/lib/actions/foreman_patch/cycle/complete.rb +41 -0
- data/app/lib/actions/foreman_patch/cycle/create.rb +69 -0
- data/app/lib/actions/foreman_patch/cycle/initiate.rb +68 -0
- data/app/lib/actions/foreman_patch/cycle/plan.rb +73 -0
- data/app/lib/actions/foreman_patch/cycle/prepare_content.rb +123 -0
- data/app/lib/actions/foreman_patch/host/reschedule.rb +32 -0
- data/app/lib/actions/foreman_patch/invocation/action.rb +135 -0
- data/app/lib/actions/foreman_patch/invocation/ensure_services.rb +47 -0
- data/app/lib/actions/foreman_patch/invocation/patch.rb +93 -0
- data/app/lib/actions/foreman_patch/invocation/reschedule.rb +21 -0
- data/app/lib/actions/foreman_patch/invocation/restart.rb +101 -0
- data/app/lib/actions/foreman_patch/invocation/update_packages.rb +52 -0
- data/app/lib/actions/foreman_patch/invocation/wait_for_host.rb +103 -0
- data/app/lib/actions/foreman_patch/round/add_missing_hosts.rb +21 -0
- data/app/lib/actions/foreman_patch/round/create.rb +37 -0
- data/app/lib/actions/foreman_patch/round/patch.rb +81 -0
- data/app/lib/actions/foreman_patch/round/plan.rb +33 -0
- data/app/lib/actions/foreman_patch/round/resolve_hosts.rb +45 -0
- data/app/lib/actions/foreman_patch/window/create.rb +41 -0
- data/app/lib/actions/foreman_patch/window/patch.rb +72 -0
- data/app/lib/actions/foreman_patch/window/plan.rb +43 -0
- data/app/lib/actions/foreman_patch/window/publish.rb +32 -0
- data/app/lib/actions/foreman_patch/window/resolve_hosts.rb +31 -0
- data/app/lib/actions/helpers/failure_notification.rb +20 -0
- data/app/lib/actions/helpers/with_feature_action.rb +102 -0
- data/app/lib/actions/middleware/check_exit_status.rb +31 -0
- data/app/mailers/foreman_patch/cycle_mailer.rb +17 -0
- data/app/mailers/foreman_patch/group_mailer.rb +41 -0
- data/app/mailers/foreman_patch/invocation_mailer.rb +19 -0
- data/app/models/foreman_patch/concerns/group_facet_host_extensions.rb +35 -0
- data/app/models/foreman_patch/concerns/host_managed_extensions.rb +17 -0
- data/app/models/foreman_patch/cycle.rb +49 -0
- data/app/models/foreman_patch/group.rb +43 -0
- data/app/models/foreman_patch/host/group_facet.rb +13 -0
- data/app/models/foreman_patch/invocation.rb +60 -0
- data/app/models/foreman_patch/plan.rb +110 -0
- data/app/models/foreman_patch/plan_task_group.rb +11 -0
- data/app/models/foreman_patch/round.rb +68 -0
- data/app/models/foreman_patch/ticket_field.rb +23 -0
- data/app/models/foreman_patch/window.rb +123 -0
- data/app/models/foreman_patch/window_plan.rb +77 -0
- data/app/models/foreman_patch/window_task_group.rb +11 -0
- data/app/models/setting/patching.rb +57 -0
- data/app/services/foreman_patch/cycle_name_generator.rb +38 -0
- data/app/services/foreman_patch/ticket/affected_items.rb +110 -0
- data/app/services/foreman_patch/ticket/api.rb +68 -0
- data/app/services/foreman_patch/ticket/change_request.rb +92 -0
- data/app/services/foreman_patch/ticket/field_render.rb +21 -0
- data/app/services/foreman_patch/ticket/payload.rb +136 -0
- data/app/services/foreman_patch/ticket.rb +14 -0
- data/app/views/dashboard/_foreman_patch_widget.html.erb +2 -0
- data/app/views/foreman_patch/api/v2/cycles/base.json.rabl +3 -0
- data/app/views/foreman_patch/api/v2/cycles/create.json.rabl +3 -0
- data/app/views/foreman_patch/api/v2/cycles/index.json.rabl +3 -0
- data/app/views/foreman_patch/api/v2/cycles/show.json.rabl +9 -0
- data/app/views/foreman_patch/api/v2/cycles/update.json.rabl +3 -0
- data/app/views/foreman_patch/api/v2/group_facet/base.json.rabl +7 -0
- data/app/views/foreman_patch/api/v2/group_facet/base_with_root.json.rabl +4 -0
- data/app/views/foreman_patch/api/v2/group_facet/show.json.rabl +3 -0
- data/app/views/foreman_patch/api/v2/groups/base.json.rabl +3 -0
- data/app/views/foreman_patch/api/v2/groups/create.json.rabl +3 -0
- data/app/views/foreman_patch/api/v2/groups/index.json.rabl +2 -0
- data/app/views/foreman_patch/api/v2/groups/show.json.rabl +14 -0
- data/app/views/foreman_patch/api/v2/groups/update.json.rabl +3 -0
- data/app/views/foreman_patch/api/v2/invocations/base.json.rabl +6 -0
- data/app/views/foreman_patch/api/v2/invocations/index.json.rabl +3 -0
- data/app/views/foreman_patch/api/v2/invocations/phase.json.rabl +7 -0
- data/app/views/foreman_patch/api/v2/invocations/show.json.rabl +7 -0
- data/app/views/foreman_patch/api/v2/plans/base.json.rabl +3 -0
- data/app/views/foreman_patch/api/v2/plans/create.json.rabl +2 -0
- data/app/views/foreman_patch/api/v2/plans/index.json.rabl +3 -0
- data/app/views/foreman_patch/api/v2/plans/show.json.rabl +9 -0
- data/app/views/foreman_patch/api/v2/plans/update.json.rabl +2 -0
- data/app/views/foreman_patch/api/v2/rounds/base.json.rabl +3 -0
- data/app/views/foreman_patch/api/v2/rounds/index.json.rabl +3 -0
- data/app/views/foreman_patch/api/v2/rounds/show.json.rabl +17 -0
- data/app/views/foreman_patch/api/v2/rounds/status.json.rabl +11 -0
- data/app/views/foreman_patch/api/v2/window_plans/base.json.rabl +4 -0
- data/app/views/foreman_patch/api/v2/window_plans/create.json.rabl +2 -0
- data/app/views/foreman_patch/api/v2/window_plans/index.json.rabl +2 -0
- data/app/views/foreman_patch/api/v2/window_plans/show.json.rabl +14 -0
- data/app/views/foreman_patch/api/v2/window_plans/update.json.rabl +2 -0
- data/app/views/foreman_patch/api/v2/windows/base.json.rabl +3 -0
- data/app/views/foreman_patch/api/v2/windows/index.json.rabl +3 -0
- data/app/views/foreman_patch/api/v2/windows/schedule.json.rabl +13 -0
- data/app/views/foreman_patch/api/v2/windows/show.json.rabl +13 -0
- data/app/views/foreman_patch/api/v2/windows/update.json.rabl +3 -0
- data/app/views/foreman_patch/cycle_mailer/_details.html.erb +4 -0
- data/app/views/foreman_patch/cycle_mailer/_round.html.erb +12 -0
- data/app/views/foreman_patch/cycle_mailer/_summary.html.erb +6 -0
- data/app/views/foreman_patch/cycle_mailer/_window.html.erb +4 -0
- data/app/views/foreman_patch/cycle_mailer/planned.html.erb +7 -0
- data/app/views/foreman_patch/cycles/_form.html.erb +9 -0
- data/app/views/foreman_patch/cycles/edit.html.erb +41 -0
- data/app/views/foreman_patch/cycles/index.html.erb +45 -0
- data/app/views/foreman_patch/cycles/show.html.erb +26 -0
- data/app/views/foreman_patch/group_mailer/_dashboard.html.erb +31 -0
- data/app/views/foreman_patch/group_mailer/_list.html.erb +17 -0
- data/app/views/foreman_patch/group_mailer/completed.html.erb +16 -0
- data/app/views/foreman_patch/group_mailer/initiated.html.erb +4 -0
- data/app/views/foreman_patch/groups/_form.html.erb +9 -0
- data/app/views/foreman_patch/groups/edit.html.erb +3 -0
- data/app/views/foreman_patch/groups/index.html.erb +40 -0
- data/app/views/foreman_patch/groups/new.html.erb +3 -0
- data/app/views/foreman_patch/hosts/hosts/new_action.html.erb +1 -0
- data/app/views/foreman_patch/hosts/new_action.html.erb +1 -0
- data/app/views/foreman_patch/invocation_mailer/_output_line_set.html.erb +6 -0
- data/app/views/foreman_patch/invocation_mailer/_output_line_set.text.erb +3 -0
- data/app/views/foreman_patch/invocation_mailer/failure.html.erb +50 -0
- data/app/views/foreman_patch/invocation_mailer/failure.text.erb +10 -0
- data/app/views/foreman_patch/invocations/_output_line_set.html.erb +8 -0
- data/app/views/foreman_patch/invocations/_phase.html.erb +17 -0
- data/app/views/foreman_patch/invocations/_primary.html.erb +1 -0
- data/app/views/foreman_patch/invocations/_refresh.js.erb +7 -0
- data/app/views/foreman_patch/invocations/show.html.erb +44 -0
- data/app/views/foreman_patch/invocations/show.js.erb +17 -0
- data/app/views/foreman_patch/layouts/react.html.erb +17 -0
- data/app/views/foreman_patch/plans/_form.html.erb +12 -0
- data/app/views/foreman_patch/plans/edit.html.erb +6 -0
- data/app/views/foreman_patch/plans/index.html.erb +32 -0
- data/app/views/foreman_patch/plans/new.html.erb +3 -0
- data/app/views/foreman_patch/plans/show.html.erb +19 -0
- data/app/views/foreman_patch/rounds/show.html.erb +54 -0
- data/app/views/foreman_patch/ticket_fields/_fields.html.erb +66 -0
- data/app/views/foreman_patch/ticket_fields/edit.html.erb +6 -0
- data/app/views/foreman_patch/ticket_fields/index.html.erb +26 -0
- data/app/views/foreman_patch/ticket_fields/new.html.erb +6 -0
- data/app/views/foreman_patch/window_plans/_form.html.erb +11 -0
- data/app/views/foreman_patch/window_plans/_hidden_layout.html.erb +7 -0
- data/app/views/foreman_patch/window_plans/edit.html.erb +3 -0
- data/app/views/foreman_patch/window_plans/new.html.erb +3 -0
- data/app/views/foreman_patch/windows/_form.html.erb +21 -0
- data/app/views/foreman_patch/windows/_groups.html.erb +2 -0
- data/app/views/foreman_patch/windows/_rounds.html.erb +24 -0
- data/app/views/foreman_patch/windows/_schedule.html.erb +16 -0
- data/app/views/foreman_patch/windows/_ticket.html.erb +12 -0
- data/app/views/foreman_patch/windows/edit.html.erb +3 -0
- data/app/views/foreman_patch/windows/new.html.erb +3 -0
- data/app/views/foreman_patch/windows/show.html.erb +27 -0
- data/app/views/foreman_patch/windows/show.json.erb +4 -0
- data/app/views/hosts/select_multiple_patch_group.html.erb +12 -0
- data/app/views/overrides/patch_groups/_host_patch_group_select.html.erb +9 -0
- data/app/views/templates/ensure_services.erb +28 -0
- data/config/api_routes.rb +37 -0
- data/config/initializers/pagelets.rb +6 -0
- data/config/initializers/safemode_jail.rb +4 -0
- data/config/routes/mount_engine.rb +3 -0
- data/config/routes/overrides.rb +10 -0
- data/config/routes.rb +47 -0
- data/db/migrate/20210202161304_create_foreman_patch_plans.rb +32 -0
- data/db/migrate/20210202163323_create_foreman_patch_cycles.rb +38 -0
- data/db/migrate/20210202164301_create_foreman_patch_groups.rb +37 -0
- data/db/migrate/20210226134103_add_name_to_cycles.rb +31 -0
- data/db/migrate/20210226162824_rename_default_window.rb +5 -0
- data/db/migrate/20210302165058_add_task_to_window_groups.rb +7 -0
- data/db/migrate/20210304141111_create_invocation.rb +16 -0
- data/db/migrate/20210519163923_add_cycle_end_date.rb +29 -0
- data/db/migrate/20210525154113_expand_window_groups.rb +27 -0
- data/db/migrate/20210723160142_add_cycle_plan_task_group.rb +7 -0
- data/db/migrate/20210831160044_cycle_plan_start_correction.rb +5 -0
- data/db/migrate/20210907104645_rename_group_priority.rb +5 -0
- data/db/migrate/20210909130118_remove_old_references.rb +14 -0
- data/db/migrate/20210910141428_rename_round.rb +7 -0
- data/db/migrate/20210910163542_rename_plan.rb +8 -0
- data/db/migrate/20211014212415_round_group_reference.rb +9 -0
- data/db/migrate/20220105224803_add_group_label.rb +25 -0
- data/db/migrate/20220114153808_plan_add_name_generator.rb +5 -0
- data/db/migrate/20220117103808_remove_cycle_description.rb +5 -0
- data/db/migrate/20220406110705_add_window_state.rb +37 -0
- data/db/migrate/20220407161120_add_round_status.rb +9 -0
- data/db/migrate/20220902134800_add_invocation_status.rb +28 -0
- data/db/seeds.d/100-assign_features_with_templates.rb +16 -0
- data/db/seeds.d/160-mail_notifications.rb +38 -0
- data/db/seeds.d/75-job_templates.rb +16 -0
- data/lib/foreman_patch/engine.rb +87 -0
- data/lib/foreman_patch/plugin.rb +47 -0
- data/lib/foreman_patch/version.rb +3 -0
- data/lib/foreman_patch.rb +4 -0
- data/lib/tasks/foreman_patch_tasks.rake +47 -0
- data/locale/Makefile +60 -0
- data/locale/en/foreman_patch.po +19 -0
- data/locale/foreman_patch.pot +19 -0
- data/locale/gemspec.rb +2 -0
- data/package.json +35 -0
- data/public/assets/foreman_patch/cycle_plans-e5667e178ba389908f5c815b24ec0ea77c340849d56bc39c5ce72bb626bd446a.scss +6 -0
- data/public/assets/foreman_patch/cycle_plans-e5667e178ba389908f5c815b24ec0ea77c340849d56bc39c5ce72bb626bd446a.scss.gz +0 -0
- data/public/assets/foreman_patch/foreman_patch-ce5805a60c0d5f896f557ff5246e5a09172043004c850b39bea54e618df1c485.css +1 -0
- data/public/assets/foreman_patch/foreman_patch-ce5805a60c0d5f896f557ff5246e5a09172043004c850b39bea54e618df1c485.css.gz +0 -0
- data/public/assets/foreman_patch/foreman_patch.json +1 -0
- data/public/assets/foreman_patch/plan_edit_windows-e656ba411642a7f983b51958ab30ac49c056322d19295a603cff4d5e6c71c8ed.js +1 -0
- data/public/assets/foreman_patch/plan_edit_windows-e656ba411642a7f983b51958ab30ac49c056322d19295a603cff4d5e6c71c8ed.js.gz +0 -0
- data/public/webpack/foreman_patch/bundle-200e97f4e2ad9ed413ea.css +1 -0
- data/public/webpack/foreman_patch/bundle-200e97f4e2ad9ed413ea.css.gz +0 -0
- data/public/webpack/foreman_patch/bundle-200e97f4e2ad9ed413ea.js +6 -0
- data/public/webpack/foreman_patch/bundle-200e97f4e2ad9ed413ea.js.gz +0 -0
- data/public/webpack/foreman_patch/bundle-200e97f4e2ad9ed413ea.js.map +1 -0
- data/public/webpack/foreman_patch/bundle-200e97f4e2ad9ed413ea.js.map.gz +0 -0
- data/public/webpack/foreman_patch/foreman_patch-1e4f2d5e6f040a27aa7a.css +1 -0
- data/public/webpack/foreman_patch/foreman_patch-1e4f2d5e6f040a27aa7a.css.gz +0 -0
- data/public/webpack/foreman_patch/foreman_patch-1e4f2d5e6f040a27aa7a.js +6 -0
- data/public/webpack/foreman_patch/foreman_patch-1e4f2d5e6f040a27aa7a.js.gz +0 -0
- data/public/webpack/foreman_patch/foreman_patch-1e4f2d5e6f040a27aa7a.js.map +1 -0
- data/public/webpack/foreman_patch/foreman_patch-1e4f2d5e6f040a27aa7a.js.map.gz +0 -0
- data/public/webpack/foreman_patch/manifest.json +26 -0
- data/public/webpack/foreman_patch/manifest.json.gz +0 -0
- data/public/webpack/foreman_patch/vendor-4b77c91f1e9103179596.js +2 -0
- data/public/webpack/foreman_patch/vendor-4b77c91f1e9103179596.js.gz +0 -0
- data/public/webpack/foreman_patch/vendor-4b77c91f1e9103179596.js.map +1 -0
- data/public/webpack/foreman_patch/vendor-4b77c91f1e9103179596.js.map.gz +0 -0
- data/test/factories/foreman_patch_factories.rb +5 -0
- data/test/test_plugin_helper.rb +6 -0
- data/test/unit/foreman_patch_test.rb +11 -0
- data/webpack/components/Cycle/Cycle.js +57 -0
- data/webpack/components/Cycle/CycleActions.js +21 -0
- data/webpack/components/Cycle/CycleConstants.js +2 -0
- data/webpack/components/Cycle/CycleHelpers.js +3 -0
- data/webpack/components/Cycle/CycleSelectors.js +10 -0
- data/webpack/components/Cycle/Window.js +32 -0
- data/webpack/components/Cycle/index.js +41 -0
- data/webpack/components/Groups/Group.js +20 -0
- data/webpack/components/Groups/Groups.js +46 -0
- data/webpack/components/Groups/GroupsHelpers.js +11 -0
- data/webpack/components/Groups/Priority.js +51 -0
- data/webpack/components/Invocation/Invocation.js +47 -0
- data/webpack/components/Invocation/InvocationActions.js +8 -0
- data/webpack/components/Invocation/InvocationConsts.js +1 -0
- data/webpack/components/Invocation/InvocationSelectors.js +14 -0
- data/webpack/components/Invocation/index.js +36 -0
- data/webpack/components/Invocations/Invocations.js +55 -0
- data/webpack/components/Invocations/InvocationsConstants.js +1 -0
- data/webpack/components/Invocations/InvocationsHelpers.js +11 -0
- data/webpack/components/Invocations/InvocationsPage.js +66 -0
- data/webpack/components/Invocations/InvocationsPage.scss +3 -0
- data/webpack/components/Invocations/InvocationsSelectors.js +21 -0
- data/webpack/components/Invocations/components/InvocationItem.js +66 -0
- data/webpack/components/Invocations/components/InvocationStatus.js +51 -0
- data/webpack/components/Invocations/index.js +99 -0
- data/webpack/components/Plan/Plan.js +90 -0
- data/webpack/components/Plan/PlanActions.js +12 -0
- data/webpack/components/Plan/PlanConstants.js +1 -0
- data/webpack/components/Plan/PlanSelectors.js +9 -0
- data/webpack/components/Plan/Window.js +33 -0
- data/webpack/components/Plan/index.js +36 -0
- data/webpack/components/PlanWindow/PlanWindow.js +55 -0
- data/webpack/components/PlanWindow/index.js +32 -0
- data/webpack/components/RoundProgress/AggregateStatus.js +58 -0
- data/webpack/components/RoundProgress/RoundProgress.js +48 -0
- data/webpack/components/RoundProgress/RoundProgressActions.js +9 -0
- data/webpack/components/RoundProgress/RoundProgressConstants.js +1 -0
- data/webpack/components/RoundProgress/RoundProgressSelectors.js +24 -0
- data/webpack/components/RoundProgress/index.js +44 -0
- data/webpack/components/Rounds/Rounds.js +57 -0
- data/webpack/components/Rounds/RoundsActions.js +8 -0
- data/webpack/components/Rounds/RoundsConsts.js +1 -0
- data/webpack/components/Rounds/RoundsSelectors.js +14 -0
- data/webpack/components/Rounds/components/RoundItem.js +52 -0
- data/webpack/components/Rounds/components/RoundStatus.js +40 -0
- data/webpack/components/Rounds/index.js +37 -0
- data/webpack/components/common/Calendar/Calendar.js +86 -0
- data/webpack/components/common/Calendar/Calendar.scss +76 -0
- data/webpack/components/common/Calendar/CalendarConstants.js +1 -0
- data/webpack/components/common/Calendar/CalendarHelpers.js +77 -0
- data/webpack/components/common/Calendar/Day/index.js +9 -0
- data/webpack/components/common/Calendar/Event.js +25 -0
- data/webpack/components/common/Calendar/Month/Day.js +51 -0
- data/webpack/components/common/Calendar/Month/Header.js +77 -0
- data/webpack/components/common/Calendar/Month/Month.js +47 -0
- data/webpack/components/common/Calendar/Month/index.js +1 -0
- data/webpack/components/common/Calendar/View.js +20 -0
- data/webpack/components/common/Calendar/Week/index.js +13 -0
- data/webpack/components/common/Calendar/index.js +2 -0
- data/webpack/components/common/Terminal/OutputLine.js +26 -0
- data/webpack/components/common/Terminal/Terminal.js +115 -0
- data/webpack/components/common/Terminal/Terminal.scss +47 -0
- data/webpack/index.js +20 -0
- metadata +438 -0
@@ -0,0 +1,92 @@
|
|
1
|
+
module ForemanPatch
|
2
|
+
module Ticket
|
3
|
+
class ChangeRequest
|
4
|
+
include API
|
5
|
+
|
6
|
+
attr_reader :window, :response, :affected_items
|
7
|
+
|
8
|
+
def self.publish(window)
|
9
|
+
ticket = Ticket.new(window)
|
10
|
+
ticket.save
|
11
|
+
end
|
12
|
+
|
13
|
+
def initialize(window)
|
14
|
+
@window = window
|
15
|
+
@hash = {}
|
16
|
+
reload
|
17
|
+
end
|
18
|
+
|
19
|
+
def reload
|
20
|
+
return if window.ticket_id.blank?
|
21
|
+
|
22
|
+
get(path)
|
23
|
+
|
24
|
+
@affected_items = AffectedItems.new(self)
|
25
|
+
|
26
|
+
ticket
|
27
|
+
end
|
28
|
+
|
29
|
+
def save
|
30
|
+
if window.ticket_id.blank?
|
31
|
+
post(path, payload)
|
32
|
+
else
|
33
|
+
put(path, payload)
|
34
|
+
end
|
35
|
+
|
36
|
+
unless response.empty?
|
37
|
+
@affected_items = AffectedItems.new(self)
|
38
|
+
@affected_items.set(window.hosts)
|
39
|
+
end
|
40
|
+
|
41
|
+
window.update(ticket_id: id)
|
42
|
+
|
43
|
+
ticket
|
44
|
+
end
|
45
|
+
|
46
|
+
def payload
|
47
|
+
@payload ||= Payload.new(window)
|
48
|
+
end
|
49
|
+
|
50
|
+
def id
|
51
|
+
ticket.fetch(Setting[:ticket_id_field], window.ticket_id)
|
52
|
+
end
|
53
|
+
|
54
|
+
def label
|
55
|
+
ticket.fetch(Setting[:ticket_label_field], window.name)
|
56
|
+
end
|
57
|
+
|
58
|
+
def link
|
59
|
+
return "#" if id.blank?
|
60
|
+
|
61
|
+
Setting[:ticket_api_host] + Setting[:ticket_web_ui_path].gsub(':id', id)
|
62
|
+
end
|
63
|
+
|
64
|
+
def keys
|
65
|
+
ticket.keys
|
66
|
+
end
|
67
|
+
|
68
|
+
def [](key)
|
69
|
+
ticket[key]
|
70
|
+
end
|
71
|
+
|
72
|
+
class Jail < Safemode::Jail
|
73
|
+
allow :[], :keys, :link, :label
|
74
|
+
end
|
75
|
+
|
76
|
+
private
|
77
|
+
|
78
|
+
def ticket
|
79
|
+
return {} if response.empty?
|
80
|
+
|
81
|
+
response['result']
|
82
|
+
end
|
83
|
+
|
84
|
+
def path
|
85
|
+
path = Setting[:ticket_api_path]
|
86
|
+
path += "/#{window.ticket_id}" unless id.blank?
|
87
|
+
path
|
88
|
+
end
|
89
|
+
|
90
|
+
end
|
91
|
+
end
|
92
|
+
end
|
@@ -0,0 +1,21 @@
|
|
1
|
+
module ForemanPatch
|
2
|
+
module Ticket
|
3
|
+
class FieldRender < ParameterSafeRender
|
4
|
+
def initialize(window)
|
5
|
+
@window = window
|
6
|
+
end
|
7
|
+
|
8
|
+
private
|
9
|
+
|
10
|
+
attr_reader :window
|
11
|
+
|
12
|
+
def render_string(string)
|
13
|
+
return string unless string.contains_erb?
|
14
|
+
|
15
|
+
source = Foreman::Renderer::Source::String.new(content: string)
|
16
|
+
scope = Foreman::Renderer::get_scope(klass: Foreman::Renderer::Scope::Partition, variables: { window: window })
|
17
|
+
Foreman::Renderer.render(source, scope)
|
18
|
+
end
|
19
|
+
end
|
20
|
+
end
|
21
|
+
end
|
@@ -0,0 +1,136 @@
|
|
1
|
+
module ForemanPatch
|
2
|
+
module Ticket
|
3
|
+
class Payload
|
4
|
+
|
5
|
+
attr_reader :window, :raw
|
6
|
+
|
7
|
+
def initialize(window)
|
8
|
+
@window = window
|
9
|
+
|
10
|
+
@safe_render = FieldRender.new(window)
|
11
|
+
|
12
|
+
@raw = {}
|
13
|
+
TicketField.all.each do |key|
|
14
|
+
@raw.update(key.key => calculate_value(key))
|
15
|
+
end
|
16
|
+
|
17
|
+
end
|
18
|
+
|
19
|
+
def keys
|
20
|
+
TicketField.all.pluck(:key)
|
21
|
+
end
|
22
|
+
|
23
|
+
def [](key)
|
24
|
+
@raw[key]
|
25
|
+
end
|
26
|
+
|
27
|
+
def to_json(*args)
|
28
|
+
@raw.compact.to_json(*args)
|
29
|
+
end
|
30
|
+
|
31
|
+
private
|
32
|
+
|
33
|
+
def field(key)
|
34
|
+
TicketField.find_by(key: key)
|
35
|
+
end
|
36
|
+
|
37
|
+
def calculate_value(key)
|
38
|
+
value = nil
|
39
|
+
|
40
|
+
if key.merge_overrides
|
41
|
+
value = merged_value(key)
|
42
|
+
else
|
43
|
+
value = unmerged_value(key)
|
44
|
+
end
|
45
|
+
|
46
|
+
unless value.nil?
|
47
|
+
needs_late_validation = value.contains_erb?
|
48
|
+
value = @safe_render.render(value)
|
49
|
+
value = type_cast(key, value)
|
50
|
+
validate(key, value) if needs_late_validation
|
51
|
+
end
|
52
|
+
|
53
|
+
value
|
54
|
+
end
|
55
|
+
|
56
|
+
def merged_value(key)
|
57
|
+
case key.key_type
|
58
|
+
when 'array'
|
59
|
+
merged_array(key)
|
60
|
+
when 'hash','yaml','json'
|
61
|
+
merged_hash(key)
|
62
|
+
else
|
63
|
+
raise "merging enabled for non-mergable key #{key.key}"
|
64
|
+
end
|
65
|
+
end
|
66
|
+
|
67
|
+
def merged_array(key)
|
68
|
+
values = default_value(key, [])
|
69
|
+
|
70
|
+
lookup_values(key).each do |lookup_value|
|
71
|
+
next if lookup_value.omit
|
72
|
+
|
73
|
+
if key.avoid_duplicates
|
74
|
+
values |= lookup_value.value
|
75
|
+
else
|
76
|
+
values += lookup_value.value
|
77
|
+
end
|
78
|
+
end
|
79
|
+
|
80
|
+
values
|
81
|
+
end
|
82
|
+
|
83
|
+
def merged_hash
|
84
|
+
values = default_value(key, {})
|
85
|
+
|
86
|
+
lookup_values(key).reverse_each do |lookup_value|
|
87
|
+
next if lookup_value.omit
|
88
|
+
|
89
|
+
values.deep_merge!(lookup_value.value)
|
90
|
+
end
|
91
|
+
|
92
|
+
values
|
93
|
+
end
|
94
|
+
|
95
|
+
def unmerged_value(key)
|
96
|
+
lookup_value = lookup_values(key).first
|
97
|
+
|
98
|
+
return key.default_value if lookup_value.nil?
|
99
|
+
lookup_value.omit ? nil : lookup_value.value
|
100
|
+
end
|
101
|
+
|
102
|
+
def validate(key, value)
|
103
|
+
lookup_value = key.lookup_values.build(value: value)
|
104
|
+
return true if lookup_value.validate_value
|
105
|
+
raise "Invalid value '#{value}' of field #{key.id} '#{key.key}'"
|
106
|
+
end
|
107
|
+
|
108
|
+
def matches
|
109
|
+
@matches ||= TicketField.all.flat_map(&:path_elements).uniq.map do |rule|
|
110
|
+
Array.wrap(rule).map do |element|
|
111
|
+
"#{element}#{LookupKey::EQ_DELM}#{window.send(element)}"
|
112
|
+
end.join(LookupKey::KEY_DELM)
|
113
|
+
end
|
114
|
+
end
|
115
|
+
|
116
|
+
def lookup_values(key)
|
117
|
+
key.lookup_values.where(match: matches).sort_by do |lookup_value|
|
118
|
+
key.path.split.index(lookup_value.path)
|
119
|
+
end
|
120
|
+
end
|
121
|
+
|
122
|
+
def default_value(key, empty_value)
|
123
|
+
default = key.merge_default ? key.default_value : nil
|
124
|
+
|
125
|
+
default.nil? ? empty_value : default
|
126
|
+
end
|
127
|
+
|
128
|
+
def type_cast(key, value)
|
129
|
+
Foreman::Parameters::Caster.new(key, attribute_name: :default_value, to: key.key_type, value: value).cast
|
130
|
+
rescue TypeError
|
131
|
+
Rails.logger.warn "Unable to type cast #{value} to #{key.key_type}"
|
132
|
+
end
|
133
|
+
|
134
|
+
end
|
135
|
+
end
|
136
|
+
end
|
@@ -0,0 +1,14 @@
|
|
1
|
+
object @group if @group
|
2
|
+
|
3
|
+
extends 'foreman_patch/api/v2/groups/base'
|
4
|
+
|
5
|
+
child default_window_plan: :default_window_plan do
|
6
|
+
extends 'foreman_patch/api/v2/window_plans/base'
|
7
|
+
end
|
8
|
+
|
9
|
+
child template: :template do
|
10
|
+
extends 'api/v2/job_templates/base'
|
11
|
+
end
|
12
|
+
|
13
|
+
attributes :created_at, :updated_at
|
14
|
+
|
@@ -0,0 +1,17 @@
|
|
1
|
+
object @round
|
2
|
+
|
3
|
+
extends 'foreman_patch/api/v2/rounds/base'
|
4
|
+
|
5
|
+
child :window do
|
6
|
+
extends 'foreman_patch/api/v2/windows/base'
|
7
|
+
end
|
8
|
+
|
9
|
+
child :group do
|
10
|
+
extends 'foreman_patch/api/v2/groups/base'
|
11
|
+
end
|
12
|
+
|
13
|
+
child invocations: :invocations do
|
14
|
+
extends 'foreman_patch/api/v2/invocations/base'
|
15
|
+
end
|
16
|
+
|
17
|
+
attributes :created_at, :updated_at
|
@@ -0,0 +1,14 @@
|
|
1
|
+
object @window_plan if @window_plan
|
2
|
+
|
3
|
+
extends 'foreman_patch/api/v2/window_plans/base'
|
4
|
+
|
5
|
+
child plan: :plan do
|
6
|
+
attributes :id, :name
|
7
|
+
end
|
8
|
+
|
9
|
+
child groups: :groups do
|
10
|
+
extends 'foreman_patch/api/v2/groups/base'
|
11
|
+
end
|
12
|
+
|
13
|
+
attributes :created_at, :updated_at
|
14
|
+
|
@@ -0,0 +1,13 @@
|
|
1
|
+
object @window
|
2
|
+
|
3
|
+
extends 'foreman_patch/api/v2/windows/base'
|
4
|
+
|
5
|
+
child :cycle do
|
6
|
+
extends 'foreman_patch/api/v2/cycles/base'
|
7
|
+
end
|
8
|
+
|
9
|
+
child :window_plan do
|
10
|
+
extends 'foreman_patch/api/v2/window_plans/base'
|
11
|
+
end
|
12
|
+
|
13
|
+
attributes :created_at, :updated_at
|
@@ -0,0 +1,13 @@
|
|
1
|
+
object @window
|
2
|
+
|
3
|
+
extends 'foreman_patch/api/v2/windows/base'
|
4
|
+
|
5
|
+
child :cycle do
|
6
|
+
extends 'foreman_patch/api/v2/cycles/base'
|
7
|
+
end
|
8
|
+
|
9
|
+
child :window_plan do
|
10
|
+
extends 'foreman_patch/api/v2/window_plans/base'
|
11
|
+
end
|
12
|
+
|
13
|
+
attributes :created_at, :updated_at
|
@@ -0,0 +1,7 @@
|
|
1
|
+
<h2 class="headline"><%= (_('<b>%{cycle}</b> planned starting %{start_date}') % {cycle: @cycle.name, start_date: @cycle.start_date}).html_safe %></h2>
|
2
|
+
<div class="dashboard">
|
3
|
+
<%= render partial: 'summary', locals: { windows: @cycle.windows } %>
|
4
|
+
</div>
|
5
|
+
<div class="hosts">
|
6
|
+
<%= render partial: 'details', locals: { windows: @cycle.windows } %>
|
7
|
+
</div>
|
@@ -0,0 +1,9 @@
|
|
1
|
+
<%= form_for @group, as: :group do |f| %>
|
2
|
+
<%= base_errors_for @group %>
|
3
|
+
<%= text_f f, :name %>
|
4
|
+
<%= textarea_f f, :description %>
|
5
|
+
<%= selectable_f f, :default_window_plan_id, ForemanPatch::WindowPlan.all.collect { |c| [c.name, c.id] }, { include_blank: true }, { label: _('Default Window Plan'), required: false } %>
|
6
|
+
<%= text_f f, :max_unavailable %>
|
7
|
+
|
8
|
+
<%= submit_or_cancel f, false, {cancel_path: groups_path} %>
|
9
|
+
<% end %>
|
@@ -0,0 +1,41 @@
|
|
1
|
+
<% title @cycle.name %>
|
2
|
+
|
3
|
+
<% title_actions link_to(_('Create Window'), hash_for_new_cycle_window_path(cycle_id: @cycle.id),
|
4
|
+
class: 'btn btn-default',
|
5
|
+
disabled: @cycle.end_date.past?,
|
6
|
+
title: _('Create a new window for this cycle'))
|
7
|
+
%>
|
8
|
+
|
9
|
+
<div class="hosts">
|
10
|
+
<table class="table table-bordered table-fixed">
|
11
|
+
<thead>
|
12
|
+
<tr>
|
13
|
+
<th><%= _('Sunday') %></th>
|
14
|
+
<th><%= _('Monday') %></th>
|
15
|
+
<th><%= _('Tuesday') %></th>
|
16
|
+
<th><%= _('Wednesday') %></th>
|
17
|
+
<th><%= _('Thursday') %></th>
|
18
|
+
<th><%= _('Friday') %></th>
|
19
|
+
<th><%= _('Saturday') %></th>
|
20
|
+
</tr>
|
21
|
+
</thead>
|
22
|
+
<tbody>
|
23
|
+
<% start = @cycle.start_date.beginning_of_week - 1 %>
|
24
|
+
<% stop = @cycle.end_date.end_of_week - 1 %>
|
25
|
+
<% (start..stop).each_slice(7) do |week| %>
|
26
|
+
<tr>
|
27
|
+
<% week.each do |day| %>
|
28
|
+
<td class="day <%= ((@cycle.start_date..@cycle.end_date).include? day) ? '' : 'disabled' %>">
|
29
|
+
<div><%= (day.day == 1 or day == start) ? day.strftime('%b') : '' %> <%= day.day %></div>
|
30
|
+
<% cycle_windows(@cycle, day).each do |window| %>
|
31
|
+
<div class="event ellipsis"><%= link_to("#{window.start_at.strftime('%l:%M %p') window.name}", edit_window_path(window)) %></div>
|
32
|
+
<% end %>
|
33
|
+
</td>
|
34
|
+
<% end %>
|
35
|
+
</tr>
|
36
|
+
<% end %>
|
37
|
+
</tbody>
|
38
|
+
</table>
|
39
|
+
</div>
|
40
|
+
|
41
|
+
|