Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
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
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@appbaseio/analytics",
"version": "1.1.1",
"version": "1.2.0-alpha.1",
"description": "Universal analytics library for appbase.io apps",
"main": "dist/@appbaseio/analytics.cjs.js",
"jsnext:main": "dist/@appbaseio/analytics.es.js",
Expand Down
49 changes: 49 additions & 0 deletions src/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -116,6 +116,13 @@ type ConversionRequestBody = {
meta?: Object
};

type UsefulnessConfig = {
useful: boolean,
reason?: string,
userID?: string,
meta?: Object
};

type CallBack = (err: any, res: any) => void;

type Metrics = {
Expand Down Expand Up @@ -149,6 +156,12 @@ type Metrics = {
body?: Object,
queryParams?: Object,
callback?: CallBack
) => void,
// Save session's usefulness
saveSessionUsefulness?: (
aiSessionId: string,
usefulnessConfig: UsefulnessConfig,
callback?: CallBack
) => void
};

Expand Down Expand Up @@ -394,6 +407,42 @@ function initClient(config: AnalyticsConfig = {}) {
// get queryID
metrics.getQueryID = () => metrics.queryID;

// Save session's usefulness
metrics.saveSessionUsefulness = (
aiSessionId: string,
usefulnessConfig: {
useful: boolean,
reason?: string,
userID?: string,
meta?: Object
},
callback?: CallBack
) => {
if (typeof aiSessionId !== 'string' || aiSessionId === '') {
throw new Error('appbase-analytics: AISessionId is required');
}
if (typeof usefulnessConfig.useful !== 'boolean') {
throw new Error(
'appbase-analytics: useful property is required and must be a boolean'
);
}

const requestBody = {
useful: usefulnessConfig.useful,
reason: usefulnessConfig.reason,
user_id: usefulnessConfig.userID,
meta: usefulnessConfig.meta
};

metrics._request(
'PUT',
`_ai/${aiSessionId}/analytics`,
requestBody,
null,
callback
);
};

return metrics;
}

Expand Down
37 changes: 37 additions & 0 deletions src/index.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -341,3 +341,40 @@ describe('favorite', () => {
);
});
});
describe('saveSessionUsefulness', () => {
test("should save session's usefulness", done => {
// Note: Chagne credentials or sessionId incase
// the test case fails
var aa = AppbaseAnalytics.init({
index,
credentials: 'a03a1cb71321:75b6603d-9456-4a5a-af6b-a487b309eb61',
url: URL
});
// Save session usefulness
aa.saveSessionUsefulness(
'nt3f6nuE7QHoEWB6JCX5Z6',
{
useful: true,
reason: 'The AI provided accurate information.',
userID: 'john_doe',
meta: {
platform: 'windows'
}
},
(err, res) => {
if (err) {
console.error(err);
expect(true).toBe(false);
done();
} else if (res && res.status === 401) {
console.error('401: Credentials no allowed to access AI');
expect(false).toBe(true);
done();
} else if (res && res.status === 200) {
expect(true).toBe(true);
done();
}
}
);
});
});