use of com.redhat.cloud.notifications.models.Endpoint in project notifications-backend by RedHatInsights.
the class LifecycleITest method test.
@Test
void test() {
final String accountId = "tenant";
final String orgId = "org-id";
final String username = "user";
setupEmailMock(accountId, orgId, username);
// First, we need a bundle, an app and an event type. Let's create them!
Bundle bundle = resourceHelpers.createBundle(BUNDLE_NAME);
Application app = resourceHelpers.createApp(bundle.getId(), APP_NAME);
EventType eventType = resourceHelpers.createEventType(app.getId(), EVENT_TYPE_NAME);
// We also need behavior groups.
BehaviorGroup behaviorGroup1 = createBehaviorGroup(accountId, bundle);
BehaviorGroup behaviorGroup2 = createBehaviorGroup(accountId, bundle);
BehaviorGroup defaultBehaviorGroup = createBehaviorGroup(null, bundle);
// We need actions for our behavior groups.
Endpoint endpoint1 = createWebhookEndpoint(accountId, SECRET_TOKEN);
Endpoint endpoint2 = createWebhookEndpoint(accountId, SECRET_TOKEN);
Endpoint endpoint3 = createWebhookEndpoint(accountId, "wrong-secret-token");
// We'll start with a first behavior group actions configuration. This will slightly change later in the test.
addBehaviorGroupAction(behaviorGroup1.getId(), endpoint1.getId());
addBehaviorGroupAction(behaviorGroup1.getId(), endpoint2.getId());
addBehaviorGroupAction(behaviorGroup2.getId(), endpoint3.getId());
// Adding an email endpoint to the default behavior group
addDefaultBehaviorGroupAction(defaultBehaviorGroup);
// Let's push a first message! It should not trigger any webhook call since we didn't link the event type with any behavior group.
pushMessage(0, 0, 0, 0);
// Now we'll link the event type with one behavior group.
addEventTypeBehavior(eventType.getId(), behaviorGroup1.getId());
// Get the account canonical email endpoint
Endpoint emailEndpoint = statelessSessionFactory.withSession(statelessSession -> {
return getAccountCanonicalEmailEndpoint(accountId);
});
// Pushing a new message should trigger two webhook calls.
pushMessage(2, 0, 0, 0);
// Let's check the notifications history.
retry(() -> checkEndpointHistory(endpoint1, 1, true));
retry(() -> checkEndpointHistory(endpoint2, 1, true));
retry(() -> checkEndpointHistory(emailEndpoint, 0, true));
// We'll link the event type with the default behavior group
addEventTypeBehavior(eventType.getId(), defaultBehaviorGroup.getId());
// We'll link an additional behavior group to the event type.
addEventTypeBehavior(eventType.getId(), behaviorGroup2.getId());
// Pushing a new message should trigger three webhook calls and 1 emails - email is not sent as the user is not subscribed
pushMessage(3, 1, 0, 0);
// Let's check the notifications history again.
retry(() -> checkEndpointHistory(endpoint1, 2, true));
retry(() -> checkEndpointHistory(endpoint2, 2, true));
retry(() -> checkEndpointHistory(endpoint3, 1, false));
retry(() -> checkEndpointHistory(emailEndpoint, 0, true));
// Lets subscribe the user to the email preferences
subscribeUserPreferences(accountId, username, app.getId());
// Pushing a new message should trigger three webhook calls and 1 email
pushMessage(3, 1, 1, 0);
// Let's check the notifications history again.
retry(() -> checkEndpointHistory(endpoint1, 3, true));
retry(() -> checkEndpointHistory(endpoint2, 3, true));
retry(() -> checkEndpointHistory(endpoint3, 2, false));
retry(() -> checkEndpointHistory(emailEndpoint, 1, true));
/*
* Let's change the behavior group actions configuration by adding an action to the second behavior group.
* Endpoint 2 is now an action for both behavior groups, but it should not be notified twice on each message because we don't want duplicate notifications.
*/
addBehaviorGroupAction(behaviorGroup2.getId(), endpoint2.getId());
// Pushing a new message should trigger three webhook calls.
pushMessage(3, 1, 1, 0);
// Let's check the notifications history again.
retry(() -> checkEndpointHistory(endpoint1, 4, true));
retry(() -> checkEndpointHistory(endpoint2, 4, true));
retry(() -> checkEndpointHistory(endpoint3, 3, false));
retry(() -> checkEndpointHistory(emailEndpoint, 2, true));
/*
* What happens if we unlink the event type from the behavior groups?
* Pushing a new message should not trigger any webhook call.
*/
// Unlinking user behavior group
clearEventTypeBehaviors(eventType);
pushMessage(0, 0, 0, 0);
// The notifications history should be exactly the same than last time.
retry(() -> checkEndpointHistory(endpoint1, 4, true));
retry(() -> checkEndpointHistory(endpoint2, 4, true));
retry(() -> checkEndpointHistory(endpoint3, 3, false));
retry(() -> checkEndpointHistory(emailEndpoint, 2, true));
// Linking the default behavior group again
addEventTypeBehavior(eventType.getId(), defaultBehaviorGroup.getId());
pushMessage(0, 1, 1, 0);
// Deleting the default behavior group should unlink it
deleteBehaviorGroup(defaultBehaviorGroup);
pushMessage(0, 0, 0, 0);
// We'll finish with a bundle removal.
deleteBundle(bundle);
}
use of com.redhat.cloud.notifications.models.Endpoint in project notifications-backend by RedHatInsights.
the class CamelTypeProcessorTest method testCamelEndpointProcessing.
@Test
void testCamelEndpointProcessing() {
// We need input data for the test.
Event event = buildEvent();
Endpoint endpoint1 = buildCamelEndpoint(event.getAction().getAccountId());
CamelProperties properties1 = endpoint1.getProperties(CamelProperties.class);
Endpoint endpoint2 = buildCamelEndpoint(event.getAction().getAccountId());
// Let's trigger the processing.
List<NotificationHistory> result = processor.process(event, List.of(endpoint1, endpoint2));
// Two endpoints should have been processed.
assertEquals(2, result.size());
// Metrics should report the same thing.
micrometerAssertionHelper.assertCounterIncrement(PROCESSED_COUNTER_NAME, 2, SUB_TYPE_KEY, SUB_TYPE);
micrometerAssertionHelper.assertCounterIncrement(PROCESSED_COUNTER_NAME, 0, SUB_TYPE_KEY, "other-type");
micrometerAssertionHelper.assertCounterIncrement(PROCESSED_COUNTER_NAME, 0);
// Let's have a look at the first result entry fields.
assertEquals(event, result.get(0).getEvent());
assertEquals(endpoint1, result.get(0).getEndpoint());
assertEquals(CAMEL, result.get(0).getEndpointType());
assertNotNull(result.get(0).getInvocationTime());
// The invocation will be complete when the response from Camel has been received.
assertFalse(result.get(0).isInvocationResult());
// Now let's check the Kafka messages sent to the outgoing channel.
InMemorySink<String> inMemorySink = inMemoryConnector.sink(TOCAMEL_CHANNEL);
// The channel should have received two messages.
assertEquals(2, inMemorySink.received().size());
// We'll only check the payload and metadata of the first Kafka message.
Message<String> message = inMemorySink.received().get(0);
// The payload should contain the action events.
JsonObject payload = new JsonObject(message.getPayload());
assertNotNull(payload.getJsonArray("events").getJsonObject(0).getString("payload"));
// The processor added a 'notif-metadata' field to the payload, let's have a look at it.
JsonObject notifMetadata = payload.getJsonObject(NOTIF_METADATA_KEY);
assertEquals(properties1.getDisableSslVerification().toString(), notifMetadata.getString("trustAll"));
assertEquals(properties1.getUrl(), notifMetadata.getString("url"));
assertEquals(endpoint1.getSubType(), notifMetadata.getString("type"));
// Todo: NOTIF-429 backward compatibility change - Remove soon.
assertEquals(properties1.getSubType(), notifMetadata.getString("type"));
assertEquals(new MapConverter().convertToDatabaseColumn(properties1.getExtras()), notifMetadata.getString("extras"));
assertEquals(properties1.getSecretToken(), notifMetadata.getString(TOKEN_HEADER));
checkBasicAuthentication(notifMetadata, properties1.getBasicAuthentication());
// Finally, we need to check the Kafka message metadata.
UUID historyId = result.get(0).getId();
checkKafkaMetadata(message, historyId, endpoint1.getSubType());
checkCloudEventMetadata(message, historyId, endpoint1.getAccountId(), endpoint1.getSubType());
checkTracingMetadata(message);
}
use of com.redhat.cloud.notifications.models.Endpoint in project notifications-backend by RedHatInsights.
the class WebhookTest method testWebhook.
@Test
void testWebhook() {
String url = getMockServerUrl() + "/foobar";
final List<String> bodyRequests = new ArrayList<>();
ExpectationResponseCallback verifyEmptyRequest = req -> {
bodyRequests.add(req.getBodyAsString());
return response().withStatusCode(200);
};
HttpRequest postReq = getMockHttpRequest(verifyEmptyRequest);
Action webhookActionMessage = buildWebhookAction();
Event event = new Event();
event.setAction(webhookActionMessage);
Endpoint ep = buildWebhookEndpoint(url);
try {
List<NotificationHistory> process = webhookTypeProcessor.process(event, List.of(ep));
NotificationHistory history = process.get(0);
assertTrue(history.isInvocationResult());
} catch (Exception e) {
e.printStackTrace();
fail(e);
} finally {
// Remove expectations
MockServerLifecycleManager.getClient().clear(postReq);
}
assertEquals(1, bodyRequests.size());
JsonObject webhookInput = new JsonObject(bodyRequests.get(0));
assertEquals("mybundle", webhookInput.getString("bundle"));
assertEquals("WebhookTest", webhookInput.getString("application"));
assertEquals("testWebhook", webhookInput.getString("event_type"));
assertEquals("tenant", webhookInput.getString("account_id"));
JsonObject webhookInputContext = webhookInput.getJsonObject("context");
assertEquals("more", webhookInputContext.getString("free"));
assertEquals(1, webhookInputContext.getInteger("format"));
assertEquals("stuff", webhookInputContext.getString("here"));
JsonArray webhookInputEvents = webhookInput.getJsonArray("events");
assertEquals(2, webhookInputEvents.size());
JsonObject webhookInputPayload1 = webhookInputEvents.getJsonObject(0).getJsonObject("payload");
assertEquals("thing", webhookInputPayload1.getString("any"));
assertEquals(1, webhookInputPayload1.getInteger("we"));
assertEquals("here", webhookInputPayload1.getString("want"));
}
use of com.redhat.cloud.notifications.models.Endpoint in project notifications-backend by RedHatInsights.
the class EventResourceTest method testAllQueryParams.
@Test
void testAllQueryParams() {
/*
* This method is very long, but splitting it into several smaller ones would mean we have to recreate lots of
* database records for each test. To avoid doing that, the data is only persisted once and many tests are run
* from the same data.
*/
Header defaultIdentityHeader = mockRbac(DEFAULT_ACCOUNT_ID, DEFAULT_ORG_ID, "user", FULL_ACCESS);
Header otherIdentityHeader = mockRbac(OTHER_ACCOUNT_ID, DEFAULT_ORG_ID, "other-username", FULL_ACCESS);
Bundle bundle1 = resourceHelpers.createBundle("bundle-1", "Bundle 1");
Bundle bundle2 = resourceHelpers.createBundle("bundle-2", "Bundle 2");
Application app1 = resourceHelpers.createApplication(bundle1.getId(), "app-1", "Application 1");
Application app2 = resourceHelpers.createApplication(bundle2.getId(), "app-2", "Application 2");
EventType eventType1 = resourceHelpers.createEventType(app1.getId(), "event-type-1", "Event type 1", "Event type 1");
EventType eventType2 = resourceHelpers.createEventType(app2.getId(), "event-type-2", "Event type 2", "Event type 2");
Event event1 = createEvent(DEFAULT_ACCOUNT_ID, bundle1, app1, eventType1, NOW.minusDays(5L));
Event event2 = createEvent(DEFAULT_ACCOUNT_ID, bundle2, app2, eventType2, NOW);
Event event3 = createEvent(DEFAULT_ACCOUNT_ID, bundle2, app2, eventType2, NOW.minusDays(2L));
Event event4 = createEvent(OTHER_ACCOUNT_ID, bundle2, app2, eventType2, NOW.minusDays(10L));
Endpoint endpoint1 = resourceHelpers.createEndpoint(DEFAULT_ACCOUNT_ID, WEBHOOK);
Endpoint endpoint2 = resourceHelpers.createEndpoint(DEFAULT_ACCOUNT_ID, EMAIL_SUBSCRIPTION);
Endpoint endpoint3 = resourceHelpers.createEndpoint(DEFAULT_ACCOUNT_ID, CAMEL, "SlAcK");
NotificationHistory history1 = resourceHelpers.createNotificationHistory(event1, endpoint1, TRUE);
NotificationHistory history2 = resourceHelpers.createNotificationHistory(event1, endpoint2, FALSE);
NotificationHistory history3 = resourceHelpers.createNotificationHistory(event2, endpoint1, TRUE);
NotificationHistory history4 = resourceHelpers.createNotificationHistory(event3, endpoint2, TRUE);
NotificationHistory history5 = resourceHelpers.createNotificationHistory(event3, endpoint3, TRUE);
endpointRepository.deleteEndpoint(DEFAULT_ACCOUNT_ID, endpoint1.getId());
endpointRepository.deleteEndpoint(DEFAULT_ACCOUNT_ID, endpoint2.getId());
endpointRepository.deleteEndpoint(DEFAULT_ACCOUNT_ID, endpoint3.getId());
/*
* Test #1
* Account: DEFAULT_ACCOUNT_ID
* Request: No filter
* Expected response: All event log entries from DEFAULT_ACCOUNT_ID should be returned
*/
Page<EventLogEntry> page = getEventLogPage(defaultIdentityHeader, null, null, null, null, null, null, null, null, null, null, false, true);
assertEquals(3, page.getMeta().getCount());
assertEquals(3, page.getData().size());
assertSameEvent(page.getData().get(0), event2, history3);
assertSameEvent(page.getData().get(1), event3, history4, history5);
assertSameEvent(page.getData().get(2), event1, history1, history2);
assertNull(page.getData().get(0).getPayload());
assertLinks(page.getLinks(), "first", "last");
/*
* Test #2
* Account: OTHER_ACCOUNT_ID
* Request: No filter
* Expected response: All event log entries from OTHER_ACCOUNT_ID should be returned
*/
page = getEventLogPage(otherIdentityHeader, null, null, null, null, null, null, null, null, null, null, false, true);
assertEquals(1, page.getMeta().getCount());
assertEquals(1, page.getData().size());
assertSameEvent(page.getData().get(0), event4);
assertNull(page.getData().get(0).getPayload());
assertLinks(page.getLinks(), "first", "last");
/*
* Test #3
* Account: DEFAULT_ACCOUNT_ID
* Request: Unknown bundle
*/
page = getEventLogPage(defaultIdentityHeader, Set.of(randomUUID()), null, null, null, null, null, null, null, null, null, false, true);
assertEquals(0, page.getMeta().getCount());
assertTrue(page.getData().isEmpty());
assertLinks(page.getLinks(), "first", "last");
/*
* Test #4
* Account: DEFAULT_ACCOUNT_ID
* Request: One existing bundle
*/
page = getEventLogPage(defaultIdentityHeader, Set.of(bundle1.getId()), null, null, null, null, null, null, null, null, null, false, true);
assertEquals(1, page.getMeta().getCount());
assertEquals(1, page.getData().size());
assertSameEvent(page.getData().get(0), event1, history1, history2);
assertNull(page.getData().get(0).getPayload());
assertLinks(page.getLinks(), "first", "last");
/*
* Test #5
* Account: DEFAULT_ACCOUNT_ID
* Request: Multiple existing bundles, sort by ascending bundle names
*/
page = getEventLogPage(defaultIdentityHeader, Set.of(bundle1.getId(), bundle2.getId()), null, null, null, null, null, null, null, null, "bundle:asc", false, true);
assertEquals(3, page.getMeta().getCount());
assertEquals(3, page.getData().size());
assertSameEvent(page.getData().get(0), event1, history1, history2);
assertSameEvent(page.getData().get(1), event2, history3);
assertSameEvent(page.getData().get(2), event3, history4, history5);
assertNull(page.getData().get(0).getPayload());
assertLinks(page.getLinks(), "first", "last");
/*
* Test #6
* Account: DEFAULT_ACCOUNT_ID
* Request: Unknown application
*/
page = getEventLogPage(defaultIdentityHeader, null, Set.of(randomUUID()), null, null, null, null, null, null, null, null, false, true);
assertEquals(0, page.getMeta().getCount());
assertTrue(page.getData().isEmpty());
assertLinks(page.getLinks(), "first", "last");
/*
* Test #7
* Account: DEFAULT_ACCOUNT_ID
* Request: One existing application
*/
page = getEventLogPage(defaultIdentityHeader, null, Set.of(app2.getId()), null, null, null, null, null, null, null, null, false, true);
assertEquals(2, page.getMeta().getCount());
assertEquals(2, page.getData().size());
assertSameEvent(page.getData().get(0), event2, history3);
assertSameEvent(page.getData().get(1), event3, history4, history5);
assertNull(page.getData().get(0).getPayload());
assertLinks(page.getLinks(), "first", "last");
/*
* Test #8
* Account: DEFAULT_ACCOUNT_ID
* Request: Multiple existing applications, sort by ascending application names
*/
page = getEventLogPage(defaultIdentityHeader, null, Set.of(app1.getId(), app2.getId()), null, null, null, null, null, null, null, "application:asc", false, true);
assertEquals(3, page.getMeta().getCount());
assertEquals(3, page.getData().size());
assertSameEvent(page.getData().get(0), event1, history1, history2);
assertSameEvent(page.getData().get(1), event2, history3);
assertSameEvent(page.getData().get(2), event3, history4, history5);
assertNull(page.getData().get(0).getPayload());
assertLinks(page.getLinks(), "first", "last");
/*
* Test #9
* Account: DEFAULT_ACCOUNT_ID
* Request: Unknown event type
*/
page = getEventLogPage(defaultIdentityHeader, null, null, "unknown", null, null, null, null, null, null, null, false, true);
assertEquals(0, page.getMeta().getCount());
assertTrue(page.getData().isEmpty());
assertLinks(page.getLinks(), "first", "last");
/*
* Test #10
* Account: DEFAULT_ACCOUNT_ID
* Request: Existing event type
*/
page = getEventLogPage(defaultIdentityHeader, null, null, eventType1.getDisplayName().substring(2).toUpperCase(), null, null, null, null, null, null, null, false, true);
assertEquals(1, page.getMeta().getCount());
assertEquals(1, page.getData().size());
assertSameEvent(page.getData().get(0), event1, history1, history2);
assertNull(page.getData().get(0).getPayload());
assertLinks(page.getLinks(), "first", "last");
/*
* Test #11
* Account: DEFAULT_ACCOUNT_ID
* Request: Start date three days in the past
*/
page = getEventLogPage(defaultIdentityHeader, null, null, null, NOW.minusDays(3L), null, null, null, null, null, null, false, true);
assertEquals(2, page.getMeta().getCount());
assertEquals(2, page.getData().size());
assertSameEvent(page.getData().get(0), event2, history3);
assertSameEvent(page.getData().get(1), event3, history4, history5);
assertNull(page.getData().get(0).getPayload());
assertLinks(page.getLinks(), "first", "last");
/*
* Test #12
* Account: DEFAULT_ACCOUNT_ID
* Request: End date three days in the past
*/
page = getEventLogPage(defaultIdentityHeader, null, null, null, null, NOW.minusDays(3L), null, null, null, null, null, false, true);
assertEquals(1, page.getMeta().getCount());
assertEquals(1, page.getData().size());
assertSameEvent(page.getData().get(0), event1, history1, history2);
assertNull(page.getData().get(0).getPayload());
assertLinks(page.getLinks(), "first", "last");
/*
* Test #13
* Account: DEFAULT_ACCOUNT_ID
* Request: Both start and end date are set
*/
page = getEventLogPage(defaultIdentityHeader, null, null, null, NOW.minusDays(3L), NOW.minusDays(1L), null, null, null, null, null, false, true);
assertEquals(1, page.getMeta().getCount());
assertEquals(1, page.getData().size());
assertSameEvent(page.getData().get(0), event3, history4, history5);
assertNull(page.getData().get(0).getPayload());
assertLinks(page.getLinks(), "first", "last");
/*
* Test #14
* Account: DEFAULT_ACCOUNT_ID
* Request: Let's try all request params at once!
*/
page = getEventLogPage(defaultIdentityHeader, Set.of(bundle2.getId()), Set.of(app2.getId()), eventType2.getDisplayName(), NOW.minusDays(3L), NOW.minusDays(1L), Set.of(EMAIL_SUBSCRIPTION.name()), Set.of(TRUE), 10, 0, "created:desc", true, true);
assertEquals(1, page.getMeta().getCount());
assertEquals(1, page.getData().size());
assertSameEvent(page.getData().get(0), event3, history4, history5);
assertEquals(PAYLOAD, page.getData().get(0).getPayload());
assertLinks(page.getLinks(), "first", "last");
/*
* Test #15
* Account: DEFAULT_ACCOUNT_ID
* Request: No filter, limit without offset
*/
page = getEventLogPage(defaultIdentityHeader, null, null, null, null, null, null, null, 2, null, null, false, true);
assertEquals(3, page.getMeta().getCount());
assertEquals(2, page.getData().size());
assertSameEvent(page.getData().get(0), event2, history3);
assertSameEvent(page.getData().get(1), event3, history4, history5);
assertNull(page.getData().get(0).getPayload());
assertLinks(page.getLinks(), "first", "last", "next");
/*
* Test #16
* Account: DEFAULT_ACCOUNT_ID
* Request: No filter, limit with offset
*/
page = getEventLogPage(defaultIdentityHeader, null, null, null, null, null, null, null, 1, 2, null, false, true);
assertEquals(3, page.getMeta().getCount());
assertEquals(1, page.getData().size());
assertSameEvent(page.getData().get(0), event1, history1, history2);
assertNull(page.getData().get(0).getPayload());
assertLinks(page.getLinks(), "first", "last", "prev");
/*
* Test #17
* Account: DEFAULT_ACCOUNT_ID
* Request: No filter, sort by ascending event names
*/
page = getEventLogPage(defaultIdentityHeader, null, null, null, null, null, null, null, null, null, "event:asc", false, true);
assertEquals(3, page.getMeta().getCount());
assertEquals(3, page.getData().size());
assertSameEvent(page.getData().get(0), event1, history1, history2);
assertSameEvent(page.getData().get(1), event2, history3);
assertSameEvent(page.getData().get(2), event3, history4, history5);
assertNull(page.getData().get(0).getPayload());
assertLinks(page.getLinks(), "first", "last");
/*
* Test #18
* Account: DEFAULT_ACCOUNT_ID
* Request: WEBHOOK endpoints
*/
page = getEventLogPage(defaultIdentityHeader, null, null, null, null, null, Set.of(WEBHOOK.name()), null, null, null, null, false, true);
assertEquals(2, page.getMeta().getCount());
assertEquals(2, page.getData().size());
assertSameEvent(page.getData().get(0), event2, history3);
assertSameEvent(page.getData().get(1), event1, history1, history2);
assertNull(page.getData().get(0).getPayload());
assertLinks(page.getLinks(), "first", "last");
/*
* Test #19
* Account: DEFAULT_ACCOUNT_ID
* Request: Invocation succeeded
*/
page = getEventLogPage(defaultIdentityHeader, null, null, null, null, null, null, Set.of(TRUE), null, null, null, false, true);
assertEquals(3, page.getMeta().getCount());
assertEquals(3, page.getData().size());
assertSameEvent(page.getData().get(0), event2, history3);
assertSameEvent(page.getData().get(1), event3, history4, history5);
assertSameEvent(page.getData().get(2), event1, history1, history2);
assertNull(page.getData().get(0).getPayload());
assertLinks(page.getLinks(), "first", "last");
/*
* Test #20
* Account: DEFAULT_ACCOUNT_ID
* Request: EMAIL_SUBSCRIPTION endpoints and invocation failed
*/
page = getEventLogPage(defaultIdentityHeader, null, null, null, null, null, Set.of(EMAIL_SUBSCRIPTION.name()), Set.of(FALSE), null, null, null, false, true);
assertEquals(1, page.getMeta().getCount());
assertEquals(1, page.getData().size());
assertSameEvent(page.getData().get(0), event1, history1, history2);
assertNull(page.getData().get(0).getPayload());
assertLinks(page.getLinks(), "first", "last");
/*
* Test #21
* Account: DEFAULT_ACCOUNT_ID
* Request: No filter
* Expected response: All event log entries from DEFAULT_ACCOUNT_ID should be returned without actions
*/
page = getEventLogPage(defaultIdentityHeader, null, null, null, null, null, null, null, null, null, null, false, false);
assertEquals(3, page.getMeta().getCount());
assertEquals(3, page.getData().size());
assertSameEvent(page.getData().get(0), event2);
assertSameEvent(page.getData().get(1), event3);
assertSameEvent(page.getData().get(2), event1);
assertNull(page.getData().get(0).getPayload());
assertLinks(page.getLinks(), "first", "last");
/*
* Test #22
* Account: DEFAULT_ACCOUNT_ID
* Request: CAMEL endpoints
*/
page = getEventLogPage(defaultIdentityHeader, null, null, null, null, null, Set.of(CAMEL.name()), null, null, null, null, false, true);
assertEquals(1, page.getMeta().getCount());
assertEquals(1, page.getData().size());
assertSameEvent(page.getData().get(0), event3, history4, history5);
assertNull(page.getData().get(0).getPayload());
assertLinks(page.getLinks(), "first", "last");
/*
* Test #23
* Account: DEFAULT_ACCOUNT_ID
* Request: CAMEL:SPLUNK endpoints
*/
page = getEventLogPage(defaultIdentityHeader, null, null, null, null, null, Set.of("camel:splunk"), null, null, null, null, false, true);
assertEquals(0, page.getMeta().getCount());
assertEquals(0, page.getData().size());
assertLinks(page.getLinks(), "first", "last");
/*
* Test #24
* Account: DEFAULT_ACCOUNT_ID
* Request: CAMEL:SLACK endpoints
*/
page = getEventLogPage(defaultIdentityHeader, null, null, null, null, null, Set.of("camel:slack"), null, null, null, null, false, true);
assertEquals(1, page.getMeta().getCount());
assertEquals(1, page.getData().size());
assertSameEvent(page.getData().get(0), event3, history4, history5);
assertNull(page.getData().get(0).getPayload());
assertLinks(page.getLinks(), "first", "last");
/*
* Test #25
* Account: DEFAULT_ACCOUNT_ID
* Request: CAMEL:SLACK and EMAIL endpoints
*/
page = getEventLogPage(defaultIdentityHeader, null, null, null, null, null, Set.of("camel:SLACK", EMAIL_SUBSCRIPTION.name()), null, null, null, null, false, true);
assertEquals(2, page.getMeta().getCount());
assertEquals(2, page.getData().size());
assertSameEvent(page.getData().get(0), event3, history4, history5);
assertSameEvent(page.getData().get(1), event1, history1, history2);
assertNull(page.getData().get(0).getPayload());
assertLinks(page.getLinks(), "first", "last");
/*
* Test #26
* Account: DEFAULT_ACCOUNT_ID
* Request: Mixing bundle and an app from a different bundle
*/
page = getEventLogPage(defaultIdentityHeader, Set.of(bundle1.getId()), Set.of(app2.getId()), null, null, null, null, null, 10, 0, null, true, true);
assertEquals(3, page.getMeta().getCount());
assertEquals(3, page.getData().size());
assertSameEvent(page.getData().get(0), event2, history3);
assertSameEvent(page.getData().get(1), event3, history4, history5);
assertSameEvent(page.getData().get(2), event1, history1, history2);
assertLinks(page.getLinks(), "first", "last");
}
use of com.redhat.cloud.notifications.models.Endpoint in project notifications-backend by RedHatInsights.
the class CamelTypeProcessor method process.
private NotificationHistory process(Notification item) {
Endpoint endpoint = item.getEndpoint();
String subType = endpoint.getSubType();
Counter processedCount = registry.counter(PROCESSED_COUNTER_NAME, "subType", subType);
processedCount.increment();
CamelProperties properties = (CamelProperties) endpoint.getProperties();
Map<String, String> metaData = new HashMap<>();
metaData.put("trustAll", String.valueOf(properties.getDisableSslVerification()));
metaData.put("url", properties.getUrl());
metaData.put("type", subType);
if (properties.getSecretToken() != null && !properties.getSecretToken().isBlank()) {
metaData.put(TOKEN_HEADER, properties.getSecretToken());
}
BasicAuthentication basicAuthentication = properties.getBasicAuthentication();
if (basicAuthentication != null && basicAuthentication.getUsername() != null && basicAuthentication.getPassword() != null) {
StringBuilder sb = new StringBuilder(basicAuthentication.getUsername());
sb.append(":");
sb.append(basicAuthentication.getPassword());
String b64 = Base64Utils.encode(sb.toString());
metaData.put("basicAuth", b64);
}
metaData.put("extras", new MapConverter().convertToDatabaseColumn(properties.getExtras()));
String originalEventId = "-not provided-";
if (item.getEvent().getId() != null) {
originalEventId = item.getEvent().getId().toString();
}
metaData.put("_originalId", originalEventId);
JsonObject payload = transformer.transform(item.getEvent().getAction());
UUID historyId = UUID.randomUUID();
JsonObject metadataAsJson = new JsonObject();
payload.put(NOTIF_METADATA_KEY, metadataAsJson);
metaData.forEach(metadataAsJson::put);
return callCamel(item, historyId, payload, originalEventId);
}
Aggregations