Skip to content
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

AUT Feature #404

Open
wants to merge 106 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
106 commits
Select commit Hold shift + click to select a range
0266240
Integrate AUT feature (#301)
hani-iterable Mar 4, 2024
287aa89
Add user object to trackanonsession and create user after live/valid …
hardikmashru Apr 23, 2024
8a178d6
Merge branch 'main' into AUT_main
hardikmashru May 24, 2024
e1a9651
aut changes
hardikmashru May 30, 2024
cff5e8b
pushed files temporarily
hardikmashru May 30, 2024
0f3861e
some updates for AUT fixes
hardikmashru May 30, 2024
bc57c34
updates
hardikmashru Jun 3, 2024
1cf0763
Criteria bugs fixed
Jun 4, 2024
c0c9f17
Criteria bugs fixed
Jun 4, 2024
a9ccb27
Criteria bugs fixed
Jun 4, 2024
04155d3
Criteria bugs fixed
Jun 4, 2024
8b20a65
Merge branch 'main' into AUT_main
hardikmashru Jun 4, 2024
bf750bc
event test undo
hardikmashru Jun 4, 2024
2c8c031
Update events.ts
hardikmashru Jun 4, 2024
44999e3
updateuser changes
hardikmashru Jun 4, 2024
72eb4a3
updates
hardikmashru Jun 4, 2024
6ffc682
more fixes and updates
hardikmashru Jun 4, 2024
ec08641
Authorization test file fixed
Jun 5, 2024
39e1729
Fixed destination email case
Jun 6, 2024
594b1cc
Sync events in case of anon user not created and developer tries to c…
Jun 6, 2024
4d4a6f3
Handle updateCart flow separately for Anon event and when syncing data
Jun 6, 2024
492addb
Fixed all the test file with authorixation and annon user event manager
Jun 7, 2024
f123483
Fixed JWT case
Jun 7, 2024
9691279
removed logs and did some improvements
hardikmashru Jun 7, 2024
b953345
fixed some circular dependencies
hardikmashru Jun 7, 2024
27b4792
keep current identity of anon user if merge fails
hardikmashru Jun 7, 2024
1f35dd1
logic changes for criteria
hardikmashru Jun 13, 2024
c2dcfcb
Simple min match works
Jun 14, 2024
8525a72
Not check event again when matched criteria
Jun 17, 2024
8bc20a3
Fixed event stored in local as it is and remove criteria id when sync
Jun 17, 2024
ea4031c
remove criteria id from events if not available in criteria list when…
Jun 17, 2024
0abef34
JWT changes added in example
Jun 17, 2024
3a905db
Merge branch 'main' into AUT_main
Jun 17, 2024
24f8ac0
Authorization changes pushed
Jun 17, 2024
e6cfdd7
Authorization test fxed
Jun 17, 2024
0f2fcab
Fixed comments
Jun 17, 2024
9a02a89
Create new AUT example
Jun 17, 2024
e672975
Merge branch 'AUT_main' into AUT_main_logicchanges2
Jun 17, 2024
0ece6da
Update setUserId
Jun 17, 2024
0bafce5
webpack updated
Jun 17, 2024
3dd3ab7
Fixed test files
Jun 17, 2024
065e5cf
Merge branch 'AUT_main' into AUT_main_logicchanges2
Jun 17, 2024
9b69989
remove criteria from utils
Jun 18, 2024
e511b7e
Test file is fixed and criteria matched
Jun 18, 2024
38863fd
Remove logs
Jun 18, 2024
f1ab176
Revert Users and Commerce changes
Jun 18, 2024
78069c8
Fixed import circular dependency
Jun 18, 2024
3a4a4bc
Fixed circular dependancy
Jun 18, 2024
8caeaae
Update imports
Jun 18, 2024
0c4597e
Reverted eventform
Jun 18, 2024
6a75ded
Fixed circular dependency
Jun 18, 2024
263bd46
more fixes
hardikmashru Jun 18, 2024
909f7b0
Update webpack.config.js
hardikmashru Jun 18, 2024
9a8911d
fixed some suggestions
hardikmashru Jun 18, 2024
db1c7ae
Fixed comment
Jun 19, 2024
0b1480e
Fixed single item matches code (#410)
hardikmashru Jul 1, 2024
6d50998
Add merge param (#414)
hardikmashru Jul 4, 2024
41ffd79
MOB 8960 (#415)
hardikmashru Jul 11, 2024
06c55d9
Isset purchase update fix (#416)
hardikmashru Jul 12, 2024
7c04dba
Fixed bools needs to be string (#422)
darshan-iterable Jul 31, 2024
c403521
MOB-9055: Resolve nested criteria match issue (#423)
darshan-iterable Aug 5, 2024
85a2d22
MOB-9138: Resolves DoesNotEqual criteria match issue (#426)
darshan-iterable Aug 6, 2024
2606561
Merge branch 'main' into AUT_main
hani-iterable Aug 9, 2024
6102cd3
Merge branch 'main' into AUT_main 2606561
hani-iterable Aug 9, 2024
80ceb0e
revert back eslint rule
hani-iterable Aug 9, 2024
c8d6dbf
Resolve path related error
hani-iterable Aug 12, 2024
5d60f23
[MOB-9258] fixed nested IsSet matching (#427)
darshan-iterable Aug 12, 2024
55e06f7
MOB-9305: fixed events createdAt timeStamps (#431)
darshan-iterable Aug 19, 2024
9061631
MOB-9168: Written automated unit tests against Combination logic with…
darshan-iterable Aug 19, 2024
7ae6910
MOB-8824: Added limitation to event storage (#430)
darshan-iterable Aug 19, 2024
fc1d7ec
Nested custom event check related change (#432)
hani-iterable Aug 19, 2024
4197cb2
MOB 9328 - Verify AUT works with JWT (#437)
hani-iterable Aug 22, 2024
2eda85d
MOB 9149 - Sample app object updates not formatted properly (#438)
hani-iterable Aug 23, 2024
904f602
MOB-9308: supports nested field types (#439)
darshan-iterable Aug 29, 2024
0218166
MOB-9081: Written automated unit tests for different field types and …
darshan-iterable Aug 29, 2024
93e1b0f
fully supports comparison for data in Array data with all comparator …
darshan-iterable Sep 4, 2024
16baf6c
MOB 9328 add JWT in response (#441)
hani-iterable Sep 4, 2024
4013132
updated nested field logic (#445)
darshan-iterable Sep 5, 2024
25fcde1
MOB-9145: support isOneOf and isNotOneOf comparator (#446)
darshan-iterable Sep 6, 2024
8f6e6a7
[MOB-9522]: Fix JWT UserID Support (#452)
mprew97 Sep 12, 2024
c9a304a
[MOB-9505] rename merge parameter (#450)
darshan-iterable Sep 17, 2024
1963926
MOB-9307 Add test to validate object created by custom event and user…
darshan-iterable Sep 18, 2024
aa2a124
[MOB-9402] update user should not be a separate call (#453)
darshan-iterable Sep 23, 2024
51bd3a2
[MOB-9568] update "criterias" to "criteriaSets" (#456)
darshan-iterable Sep 25, 2024
5b7ffa0
[MOB-9578] implements identity resolution (#458)
darshan-iterable Oct 2, 2024
604ea66
MOB-9650 Added support for nested criteria match a.b.c (#457)
darshan-iterable Oct 2, 2024
c720d4f
[MOB-9652] support for nested JSON array (#459)
darshan-iterable Oct 7, 2024
275b460
[MOB-9639] Added handler for notifying customer app of a newly create…
darshan-iterable Oct 7, 2024
1d28695
[MOB-9640] Keep AUT off until concent to track is granted (#462)
darshan-iterable Oct 15, 2024
66dc2a0
[MOB-9899]: Add Auth Checks Before API Calls (#463)
mprew97 Oct 15, 2024
fdf8dd7
[MOB-9955]: Allow IdentityResolution Overrides and Move onAnonUserCre…
mprew97 Oct 15, 2024
1cf59ee
fix replay issue with JWT (#465)
mprew97 Oct 16, 2024
b3f50c4
[MOB-9954]: fix userMergeScenario test (#466)
mprew97 Oct 17, 2024
061b42c
[MOB-9954]: Fix Circular Dependency and Clean Up Auth Checks on API C…
mprew97 Oct 17, 2024
9c41772
rename (#470)
mprew97 Oct 24, 2024
1387a2d
[MOB-9703] Added support for fetching new JWT prior to calling merge …
darshan-iterable Oct 25, 2024
fd7d971
[MOB-9970] anonymous criteria should match for nested values (#472)
darshan-iterable Oct 28, 2024
7699b03
[MOB-10064] single primitive array bug fix (#473)
darshan-iterable Oct 28, 2024
2f3792e
[MOB-10086]: Minor AUT Code Cleanup/Renaming (#474)
mprew97 Oct 30, 2024
baa3f7c
[MOB-10091]: AUT Pre-Bash Updates (#475)
mprew97 Oct 31, 2024
f95cc67
Merge branch 'main' of github.com:Iterable/iterable-web-sdk into AUT_…
mprew97 Oct 31, 2024
0c0fd2d
remove md file (#477)
mprew97 Nov 6, 2024
c293ab4
add method to clear anon data (#480)
mprew97 Nov 6, 2024
ebd61bf
add new messsage to rejection (#479)
mprew97 Nov 6, 2024
4ceae33
[MOB-10123]: Clear Anon Data When Replay is False (#478)
mprew97 Nov 6, 2024
4b1829a
update release version (#481)
mprew97 Nov 7, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions package.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"name": "@iterable/web-sdk",
"description": "Iterable SDK for JavaScript and Node.",
"version": "1.1.2",
"version": "1.2.0-beta",
"homepage": "https://iterable.com/",
"repository": {
"type": "git",
Expand Down Expand Up @@ -74,7 +74,7 @@
"@types/jest": "^27.0.2",
"@types/node": "^12.7.1",
"@types/throttle-debounce": "^2.1.0",
"@types/uuid": "^9.0.2",
"@types/uuid": "^9.0.8",
"@typescript-eslint/eslint-plugin": "^5.38.1",
"@typescript-eslint/parser": "^5.38.1",
"@webpack-cli/serve": "^1.6.0",
Expand Down
13 changes: 4 additions & 9 deletions react-example/.eslintrc
Original file line number Diff line number Diff line change
@@ -1,13 +1,8 @@
{
"extends": [
"../.eslintrc",
"plugin:react/recommended"
],
"extends": ["../.eslintrc", "plugin:react/recommended"],
"rules": {
"@typescript-eslint/no-empty-interface": "off",
"react/react-in-jsx-scope": "off",
"react/react-in-jsx-scope": "off"
},
"ignorePatterns": [
"node_modules/"
]
}
"ignorePatterns": ["node_modules/"]
}
4 changes: 1 addition & 3 deletions react-example/src/components/EventsForm.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -28,10 +28,9 @@ export const EventsForm: FC<Props> = ({
);

const [trackEvent, setTrackEvent] = useState<string>('');

const [isTrackingEvent, setTrackingEvent] = useState<boolean>(false);

const handleTrack = (e: FormEvent<HTMLFormElement>) => {
const handleTrack = async (e: FormEvent<HTMLFormElement>) => {
e.preventDefault();
setTrackingEvent(true);

Expand All @@ -50,7 +49,6 @@ export const EventsForm: FC<Props> = ({
})
.catch((e: any) => {
setTrackResponse(JSON.stringify(e.response.data));
setTrackingEvent(false);
});
};

Expand Down
154 changes: 154 additions & 0 deletions react-example/src/components/LoginFormWithoutJWT.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,154 @@
/* eslint-disable @typescript-eslint/no-unused-vars */
import { ChangeEvent, FC, FormEvent, useState } from 'react';
import styled from 'styled-components';

import { IdentityResolution } from '@iterable/web-sdk';
import { TextField as _TextField } from './TextField';
import { Button as _Button } from './Button';

import { useUser } from '../context/Users';

const TextField = styled(_TextField)``;

const Button = styled(_Button)`
margin-left: 0.4em;
max-width: 425px;
`;

const Form = styled.form`
display: flex;
flex-flow: row;
align-items: center;
justify-content: flex-end;
height: 100%;

${TextField} {
align-self: stretch;
margin-top: 5px;
}
`;

const StyledDiv = styled.div`
display: flex;
flex-direction: column;
align-items: flex-start;
`;

const Error = styled.div`
color: red;
`;

interface Props {
setEmail: (email: string) => Promise<void>;
setUserId: (
userId: string,
identityResolution?: IdentityResolution
) => Promise<void>;
logout: () => void;
}

export const LoginFormWithoutJWT: FC<Props> = ({
setEmail,
setUserId,
logout
}) => {
const [useEmail, setUseEmail] = useState<boolean>(true);
const [user, updateUser] = useState<string>(process.env.LOGIN_EMAIL || '');

const [error, setError] = useState<string>('');

const [isEditingUser, setEditingUser] = useState<boolean>(false);

const { loggedInUser, setLoggedInUser } = useUser();

const handleSubmit = (e: FormEvent<HTMLFormElement>) => {
e.preventDefault();

const setUser = useEmail ? setEmail : setUserId;

setUser(user)
.then(() => {
setEditingUser(false);
setLoggedInUser({ type: 'user_update', data: user });
})
.catch(() => setError('Something went wrong!'));
};

const handleLogout = () => {
logout();
setLoggedInUser({ type: 'user_update', data: '' });
};

const handleEditUser = () => {
updateUser(loggedInUser);
setEditingUser(true);
};

const handleCancelEditUser = () => {
updateUser('');
setEditingUser(false);
};

const handleRadioChange = (e: ChangeEvent<HTMLInputElement>) => {
setUseEmail(e.target.value === 'email');
};

const first5 = loggedInUser.substring(0, 5);
const last9 = loggedInUser.substring(loggedInUser.length - 9);

return (
<>
{loggedInUser && !isEditingUser ? (
<>
<Button onClick={handleEditUser}>
Logged in as {`${first5}...${last9}`} (change)
</Button>
<Button onClick={handleLogout}>Logout</Button>
</>
) : (
<StyledDiv>
<Form>
<div>
<input
type="radio"
id="userId"
name="userId"
value="userId"
checked={!useEmail}
onChange={handleRadioChange}
/>
<label>UserId</label>
</div>
<div>
<input
type="radio"
id="email"
name="email"
value="email"
checked={useEmail}
onChange={handleRadioChange}
/>
<label>Email</label>
</div>
</Form>
<Form onSubmit={handleSubmit} data-qa-login-form>
<TextField
onChange={(e) => updateUser(e.target.value)}
value={user}
placeholder="e.g. [email protected]"
required
data-qa-login-input
/>
<Button type="submit">{isEditingUser ? 'Change' : 'Login'}</Button>
{isEditingUser && (
<Button onClick={handleCancelEditUser}>Cancel</Button>
)}
</Form>
{error && <Error>{error}</Error>}
</StyledDiv>
)}
</>
);
};

export default LoginFormWithoutJWT;
19 changes: 16 additions & 3 deletions react-example/src/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ import { EmbeddedMessage } from './views/Embedded';
import { Link } from './components/Link';
import { LoginForm } from './components/LoginForm';
import { EmbeddedMsgs } from './views/EmbeddedMsgs';
import AUTTesting from './views/AUTTesting';

import { UserProvider } from './context/Users';
import { EmbeddedMsgsImpressionTracker } from './views/EmbeddedMsgsImpressionTracker';
Expand Down Expand Up @@ -45,7 +46,8 @@ const HomeLink = styled(Link)`
authToken: process.env.API_KEY || '',
configOptions: {
isEuIterableService: false,
dangerouslyAllowJsPopups: true
dangerouslyAllowJsPopups: true,
enableAnonActivation: true
},
generateJWT: ({ email, userID }) =>
axios
Expand All @@ -65,8 +67,15 @@ const HomeLink = styled(Link)`
)
.then((response: any) => response.data?.token)
};
const { setEmail, setUserID, logout, refreshJwtToken } =
initializeWithConfig(initializeParams);
const {
setEmail,
setUserID,
logout,
refreshJwtToken,
setVisitorUsageTracked
} = initializeWithConfig(initializeParams);

const handleConsent = (consent?: boolean) => setVisitorUsageTracked(consent);

const container = document.getElementById('root');
const root = createRoot(container);
Expand Down Expand Up @@ -98,6 +107,10 @@ const HomeLink = styled(Link)`
path="/embedded-msgs-impression-tracker"
element={<EmbeddedMsgsImpressionTracker />}
/>
<Route
path="/aut-testing"
element={<AUTTesting setConsent={handleConsent} />}
/>
</Routes>
</RouteWrapper>
</UserProvider>
Expand Down
100 changes: 100 additions & 0 deletions react-example/src/indexWithoutJWT.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,100 @@
import { initializeWithConfig, WithoutJWTParams } from '@iterable/web-sdk';
import ReactDOM from 'react-dom';
import './styles/index.css';

import { BrowserRouter, Routes, Route } from 'react-router-dom';
import styled from 'styled-components';
import { Home } from './views/Home';
import { Commerce } from './views/Commerce';
import { Events } from './views/Events';
import { Users } from './views/Users';
import { InApp } from './views/InApp';
import LoginFormWithoutJWT from './components/LoginFormWithoutJWT';
import AUTTesting from './views/AUTTesting';
import { EmbeddedMsgs } from './views/EmbeddedMsgs';
import { EmbeddedMessage } from './views/Embedded';
import { EmbeddedMsgsImpressionTracker } from './views/EmbeddedMsgsImpressionTracker';
import { Link } from './components/Link';
import { UserProvider } from './context/Users';

const Wrapper = styled.div`
display: flex;
flex-flow: column;
`;

const RouteWrapper = styled.div`
width: 90%;
margin: 0 auto;
`;

const HeaderWrapper = styled.div`
display: flex;
flex-flow: row;
align-items: center;
justify-content: space-between;
margin: 1em;
`;

const HomeLink = styled(Link)`
width: 100px;
`;

((): void => {
// Here we are testing it using NON-JWT based project.
const initializeParams: WithoutJWTParams = {
authToken: process.env.API_KEY || '',
configOptions: {
isEuIterableService: false,
dangerouslyAllowJsPopups: true,
enableAnonActivation: true,
onAnonUserCreated: (userId: string) => {
console.log('onAnonUserCreated', userId);
}
}
};

const { setUserID, logout, setEmail, setVisitorUsageTracked } =
initializeWithConfig(initializeParams);

const handleConsent = (consent?: boolean) => setVisitorUsageTracked(consent);

// eslint-disable-next-line react/no-deprecated
ReactDOM.render(
<BrowserRouter>
<Wrapper>
<UserProvider>
<HeaderWrapper>
<HomeLink renderAsButton to="/">
Home
</HomeLink>
<LoginFormWithoutJWT
setEmail={setEmail}
setUserId={setUserID}
logout={logout}
/>
</HeaderWrapper>
<RouteWrapper>
<Routes>
<Route path="/" element={<Home />} />
<Route path="/commerce" element={<Commerce />} />
<Route path="/events" element={<Events />} />
<Route path="/users" element={<Users />} />
<Route path="/inApp" element={<InApp />} />
<Route path="/embedded-msgs" element={<EmbeddedMsgs />} />
<Route path="/embedded" element={<EmbeddedMessage />} />
<Route
path="/embedded-msgs-impression-tracker"
element={<EmbeddedMsgsImpressionTracker />}
/>
<Route
path="/aut-testing"
element={<AUTTesting setConsent={handleConsent} />}
/>
</Routes>
</RouteWrapper>
</UserProvider>
</Wrapper>
</BrowserRouter>,
document.getElementById('root')
);
})();
Loading