• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

mendersoftware / gui / 951494492

pending completion
951494492

Pull #3921

gitlab-ci

web-flow
chore: bump react-redux from 8.1.1 to 8.1.2

Bumps [react-redux](https://github.com/reduxjs/react-redux) from 8.1.1 to 8.1.2.
- [Release notes](https://github.com/reduxjs/react-redux/releases)
- [Changelog](https://github.com/reduxjs/react-redux/blob/master/CHANGELOG.md)
- [Commits](https://github.com/reduxjs/react-redux/compare/v8.1.1...v8.1.2)

---
updated-dependencies:
- dependency-name: react-redux
  dependency-type: direct:production
  update-type: version-update:semver-patch
...

Signed-off-by: dependabot[bot] <support@github.com>
Pull Request #3921: chore: bump react-redux from 8.1.1 to 8.1.2

4446 of 6414 branches covered (69.32%)

8342 of 10084 relevant lines covered (82.73%)

181.59 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

57.89
/src/js/components/settings/webhooks/configuration.js
1
// Copyright 2022 Northern.tech AS
2
//
3
//    Licensed under the Apache License, Version 2.0 (the "License");
4
//    you may not use this file except in compliance with the License.
5
//    You may obtain a copy of the License at
6
//
7
//        http://www.apache.org/licenses/LICENSE-2.0
8
//
9
//    Unless required by applicable law or agreed to in writing, software
10
//    distributed under the License is distributed on an "AS IS" BASIS,
11
//    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
//    See the License for the specific language governing permissions and
13
//    limitations under the License.
14
import React, { useCallback, useEffect, useState } from 'react';
15

16
// material ui
17
import { Close as CloseIcon } from '@mui/icons-material';
18
import { Button, Divider, Drawer, IconButton, TextField } from '@mui/material';
19

20
import validator from 'validator';
21

22
import { EXTERNAL_PROVIDER } from '../../../constants/deviceConstants';
23
import { emptyWebhook } from '../../../constants/organizationConstants';
24
import InfoHint from '../../common/info-hint';
25
import MenderTooltip from '../../common/mendertooltip';
26

27
const WebhookConfiguration = ({ adding, editing, onCancel, onSubmit, webhook = { ...emptyWebhook } }) => {
6✔
28
  const [description, setDescription] = useState('');
2✔
29
  const [secret, setSecret] = useState('');
2✔
30
  const [secretFormatError, setSecretFormatError] = useState('');
2✔
31
  const [url, setUrl] = useState('');
2✔
32

33
  const { credentials = {}, description: hookDescription = '', id = 'new' } = webhook;
2!
34
  const {
35
    [EXTERNAL_PROVIDER.webhook.credentialsType]: { secret: hookSecret = '', url: hookUrl = '' }
×
36
  } = credentials;
2✔
37
  useEffect(() => {
2✔
38
    setDescription(hookDescription);
2✔
39
    setUrl(hookUrl);
2✔
40
    setSecret(hookSecret);
2✔
41
  }, [adding, editing, hookDescription, hookSecret, hookUrl]);
42

43
  useEffect(() => {
2✔
44
    setSecretFormatError(!secret || validator.isHexadecimal(secret) ? '' : 'The secret has to be entered as a hexadecimal string');
2!
45
  }, [secret]);
46

47
  const onSubmitClick = useCallback(() => {
2✔
48
    let webhookConfig = {
×
49
      id,
50
      provider: EXTERNAL_PROVIDER.webhook.provider,
51
      credentials: { type: EXTERNAL_PROVIDER.webhook.credentialsType, [EXTERNAL_PROVIDER.webhook.credentialsType]: { secret, url } },
52
      description
53
    };
54
    if (editing) {
×
55
      // eslint-disable-next-line no-unused-vars
56
      const { credentials, description, ...remainder } = webhookConfig;
×
57
      webhookConfig = { ...remainder, credentials: { ...credentials, [EXTERNAL_PROVIDER.webhook.credentialsType]: { url } } };
×
58
    }
59
    onSubmit(webhookConfig);
×
60
  }, [description, editing, id, secret, url]);
61

62
  const secretInputTip = editing ? 'Cannot edit webhook secrets after they have been saved' : 'The secret has to be entered as a hexadecimal string';
2!
63
  const descriptionInput = (
64
    <TextField
2✔
65
      label="Description (optional)"
66
      id="webhook-description"
67
      disabled={editing}
68
      multiline
69
      onChange={e => setDescription(e.target.value)}
×
70
      value={description}
71
    />
72
  );
73
  const urlInput = <TextField label="Url" id="webhook-name" disabled={editing} value={url} onChange={e => setUrl(e.target.value)} />;
2✔
74
  const isSubmitDisabled = !url || (editing && url === hookUrl);
2!
75
  return (
2✔
76
    <>
77
      <InfoHint content="Webhooks are triggered when a device's status is updated, or a device is decommissioned or provisioned." />
78
      <div className="flexbox column" style={{ width: 500 }}>
79
        {editing ? (
2!
80
          <MenderTooltip arrow placement="bottom-start" title="Cannot edit webhook url after it has been saved">
81
            {urlInput}
82
          </MenderTooltip>
83
        ) : (
84
          urlInput
85
        )}
86
        {editing ? (
2!
87
          <MenderTooltip arrow placement="bottom-start" title="Cannot edit webhook description after it has been saved">
88
            {descriptionInput}
89
          </MenderTooltip>
90
        ) : (
91
          descriptionInput
92
        )}
93
        <MenderTooltip arrow placement="bottom-start" title={secretInputTip}>
94
          <TextField
95
            label="Secret (optional)"
96
            id="webhook-secret"
97
            disabled={editing}
98
            error={!editing && !!secretFormatError}
2!
99
            helperText={!editing && secretFormatError}
2!
100
            onChange={e => setSecret(e.target.value)}
×
101
            type={editing ? 'password' : 'text'}
2!
102
            value={secret}
103
          />
104
        </MenderTooltip>
105
      </div>
106
      <Divider className="margin-top-large" light />
107
      <div className="flexbox centered margin-top" style={{ justifyContent: 'flex-end' }}>
108
        <Button onClick={onCancel}>Cancel</Button>
109
        {!editing && (
2!
110
          <Button color="secondary" variant="contained" disabled={isSubmitDisabled} onClick={onSubmitClick}>
111
            Submit
112
          </Button>
113
        )}
114
      </div>
115
    </>
116
  );
117
};
118

119
export const WebhookCreation = ({ adding, onCancel, ...props }) => (
6✔
120
  <Drawer anchor="right" open={adding} PaperProps={{ style: { minWidth: 600, width: '50vw' } }}>
3✔
121
    <div className="flexbox center-aligned margin-bottom-small space-between">
122
      <h3>Add a webhook</h3>
123
      <IconButton onClick={onCancel} aria-label="close">
124
        <CloseIcon />
125
      </IconButton>
126
    </div>
127
    <Divider />
128
    <WebhookConfiguration adding={adding} onCancel={onCancel} {...props} />
129
  </Drawer>
130
);
131

132
export default WebhookConfiguration;
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2025 Coveralls, Inc