-
Notifications
You must be signed in to change notification settings - Fork 903
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat(cdevents-notification): CDEvents notification to produce CDEvents #9997
Changes from 19 commits
c6c2f18
9b46d39
129c59d
3ac861a
bf27653
f1f5934
aaa1a7f
e27f287
1f702ec
a2aa0e9
26f6792
16bf5e8
af60d16
5bffdf9
b27eaff
0e5d44f
de0e35f
591cc9c
09ed874
096330b
9778374
9099a58
491e216
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,40 @@ | ||
import React from 'react'; | ||
|
||
import type { INotificationTypeCustomConfig } from '../../../../domain'; | ||
import { FormikFormField, TextInput, Validators } from '../../../../presentation'; | ||
|
||
export class CDEventsNotificationType extends React.Component<INotificationTypeCustomConfig> { | ||
public render() { | ||
const { fieldName } = this.props; | ||
return ( | ||
<> | ||
<FormikFormField | ||
label="Events Broker URL" | ||
name={fieldName ? `${fieldName}.address` : 'address'} | ||
validate={Validators.skipIfSpel(Validators.urlValue('Please enter a valid URL'))} | ||
input={(props) => ( | ||
<TextInput | ||
inputClassName={'form-control input-sm'} | ||
{...props} | ||
placeholder="URL starts with https://events-broker-address/default/events-broker/" | ||
/> | ||
)} | ||
required={true} | ||
/> | ||
<FormikFormField | ||
label="CDEvents Type" | ||
name={fieldName ? `${fieldName}.cdEventsType` : 'cdEventsType'} | ||
validate={Validators.skipIfSpel(Validators.cdeventsTypeValue('Please enter a valid CDEvents Type'))} | ||
input={(props) => ( | ||
<TextInput | ||
inputClassName={'form-control input-sm'} | ||
{...props} | ||
placeholder="CDEvents Type starts with dev.cdevents.<subject>.<predicate>" | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Similar to the above comment, placeholder text is best as an actual value, and would match the PR screenshot. More descriptive help can also be added if needed, as above. We may also need this placeholder value configurable from There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. when looking at other notifications I think placeholders are showing an example/description how actual value should be, in this case the input for There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. The CDEvents spec details that event types "should" start with That's the typical interpretation of that language in other RFC processes. As for the placeholder value itself, I don't have a strong opinion on the text of it, so long as it doesn't conflict with event type validation. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Agree, changing the placeholder for CDEvents Type to a message "Enter a CDEvents type" and make configurable through |
||
/> | ||
)} | ||
required={true} | ||
/> | ||
</> | ||
); | ||
} | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
import { CDEventsNotificationType } from './CDEventsNotificationType'; | ||
import type { INotificationTypeConfig } from '../../../../domain'; | ||
|
||
export const cdEventsNotification: INotificationTypeConfig = { | ||
component: CDEventsNotificationType, | ||
key: 'cdevents', | ||
label: 'CDEvents', | ||
}; |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -9,13 +9,31 @@ const VALID_EMAIL_REGEX = new RegExp( | |
'^(([^<>()\\[\\]\\\\.,;:\\s@"]+(\\.[^<>()\\[\\]\\\\.,;:\\s@"]+)*)|(".+"))@((\\[[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}])|(([a-zA-Z\\-0-9]+\\.)+[a-zA-Z]{2,}))$', | ||
); | ||
|
||
const VALID_URL = new RegExp('^https?://.+$'); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. It would be good to make this configurable from There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. @jcavanagh Thank you for reviewing this PR The URL here is a single Message Broker URL where the CDEvents should be delivered. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. The need is as I described in the first comment - operators may wish to only allow just one or a few URLs here, or limit that to a subset of domains. Exfiltration of CDEvents can be a serious security problem, and it would be useful to have an additional guard on the frontend to have that experience align with any guards on the backend. Or, we could just delegate validation to the backend, and skip the frontend URL validation entirely. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. As an example, the code in here would first check for a value from the Spinnaker
Or something along those lines. The import path will vary based on where this file is relative to that in the Deck source tree. |
||
|
||
const VALID_CDEVENT_REGEX = new RegExp('^dev\\.cdevents\\.[^.]+\\.[^.]+$'); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. It would also be good to make this configurable from |
||
|
||
const emailValue = (message?: string): IValidator => { | ||
return function emailValue(val: string, label = THIS_FIELD) { | ||
message = message || `${label} is not a valid email address.`; | ||
return val && !VALID_EMAIL_REGEX.test(val) && message; | ||
}; | ||
}; | ||
|
||
const urlValue = (message?: string): IValidator => { | ||
return function urlValue(val: string, label = THIS_FIELD) { | ||
message = message || `${label} is not a valid URL.`; | ||
return val && !VALID_URL.test(val) && message; | ||
}; | ||
}; | ||
|
||
const cdeventsTypeValue = (message?: string): IValidator => { | ||
return function cdeventsTypeValue(val: string, label = THIS_FIELD) { | ||
message = message || `${label} is not a valid CDEvents Type.`; | ||
return val && !VALID_CDEVENT_REGEX.test(val) && message; | ||
}; | ||
}; | ||
|
||
const isRequired = (message?: string): IValidator => { | ||
return function isRequired(val: any, label = THIS_FIELD) { | ||
message = message || `${label} is required.`; | ||
|
@@ -138,6 +156,8 @@ export const Validators = { | |
arrayNotEmpty, | ||
checkBetween, | ||
emailValue, | ||
cdeventsTypeValue, | ||
urlValue, | ||
isNum, | ||
isRequired, | ||
isValidJson, | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Placeholder text is best when it is an actual possible value, not a description (e.g.
placeholder="https://..."
).The screenshot in the PR already has it like that, but this is different here in the code.
More descriptive help can be added via a
help
field on theFormikFormField
component, e.g.:We may also need this placeholder value configurable from
settings.js
, as it would need to match the custom validation.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I followed the same format how it is used today for MS Teams or GoogleChat notifications, not sure If we change for this alone, will it be a different user experience?
Configurable from settings.js, not sure If I understood this correctly is that keeping a key:value pair in settings.js something like this, but this will actually keep the default value right, rather this value should be just an example URL
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't mind that much either way on the content of the placeholder text. However, if the URL validation is configurable, the placeholder value should not conflict with it.
I would probably suggest removing it in this case, as the path on the event broker is not in the CDEvents spec, and so the
/default/events-broker/
path is probably more confusing than helpful.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ok, changing the placeholder for Events Broker URL to a message "Enter an events message broker URL" and make configurable through
settings