All Downloads are FREE. Search and download functionalities are using the official Maven repository.

siddhi-files.IS_ANALYTICS_AUTHENTICATION_AGGREGATIONS.siddhi Maven / Gradle / Ivy

There is a newer version: 1.0.63
Show newest version
@App:name("IS_ANALYTICS_AUTHENTICATION_AGGREGATIONS")/*
 * Copyright (c) 2018 WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
 *
 * WSO2 Inc. licenses this file to you under the Apache License,
 * Version 2.0 (the "License"); you may not use this file except
 * in compliance with the License.
 * You may obtain a copy of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on an
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied.  See the License for the
 * specific language governing permissions and limitations
 * under the License.
 */


@App:description("Handle Event from IS and save data in a table for Overall Authentication")

-- STREAM DEFINITIONS

-- Stream from the Common
@source(type='inMemory', topic='IsAnalytics.Authentication.Common.OutputSinkFromProcessedAuthenticationDataStream', @map(type='passThrough'))
define stream ProcessedAuthenticationDataStream (
    meta_tenantId int,
    eventId string,
    username string,
    localUsername string,
    userStoreDomain string,
    tenantDomain string,
    rolesCommaSeparated string,
    remoteIp string,
    region string,
    inboundAuthType string,
    serviceProvider string,
    rememberMeEnabled bool,
    forceAuthEnabled bool,
    passiveAuthEnabled bool,
    stepAuthenticator string,
    authenticationStep string,
    authStepSuccess bool,
    identityProvider string,
    identityProviderType string,
    isFirstLogin bool,
    successValue int,
    failureValue int,
    stepSuccessValue int,
    firstLoginValue int,
    timestamp long
);

-- Duplicate stream for tokenize the comma separated roles
define stream PerUserRolesDuplicateEventStream (
    meta_tenantId int,
    eventId string,
    username string,
    localUsername string,
    userStoreDomain string,
    tenantDomain string,
    rolesCommaSeparated string,
    remoteIp string,
    region string,
    inboundAuthType string,
    serviceProvider string,
    rememberMeEnabled bool,
    forceAuthEnabled bool,
    passiveAuthEnabled bool,
    stepAuthenticator string,
    authenticationStep string,
    authStepSuccess bool,
    identityProvider string,
    identityProviderType string,
    isFirstLogin bool,
    successValue int,
    failureValue int,
    stepSuccessValue int,
    firstLoginValue int,
    timestamp long,
    token string
);

-- QUERIES

-- Role Aggreagation from Duplicate Stream
@store(type='rdbms', datasource='IS_ANALYTICS_DB', field.length='serviceProvider:100, identityProvider:100, userStoreDomain:50, region:45, token:100')
@purge(enable='true', interval='60 min', @retentionPeriod(sec='1 day', min='72 hours', hours='90 days', days='1 year', months='2 years', years='3 years'))
define aggregation RoleAggregation
from PerUserRolesDuplicateEventStream
select
    meta_tenantId,
    username,
    serviceProvider,
    identityProvider,
    token as role,
    remoteIp,
    region,
    userStoreDomain,
    isFirstLogin,
    sum(successValue) as authSuccessCount,
    sum(failureValue) as authFailureCount,
    sum(stepSuccessValue) as authStepSuccessCount,
    sum(firstLoginValue) as  authFirstSuccessCount,
    identityProviderType,
    timestamp
group by
    username,
    serviceProvider,
    identityProvider,
    region,
    token,
    userStoreDomain,
    isFirstLogin
aggregate by timestamp every second ... year;

-- Authentication Stat Stream for Store everything
@store(type='rdbms', datasource='IS_ANALYTICS_DB', field.length='serviceProvider:100, identityProvider:100, userStoreDomain:50, region:45')
@purge(enable='true', interval='60 min', @retentionPeriod(sec='1 day', min='72 hours', hours='90 days', days='1 year', months='2 years', years='3 years'))
define aggregation AuthStatAgg
from ProcessedAuthenticationDataStream
select
    meta_tenantId,
    username,
    localUsername,
    rolesCommaSeparated,
    serviceProvider,
    identityProvider,
    remoteIp,
    region,
    userStoreDomain,
    isFirstLogin,
    sum(successValue) as authSuccessCount,
    sum(failureValue) as authFailureCount,
    sum(stepSuccessValue) as authStepSuccessCount,
    sum(firstLoginValue) as  authFirstSuccessCount,
    identityProviderType,
    timestamp
group by
    username,
    serviceProvider,
    identityProvider,
    region,
    userStoreDomain,
    isFirstLogin
aggregate by timestamp every second ... year;

from ProcessedAuthenticationDataStream#str:tokenize(rolesCommaSeparated, ',')
insert into PerUserRolesDuplicateEventStreamNullCheck;

from PerUserRolesDuplicateEventStreamNullCheck[token!=""]
insert into PerUserRolesDuplicateEventStream;




© 2015 - 2025 Weber Informatics LLC | Privacy Policy