foreman_rh_cloud 0.9.9 → 0.9.13.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +33 -0
- data/app/controllers/foreman_inventory_upload/accounts_controller.rb +3 -0
- data/app/controllers/foreman_inventory_upload/tasks_controller.rb +25 -0
- data/app/controllers/foreman_inventory_upload/uploads_controller.rb +18 -0
- data/app/controllers/insights_cloud/hits_controller.rb +17 -0
- data/app/controllers/insights_cloud/settings_controller.rb +24 -0
- data/app/controllers/insights_cloud/tasks_controller.rb +1 -2
- data/app/helpers/foreman_inventory_upload_host_helper.rb +10 -2
- data/app/models/concerns/rh_cloud_host.rb +15 -0
- data/app/models/insights_facet.rb +5 -1
- data/app/models/insights_hit.rb +1 -1
- data/app/models/inventory_sync/inventory_status.rb +30 -0
- data/app/models/setting/rh_cloud.rb +3 -0
- data/app/overrides/hosts_list.rb +1 -1
- data/app/services/foreman_rh_cloud/cloud_auth.rb +28 -0
- data/app/views/foreman_rh_cloud/react/inventory_upload.html.erb +1 -1
- data/app/views/hosts/_insights_tab.html.erb +15 -0
- data/config/routes.rb +6 -0
- data/db/migrate/20200727111529_add_uuid_column_to_insights_facets.foreman_rh_cloud.rb +5 -0
- data/db/migrate/20201007115752_add_hits_count_to_insights_facets_table.foreman_rh_cloud.rb +5 -0
- data/db/migrate/20201007121540_setup_hits_count_cache.foreman_rh_cloud.rb +10 -0
- data/lib/foreman_inventory_upload.rb +4 -0
- data/lib/foreman_inventory_upload/async/generate_report_job.rb +1 -1
- data/lib/foreman_inventory_upload/async/shell_process.rb +15 -9
- data/lib/foreman_inventory_upload/async/upload_report_job.rb +21 -9
- data/lib/foreman_inventory_upload/generators/fact_helpers.rb +36 -1
- data/lib/foreman_inventory_upload/generators/json_stream.rb +7 -2
- data/lib/foreman_inventory_upload/generators/metadata.rb +3 -0
- data/lib/foreman_inventory_upload/generators/queries.rb +4 -4
- data/lib/foreman_inventory_upload/generators/slice.rb +51 -27
- data/lib/foreman_rh_cloud.rb +67 -0
- data/lib/foreman_rh_cloud/engine.rb +20 -3
- data/lib/foreman_rh_cloud/version.rb +1 -1
- data/lib/insights_cloud.rb +8 -8
- data/lib/insights_cloud/async/insights_full_sync.rb +19 -31
- data/lib/insights_cloud/async/insights_scheduled_sync.rb +23 -0
- data/lib/inventory_sync/async/host_result.rb +50 -0
- data/lib/inventory_sync/async/inventory_full_sync.rb +80 -0
- data/lib/tasks/insights.rake +15 -0
- data/lib/tasks/rh_cloud_inventory.rake +37 -0
- data/package.json +3 -1
- data/test/controllers/insights_sync/settings_controller_test.rb +30 -0
- data/test/factories/insights_factories.rb +31 -0
- data/test/jobs/insights_full_sync_test.rb +4 -2
- data/test/jobs/inventory_full_sync_test.rb +91 -0
- data/test/jobs/upload_report_job_test.rb +34 -0
- data/test/unit/fact_helpers_test.rb +22 -0
- data/test/unit/insights_facet_test.rb +23 -0
- data/test/unit/metadata_generator_test.rb +2 -0
- data/test/unit/rh_cloud_http_proxy_test.rb +52 -0
- data/test/unit/slice_generator_test.rb +144 -8
- data/webpack/ForemanInventoryUpload/Components/AccountList/AccountList.fixtures.js +16 -1
- data/webpack/ForemanInventoryUpload/Components/AccountList/AccountListActions.js +22 -17
- data/webpack/ForemanInventoryUpload/Components/AccountList/AccountListReducer.js +18 -0
- data/webpack/ForemanInventoryUpload/Components/AccountList/AccountListSelectors.js +8 -0
- data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/AccountListActions.test.js +7 -0
- data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/AccountListReducer.test.js +12 -6
- data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/AccountListSelectors.test.js +9 -0
- data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/__snapshots__/AccountListActions.test.js.snap +20 -0
- data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/__snapshots__/AccountListReducer.test.js.snap +12 -0
- data/webpack/ForemanInventoryUpload/Components/AccountList/__tests__/__snapshots__/AccountListSelectors.test.js.snap +6 -0
- data/webpack/ForemanInventoryUpload/Components/AutoUploadSwitcher/AutoUploadSwitcher.fixtures.js +2 -0
- data/webpack/ForemanInventoryUpload/Components/AutoUploadSwitcher/AutoUploadSwitcherActions.js +10 -11
- data/webpack/ForemanInventoryUpload/Components/AutoUploadSwitcher/AutoUploadSwitcherConstants.js +0 -1
- data/webpack/ForemanInventoryUpload/Components/AutoUploadSwitcher/__tests__/AutoUploadSwitcherActions.test.js +12 -2
- data/webpack/ForemanInventoryUpload/Components/AutoUploadSwitcher/__tests__/__snapshots__/AutoUploadSwitcherActions.test.js.snap +17 -0
- data/webpack/ForemanInventoryUpload/Components/ExcludePackagesSwitcher/ExcludePackagesSwitcher.fixtures.js +1 -0
- data/webpack/ForemanInventoryUpload/Components/ExcludePackagesSwitcher/ExcludePackagesSwitcher.js +30 -0
- data/webpack/ForemanInventoryUpload/Components/ExcludePackagesSwitcher/ExcludePackagesSwitcherActions.js +29 -0
- data/webpack/ForemanInventoryUpload/Components/ExcludePackagesSwitcher/ExcludePackagesSwitcherConstants.js +1 -0
- data/webpack/ForemanInventoryUpload/Components/ExcludePackagesSwitcher/__tests__/ExcludePackagesSwitcher.test.js +13 -0
- data/webpack/ForemanInventoryUpload/Components/ExcludePackagesSwitcher/__tests__/ExcludePackagesSwitcherActions.test.js +21 -0
- data/webpack/ForemanInventoryUpload/Components/ExcludePackagesSwitcher/__tests__/__snapshots__/ExcludePackagesSwitcher.test.js.snap +38 -0
- data/webpack/ForemanInventoryUpload/Components/ExcludePackagesSwitcher/__tests__/__snapshots__/ExcludePackagesSwitcherActions.test.js.snap +31 -0
- data/webpack/ForemanInventoryUpload/Components/ExcludePackagesSwitcher/__tests__/__snapshots__/integration.test.js.snap +41 -0
- data/webpack/ForemanInventoryUpload/Components/ExcludePackagesSwitcher/__tests__/integration.test.js +38 -0
- data/webpack/ForemanInventoryUpload/Components/ExcludePackagesSwitcher/excludePackagesSwitcher.scss +3 -0
- data/webpack/ForemanInventoryUpload/Components/ExcludePackagesSwitcher/index.js +20 -0
- data/webpack/ForemanInventoryUpload/Components/FullScreenModal/FullScreenModal.js +5 -1
- data/webpack/ForemanInventoryUpload/Components/FullScreenModal/__tests__/__snapshots__/FullScreenModal.test.js.snap +1 -0
- data/webpack/ForemanInventoryUpload/Components/FullScreenModal/fullScreenModal.scss +15 -13
- data/webpack/ForemanInventoryUpload/Components/HostObfuscationSwitcher/HostObfuscationSwitcher.fixtures.js +2 -1
- data/webpack/ForemanInventoryUpload/Components/HostObfuscationSwitcher/HostObfuscationSwitcher.js +1 -0
- data/webpack/ForemanInventoryUpload/Components/HostObfuscationSwitcher/HostObfuscationSwitcher.scss +3 -0
- data/webpack/ForemanInventoryUpload/Components/HostObfuscationSwitcher/HostObfuscationSwitcherActions.js +10 -11
- data/webpack/ForemanInventoryUpload/Components/HostObfuscationSwitcher/HostObfuscationSwitcherConstants.js +0 -2
- data/webpack/ForemanInventoryUpload/Components/HostObfuscationSwitcher/__tests__/HostObfuscationSwitcherActions.test.js +12 -2
- data/webpack/ForemanInventoryUpload/Components/HostObfuscationSwitcher/__tests__/__snapshots__/HostObfuscationSwitcherActions.test.js.snap +18 -1
- data/webpack/ForemanInventoryUpload/Components/InventoryFilter/__tests__/__snapshots__/integration.test.js.snap +9 -0
- data/webpack/ForemanInventoryUpload/Components/InventorySettings/InventorySettings.js +4 -0
- data/webpack/ForemanInventoryUpload/Components/InventorySettings/__tests__/__snapshots__/InventorySettings.test.js.snap +2 -0
- data/webpack/ForemanInventoryUpload/Components/IpsObfuscationSwitcher/IpsObfuscationSwitcher.fixtures.js +1 -0
- data/webpack/ForemanInventoryUpload/Components/IpsObfuscationSwitcher/IpsObfuscationSwitcher.js +29 -0
- data/webpack/ForemanInventoryUpload/Components/IpsObfuscationSwitcher/IpsObfuscationSwitcherActions.js +29 -0
- data/webpack/ForemanInventoryUpload/Components/IpsObfuscationSwitcher/IpsObfuscationSwitcherConstants.js +1 -0
- data/webpack/ForemanInventoryUpload/Components/IpsObfuscationSwitcher/__tests__/IpsObfuscationSwitcher.test.js +13 -0
- data/webpack/ForemanInventoryUpload/Components/IpsObfuscationSwitcher/__tests__/IpsObfuscationSwitcherActions.test.js +21 -0
- data/webpack/ForemanInventoryUpload/Components/IpsObfuscationSwitcher/__tests__/__snapshots__/IpsObfuscationSwitcher.test.js.snap +38 -0
- data/webpack/ForemanInventoryUpload/Components/IpsObfuscationSwitcher/__tests__/__snapshots__/IpsObfuscationSwitcherActions.test.js.snap +31 -0
- data/webpack/ForemanInventoryUpload/Components/IpsObfuscationSwitcher/index.js +20 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/PageHeader.js +1 -1
- data/webpack/ForemanInventoryUpload/Components/PageHeader/__tests__/__snapshots__/PageHeader.test.js.snap +3 -3
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/DocsButton/DocsButton.js +1 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/DocsButton/__tests__/__snapshots__/DocsButton.test.js.snap +1 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/HistoryButton/HistoryButton.js +1 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/HistoryButton/__tests__/__snapshots__/HistoryButton.test.js.snap +1 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/SyncButton.js +58 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/SyncButtonActions.js +57 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/SyncButtonConstants.js +3 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/SyncButtonReducer.js +36 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/SyncButtonSelectors.js +13 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/__tests__/SyncButton.test.js +13 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/__tests__/SyncButtonActions.test.js +31 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/__tests__/SyncButtonFixtures.js +9 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/__tests__/SyncButtonReducer.test.js +26 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/__tests__/SyncButtonSelectors.test.js +36 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/__tests__/__snapshots__/SyncButton.test.js.snap +26 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/__tests__/__snapshots__/SyncButtonActions.test.js.snap +98 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/__tests__/__snapshots__/SyncButtonReducer.test.js.snap +18 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/__tests__/__snapshots__/SyncButtonSelectors.test.js.snap +18 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/components/Modal.js +63 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/components/Toast.js +41 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/components/modal.scss +20 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/index.js +22 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/ToolbarButtons/ToolbarButtons.js +2 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/ToolbarButtons/__tests__/__snapshots__/ToolbarButtons.test.js.snap +1 -0
- data/webpack/ForemanInventoryUpload/Components/PageHeader/components/ToolbarButtons/toolbarButtons.scss +6 -1
- data/webpack/ForemanInventoryUpload/Components/StatusChart/StatusChart.js +1 -1
- data/webpack/ForemanInventoryUpload/Components/StatusChart/__tests__/__snapshots__/StatusChart.test.js.snap +1 -1
- data/webpack/ForemanInventoryUpload/Components/TabContainer/tabContainer.scss +1 -1
- data/webpack/ForemanInventoryUpload/Components/TabHeader/TabHeader.js +6 -1
- data/webpack/ForemanInventoryUpload/Components/Terminal/Terminal.js +2 -4
- data/webpack/ForemanInventoryUpload/ForemanInventoryConstants.js +3 -1
- data/webpack/ForemanInventoryUpload/ForemanInventoryHelpers.js +8 -0
- data/webpack/ForemanInventoryUpload/ForemanInventoryUploadReducers.js +2 -0
- data/webpack/ForemanRhCloudPages.js +9 -0
- data/webpack/ForemanRhCloudReducers.js +2 -0
- data/webpack/ForemanRhCloudSelectors.js +5 -0
- data/webpack/ForemanRhCloudTestHelpers.js +17 -3
- data/webpack/InsightsCloudSync/Components/InsightsSettings/InsightsSettings.js +33 -0
- data/webpack/InsightsCloudSync/Components/InsightsSettings/InsightsSettingsActions.js +57 -0
- data/webpack/InsightsCloudSync/Components/InsightsSettings/InsightsSettingsConstants.js +4 -0
- data/webpack/InsightsCloudSync/Components/InsightsSettings/InsightsSettingsReducer.js +24 -0
- data/webpack/InsightsCloudSync/Components/InsightsSettings/InsightsSettingsSelectors.js +6 -0
- data/webpack/InsightsCloudSync/Components/InsightsSettings/__tests__/InsightsSettings.test.js +18 -0
- data/webpack/InsightsCloudSync/Components/InsightsSettings/__tests__/InsightsSettingsActions.test.js +62 -0
- data/webpack/InsightsCloudSync/Components/InsightsSettings/__tests__/InsightsSettingsReducer.test.js +33 -0
- data/webpack/InsightsCloudSync/Components/InsightsSettings/__tests__/InsightsSettingsSelectors.test.js +21 -0
- data/webpack/InsightsCloudSync/Components/InsightsSettings/__tests__/__snapshots__/InsightsSettings.test.js.snap +15 -0
- data/webpack/InsightsCloudSync/Components/InsightsSettings/__tests__/__snapshots__/InsightsSettingsActions.test.js.snap +65 -0
- data/webpack/InsightsCloudSync/Components/InsightsSettings/__tests__/__snapshots__/InsightsSettingsReducer.test.js.snap +19 -0
- data/webpack/InsightsCloudSync/Components/InsightsSettings/__tests__/__snapshots__/InsightsSettingsSelectors.test.js.snap +9 -0
- data/webpack/InsightsCloudSync/Components/InsightsSettings/index.js +21 -0
- data/webpack/InsightsCloudSync/Components/InsightsSettings/insightsSettings.scss +16 -0
- data/webpack/InsightsCloudSync/Components/InsightsSyncSwitcher/InsightsSyncSwitcher.fixtures.js +1 -0
- data/webpack/InsightsCloudSync/Components/InsightsSyncSwitcher/InsightsSyncSwitcher.js +45 -0
- data/webpack/InsightsCloudSync/Components/InsightsSyncSwitcher/__tests__/InsightsSyncSwitcher.test.js +17 -0
- data/webpack/InsightsCloudSync/Components/InsightsSyncSwitcher/__tests__/__snapshots__/InsightsSyncSwitcher.test.js.snap +38 -0
- data/webpack/InsightsCloudSync/Components/InsightsSyncSwitcher/index.js +1 -0
- data/webpack/InsightsCloudSync/Components/InsightsSyncSwitcher/insightsSyncSwitcher.scss +3 -0
- data/webpack/InsightsCloudSync/InsightsCloudSync.js +32 -28
- data/webpack/InsightsCloudSync/InsightsCloudSyncActions.js +10 -11
- data/webpack/InsightsCloudSync/InsightsCloudSyncConstants.js +0 -2
- data/webpack/InsightsCloudSync/InsightsCloudSyncReducers.js +7 -2
- data/webpack/InsightsCloudSync/__snapshots__/InsightsCloudSync.test.js.snap +49 -44
- data/webpack/InsightsCloudSync/index.js +2 -1
- data/webpack/InsightsHostDetailsTab/InsightsTab.js +64 -0
- data/webpack/InsightsHostDetailsTab/InsightsTab.scss +86 -0
- data/webpack/InsightsHostDetailsTab/InsightsTabActions.js +31 -0
- data/webpack/InsightsHostDetailsTab/InsightsTabConstants.js +2 -0
- data/webpack/InsightsHostDetailsTab/InsightsTabReducer.js +19 -0
- data/webpack/InsightsHostDetailsTab/InsightsTabSelectors.js +3 -0
- data/webpack/InsightsHostDetailsTab/__tests__/InsightsTab.fixtures.js +25 -0
- data/webpack/InsightsHostDetailsTab/__tests__/InsightsTab.test.js +13 -0
- data/webpack/InsightsHostDetailsTab/__tests__/InsightsTabActions.test.js +19 -0
- data/webpack/InsightsHostDetailsTab/__tests__/InsightsTabIntegration.test.js +17 -0
- data/webpack/InsightsHostDetailsTab/__tests__/InsightsTabReducer.test.js +26 -0
- data/webpack/InsightsHostDetailsTab/__tests__/InsightsTabSelectors.test.js +13 -0
- data/webpack/InsightsHostDetailsTab/__tests__/__snapshots__/InsightsTab.test.js.snap +30 -0
- data/webpack/InsightsHostDetailsTab/__tests__/__snapshots__/InsightsTabActions.test.js.snap +58 -0
- data/webpack/InsightsHostDetailsTab/__tests__/__snapshots__/InsightsTabReducer.test.js.snap +34 -0
- data/webpack/InsightsHostDetailsTab/__tests__/__snapshots__/InsightsTabSelectors.test.js.snap +20 -0
- data/webpack/InsightsHostDetailsTab/components/ListItem/ListItem.js +69 -0
- data/webpack/InsightsHostDetailsTab/components/ListItem/index.js +1 -0
- data/webpack/InsightsHostDetailsTab/index.js +20 -0
- data/webpack/__mocks__/foremanReact/constants.js +5 -0
- data/webpack/__mocks__/foremanReact/redux/actions/toasts.js +8 -0
- data/webpack/__tests__/ForemanRhCloudSelectors.test.js +4 -1
- data/webpack/__tests__/ForemanRhCloudTestHelpers.test.js +12 -2
- data/webpack/__tests__/__snapshots__/ForemanRhCloudSelectors.test.js.snap +10 -9
- data/webpack/__tests__/__snapshots__/ForemanRhCloudTestHelpers.test.js.snap +27 -2
- data/webpack/index.js +2 -12
- data/webpack/stories/decorators/withCardsDecorator.js +1 -1
- metadata +120 -12
- data/lib/tasks/generator.rake +0 -29
- data/webpack/ForemanInventoryUpload/Components/HostObfuscationSwitcher/hostObfuscationSwitcher.scss +0 -0
@@ -0,0 +1,18 @@
|
|
1
|
+
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
2
|
+
|
3
|
+
exports[`AccountList reducer should handle INVENTORY_SYNC_REQUEST 1`] = `
|
4
|
+
Object {
|
5
|
+
"error": null,
|
6
|
+
"status": "PENDING",
|
7
|
+
}
|
8
|
+
`;
|
9
|
+
|
10
|
+
exports[`AccountList reducer should handle INVENTORY_SYNC_SUCCESS 1`] = `
|
11
|
+
Object {
|
12
|
+
"disconnectHosts": 0,
|
13
|
+
"status": "RESOLVED",
|
14
|
+
"syncHosts": 1,
|
15
|
+
}
|
16
|
+
`;
|
17
|
+
|
18
|
+
exports[`AccountList reducer should return the initial state 1`] = `Object {}`;
|
@@ -0,0 +1,18 @@
|
|
1
|
+
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
2
|
+
|
3
|
+
exports[`SyncButton selectors should return InventorySync 1`] = `
|
4
|
+
Object {
|
5
|
+
"disconnectHosts": 0,
|
6
|
+
"error": "some-error",
|
7
|
+
"status": "RESOLVED",
|
8
|
+
"syncHosts": 1,
|
9
|
+
}
|
10
|
+
`;
|
11
|
+
|
12
|
+
exports[`SyncButton selectors should return InventorySync SyncHosts 1`] = `1`;
|
13
|
+
|
14
|
+
exports[`SyncButton selectors should return InventorySync disconnectHosts 1`] = `0`;
|
15
|
+
|
16
|
+
exports[`SyncButton selectors should return InventorySync error 1`] = `"some-error"`;
|
17
|
+
|
18
|
+
exports[`SyncButton selectors should return InventorySync status 1`] = `"RESOLVED"`;
|
data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/components/Modal.js
ADDED
@@ -0,0 +1,63 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import PropTypes from 'prop-types';
|
3
|
+
import { Icon, Modal, Grid, Button } from 'patternfly-react';
|
4
|
+
import { translate as __ } from 'foremanReact/common/I18n';
|
5
|
+
import { foremanUrl } from '../../../../../../ForemanRhCloudHelpers';
|
6
|
+
import './modal.scss';
|
7
|
+
|
8
|
+
const SyncModal = ({ show, toggleModal }) => (
|
9
|
+
<Modal show={show} onHide={toggleModal} id="sync_modal">
|
10
|
+
<Modal.Header>
|
11
|
+
<button
|
12
|
+
className="close"
|
13
|
+
onClick={toggleModal}
|
14
|
+
aria-hidden="true"
|
15
|
+
aria-label="Close"
|
16
|
+
>
|
17
|
+
<Icon type="pf" name="close" />
|
18
|
+
</button>
|
19
|
+
<Modal.Title>{__('Token is required')}</Modal.Title>
|
20
|
+
</Modal.Header>
|
21
|
+
<Modal.Body>
|
22
|
+
<Grid>
|
23
|
+
<p>
|
24
|
+
{__(`Please go over the following steps to add a RHSM API token:`)}
|
25
|
+
</p>
|
26
|
+
<p>
|
27
|
+
{__(`1. Obtain an RHSM API token: `)}
|
28
|
+
<a
|
29
|
+
href="https://access.redhat.com/management/api"
|
30
|
+
target="_blank"
|
31
|
+
rel="noopener noreferrer"
|
32
|
+
>
|
33
|
+
access.redhat.com <Icon name="external-link" />
|
34
|
+
</a>
|
35
|
+
<br />
|
36
|
+
{__("2. Copy the token to 'Red Hat Cloud token' setting: ")}
|
37
|
+
<a
|
38
|
+
href={foremanUrl('/settings?search=name+%3D+rh_cloud_token')}
|
39
|
+
target="_blank"
|
40
|
+
rel="noopener noreferrer"
|
41
|
+
>
|
42
|
+
{__('Red Hat Cloud token ')}
|
43
|
+
<Icon name="external-link" />
|
44
|
+
</a>
|
45
|
+
<br />
|
46
|
+
{__(
|
47
|
+
'3. Now you can synchronize inventory status manually, by clicking the "Sync inventory status" button.'
|
48
|
+
)}
|
49
|
+
</p>
|
50
|
+
<Button bsStyle="primary" bsSize="lg" onClick={toggleModal}>
|
51
|
+
Close
|
52
|
+
</Button>
|
53
|
+
</Grid>
|
54
|
+
</Modal.Body>
|
55
|
+
</Modal>
|
56
|
+
);
|
57
|
+
|
58
|
+
SyncModal.propTypes = {
|
59
|
+
show: PropTypes.bool.isRequired,
|
60
|
+
toggleModal: PropTypes.func.isRequired,
|
61
|
+
};
|
62
|
+
|
63
|
+
export default SyncModal;
|
data/webpack/ForemanInventoryUpload/Components/PageHeader/components/SyncButton/components/Toast.js
ADDED
@@ -0,0 +1,41 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import PropTypes from 'prop-types';
|
3
|
+
import { translate as __ } from 'foremanReact/common/I18n';
|
4
|
+
import { foremanUrl } from '../../../../../../ForemanRhCloudHelpers';
|
5
|
+
|
6
|
+
const Toast = ({ syncHosts, disconnectHosts }) => {
|
7
|
+
const totalHosts = syncHosts + disconnectHosts;
|
8
|
+
return (
|
9
|
+
<span>
|
10
|
+
<p>
|
11
|
+
{__('Hosts with subscription in organization: ')}
|
12
|
+
<strong>{totalHosts}</strong>
|
13
|
+
</p>
|
14
|
+
<p>
|
15
|
+
{__('Successfully synced hosts: ')}
|
16
|
+
<strong>{syncHosts}</strong>
|
17
|
+
</p>
|
18
|
+
<p>
|
19
|
+
{__('Disconnected hosts: ')}
|
20
|
+
<strong>{disconnectHosts}</strong>
|
21
|
+
</p>
|
22
|
+
<p>
|
23
|
+
For more info, please visit the{' '}
|
24
|
+
<a
|
25
|
+
href={foremanUrl('/hosts')}
|
26
|
+
target="_blank"
|
27
|
+
rel="noopener noreferrer"
|
28
|
+
>
|
29
|
+
hosts page
|
30
|
+
</a>
|
31
|
+
</p>
|
32
|
+
</span>
|
33
|
+
);
|
34
|
+
};
|
35
|
+
|
36
|
+
Toast.propTypes = {
|
37
|
+
syncHosts: PropTypes.number.isRequired,
|
38
|
+
disconnectHosts: PropTypes.number.isRequired,
|
39
|
+
};
|
40
|
+
|
41
|
+
export default Toast;
|
@@ -0,0 +1,22 @@
|
|
1
|
+
import { bindActionCreators } from 'redux';
|
2
|
+
import { connect } from 'react-redux';
|
3
|
+
|
4
|
+
import * as actions from './SyncButtonActions';
|
5
|
+
import reducer from './SyncButtonReducer';
|
6
|
+
import SyncButton from './SyncButton';
|
7
|
+
import { selectCloudToken } from '../../../AccountList/AccountListSelectors';
|
8
|
+
import { selectStatus } from './SyncButtonSelectors';
|
9
|
+
|
10
|
+
// map state to props
|
11
|
+
const mapStateToProps = state => ({
|
12
|
+
cloudToken: selectCloudToken(state),
|
13
|
+
status: selectStatus(state),
|
14
|
+
});
|
15
|
+
|
16
|
+
// map action dispatchers to props
|
17
|
+
const mapDispatchToProps = dispatch => bindActionCreators(actions, dispatch);
|
18
|
+
|
19
|
+
export const reducers = { inventorySync: reducer };
|
20
|
+
|
21
|
+
// export connected component
|
22
|
+
export default connect(mapStateToProps, mapDispatchToProps)(SyncButton);
|
@@ -1,10 +1,12 @@
|
|
1
1
|
import React from 'react';
|
2
2
|
import DocsButton from '../DocsButton';
|
3
3
|
import HistoryButton from '../HistoryButton';
|
4
|
+
import SyncButton from '../SyncButton';
|
4
5
|
import './toolbarButtons.scss';
|
5
6
|
|
6
7
|
const ToolbarButtons = () => (
|
7
8
|
<div className="inventory_toolbar_buttons">
|
9
|
+
<SyncButton />
|
8
10
|
<HistoryButton />
|
9
11
|
<DocsButton />
|
10
12
|
</div>
|
@@ -2,6 +2,7 @@ import React from 'react';
|
|
2
2
|
import PropTypes from 'prop-types';
|
3
3
|
import { noop, Grid, Button, Icon } from 'patternfly-react';
|
4
4
|
import { sprintf, translate as __ } from 'foremanReact/common/I18n';
|
5
|
+
import { isExitCodeLoading } from '../../ForemanInventoryHelpers';
|
5
6
|
import './tabHeader.scss';
|
6
7
|
|
7
8
|
const TabHeader = ({ exitCode, onRestart, onDownload, toggleFullScreen }) => (
|
@@ -12,7 +13,11 @@ const TabHeader = ({ exitCode, onRestart, onDownload, toggleFullScreen }) => (
|
|
12
13
|
<Grid.Col sm={6}>
|
13
14
|
<div className="tab-action-buttons">
|
14
15
|
{onRestart ? (
|
15
|
-
<Button
|
16
|
+
<Button
|
17
|
+
bsStyle="primary"
|
18
|
+
onClick={onRestart}
|
19
|
+
disabled={isExitCodeLoading(exitCode)}
|
20
|
+
>
|
16
21
|
{__('Restart')}
|
17
22
|
</Button>
|
18
23
|
) : null}
|
@@ -4,6 +4,7 @@ import { Grid, Spinner } from 'patternfly-react';
|
|
4
4
|
import isEqual from 'lodash/isEqual';
|
5
5
|
import './terminal.scss';
|
6
6
|
import { isTerminalScrolledDown } from './TerminalHelper';
|
7
|
+
import { isExitCodeLoading } from '../../ForemanInventoryHelpers';
|
7
8
|
|
8
9
|
class Terminal extends React.Component {
|
9
10
|
constructor(props) {
|
@@ -67,10 +68,7 @@ class Terminal extends React.Component {
|
|
67
68
|
} else {
|
68
69
|
modifiedLogs = <p>{logs}</p>;
|
69
70
|
}
|
70
|
-
const
|
71
|
-
const loading =
|
72
|
-
exitCodeLowerCase.indexOf('running') !== -1 ||
|
73
|
-
exitCodeLowerCase.indexOf('restarting') !== -1;
|
71
|
+
const loading = isExitCodeLoading(exitCode);
|
74
72
|
return (
|
75
73
|
<Grid.Col sm={12}>
|
76
74
|
<div
|
@@ -1,7 +1,9 @@
|
|
1
1
|
import { translate as __ } from 'foremanReact/common/I18n';
|
2
2
|
|
3
|
-
export const INVENTORY_PAGE_TITLE = __('Red Hat Inventory
|
3
|
+
export const INVENTORY_PAGE_TITLE = __('Red Hat Inventory');
|
4
4
|
|
5
5
|
export const DOCS_BUTTON_TEXT = __(' Documentation');
|
6
6
|
|
7
7
|
export const ACTIONS_HISTORY_BUTTON_TEXT = __(' Actions history');
|
8
|
+
|
9
|
+
export const SYNC_BUTTON_TEXT = __(' Sync inventory status');
|
@@ -10,3 +10,11 @@ export const getActionsHistoryUrl = () =>
|
|
10
10
|
foremanUrl(
|
11
11
|
'/foreman_tasks/tasks?search=action++%3D++ForemanInventoryUpload%3A%3AAsync%3A%3AGenerateReportJob+or+action++%3D++ForemanInventoryUpload%3A%3AAsync%3A%3AGenerateAllReportsJob&page=1'
|
12
12
|
);
|
13
|
+
|
14
|
+
export const isExitCodeLoading = exitCode => {
|
15
|
+
const exitCodeLC = exitCode.toLowerCase();
|
16
|
+
return (
|
17
|
+
exitCodeLC.indexOf('running') !== -1 ||
|
18
|
+
exitCodeLC.indexOf('restarting') !== -1
|
19
|
+
);
|
20
|
+
};
|
@@ -2,11 +2,13 @@ import { combineReducers } from 'redux';
|
|
2
2
|
import { reducers as accountListReducers } from './Components/AccountList';
|
3
3
|
import { reducers as dashboardReducers } from './Components/Dashboard';
|
4
4
|
import { reducers as filterReducers } from './Components/InventoryFilter';
|
5
|
+
import { reducers as inventorySyncReducers } from './Components/PageHeader/components/SyncButton';
|
5
6
|
|
6
7
|
export default {
|
7
8
|
inventoryUpload: combineReducers({
|
8
9
|
...accountListReducers,
|
9
10
|
...dashboardReducers,
|
10
11
|
...filterReducers,
|
12
|
+
...inventorySyncReducers,
|
11
13
|
}),
|
12
14
|
};
|
@@ -0,0 +1,9 @@
|
|
1
|
+
import ForemanInventoryUpload from './ForemanInventoryUpload';
|
2
|
+
import InsightsCloudSync from './InsightsCloudSync';
|
3
|
+
import InsightsHostDetailsTab from './InsightsHostDetailsTab';
|
4
|
+
|
5
|
+
export default [
|
6
|
+
{ name: 'ForemanInventoryUpload', type: ForemanInventoryUpload },
|
7
|
+
{ name: 'InsightsCloudSync', type: InsightsCloudSync },
|
8
|
+
{ name: 'InsightsHostDetailsTab', type: InsightsHostDetailsTab },
|
9
|
+
];
|
@@ -1,10 +1,12 @@
|
|
1
1
|
import { combineReducers } from 'redux';
|
2
2
|
import inventoryUploadReducers from './ForemanInventoryUpload/ForemanInventoryUploadReducers';
|
3
3
|
import insightsReducers from './InsightsCloudSync/InsightsCloudSyncReducers';
|
4
|
+
import { hostInsightsReducers } from './InsightsHostDetailsTab';
|
4
5
|
|
5
6
|
export default {
|
6
7
|
ForemanRhCloud: combineReducers({
|
7
8
|
...inventoryUploadReducers,
|
8
9
|
...insightsReducers,
|
10
|
+
...hostInsightsReducers,
|
9
11
|
}),
|
10
12
|
};
|
@@ -1,5 +1,10 @@
|
|
1
1
|
export const selectForemanRhCloud = state => state.ForemanRhCloud;
|
2
|
+
|
2
3
|
export const selectForemanInventoryUpload = state =>
|
3
4
|
selectForemanRhCloud(state).inventoryUpload;
|
5
|
+
|
4
6
|
export const selectInsightsCloudSync = state =>
|
5
7
|
selectForemanRhCloud(state).InsightsCloudSync;
|
8
|
+
|
9
|
+
export const selectHostInsights = state =>
|
10
|
+
selectForemanRhCloud(state).hostInsights;
|
@@ -1,6 +1,20 @@
|
|
1
|
-
export const rhCloudStateWrapper =
|
1
|
+
export const rhCloudStateWrapper = (
|
2
|
+
inventoryState = {},
|
3
|
+
insightsState = {},
|
4
|
+
hostInsightsState = {}
|
5
|
+
) => ({
|
2
6
|
ForemanRhCloud: {
|
3
|
-
inventoryUpload: { ...
|
4
|
-
InsightsCloudSync: { ...
|
7
|
+
inventoryUpload: { ...inventoryState },
|
8
|
+
InsightsCloudSync: { ...insightsState },
|
9
|
+
hostInsights: { ...hostInsightsState },
|
5
10
|
},
|
6
11
|
});
|
12
|
+
|
13
|
+
export const inventoryStateWrapper = innerState =>
|
14
|
+
rhCloudStateWrapper(innerState);
|
15
|
+
|
16
|
+
export const insightsStateWrapper = innerState =>
|
17
|
+
rhCloudStateWrapper({}, innerState);
|
18
|
+
|
19
|
+
export const hostInsightsStateWrapper = innerState =>
|
20
|
+
rhCloudStateWrapper({}, {}, innerState);
|
@@ -0,0 +1,33 @@
|
|
1
|
+
import React, { Component } from 'react';
|
2
|
+
import PropTypes from 'prop-types';
|
3
|
+
import { translate as __ } from 'foremanReact/common/I18n';
|
4
|
+
import InsightsSyncSwitcher from '../InsightsSyncSwitcher';
|
5
|
+
import './insightsSettings.scss';
|
6
|
+
|
7
|
+
class InsightsSettings extends Component {
|
8
|
+
componentDidMount() {
|
9
|
+
const { getInsightsSyncSettings } = this.props;
|
10
|
+
getInsightsSyncSettings();
|
11
|
+
}
|
12
|
+
|
13
|
+
render() {
|
14
|
+
const { insightsSyncEnabled, setInsightsSyncEnabled } = this.props;
|
15
|
+
return (
|
16
|
+
<div className="insights_settings">
|
17
|
+
<h3>{__('Settings')}</h3>
|
18
|
+
<InsightsSyncSwitcher
|
19
|
+
insightsSyncEnabled={insightsSyncEnabled}
|
20
|
+
setInsightsSyncEnabled={setInsightsSyncEnabled}
|
21
|
+
/>
|
22
|
+
</div>
|
23
|
+
);
|
24
|
+
}
|
25
|
+
}
|
26
|
+
|
27
|
+
InsightsSettings.propTypes = {
|
28
|
+
insightsSyncEnabled: PropTypes.bool.isRequired,
|
29
|
+
getInsightsSyncSettings: PropTypes.func.isRequired,
|
30
|
+
setInsightsSyncEnabled: PropTypes.func.isRequired,
|
31
|
+
};
|
32
|
+
|
33
|
+
export default InsightsSettings;
|
@@ -0,0 +1,57 @@
|
|
1
|
+
import API from 'foremanReact/API';
|
2
|
+
import { addToast } from 'foremanReact/redux/actions/toasts';
|
3
|
+
import { insightsCloudUrl } from '../../InsightsCloudSyncHelpers';
|
4
|
+
import {
|
5
|
+
INSIGHTS_SYNC_SETTING_SET,
|
6
|
+
INSIGHTS_SYNC_SETTINGS_GET_SUCCESS,
|
7
|
+
} from './InsightsSettingsConstants';
|
8
|
+
|
9
|
+
export const getInsightsSyncSettings = () => async dispatch => {
|
10
|
+
try {
|
11
|
+
const {
|
12
|
+
data: { insightsSyncEnabled },
|
13
|
+
} = await API.get(insightsCloudUrl('settings'));
|
14
|
+
dispatch({
|
15
|
+
type: INSIGHTS_SYNC_SETTINGS_GET_SUCCESS,
|
16
|
+
payload: {
|
17
|
+
settings: {
|
18
|
+
insightsSyncEnabled,
|
19
|
+
},
|
20
|
+
},
|
21
|
+
});
|
22
|
+
} catch ({ message }) {
|
23
|
+
dispatch(
|
24
|
+
addToast({
|
25
|
+
sticky: true,
|
26
|
+
type: 'error',
|
27
|
+
message,
|
28
|
+
})
|
29
|
+
);
|
30
|
+
}
|
31
|
+
};
|
32
|
+
|
33
|
+
export const setInsightsSyncEnabled = currentInsightsSyncEnabled => async dispatch => {
|
34
|
+
try {
|
35
|
+
const {
|
36
|
+
data: { insightsSyncEnabled },
|
37
|
+
} = await API.patch(insightsCloudUrl('settings'), {
|
38
|
+
insightsSyncEnabled: currentInsightsSyncEnabled,
|
39
|
+
});
|
40
|
+
dispatch({
|
41
|
+
type: INSIGHTS_SYNC_SETTING_SET,
|
42
|
+
payload: {
|
43
|
+
settings: {
|
44
|
+
insightsSyncEnabled,
|
45
|
+
},
|
46
|
+
},
|
47
|
+
});
|
48
|
+
} catch ({ message }) {
|
49
|
+
dispatch(
|
50
|
+
addToast({
|
51
|
+
sticky: true,
|
52
|
+
type: 'error',
|
53
|
+
message,
|
54
|
+
})
|
55
|
+
);
|
56
|
+
}
|
57
|
+
};
|