data:image/s3,"s3://crabby-images/7e228/7e2287ba60e21dee87416ea9983ec241b5307ec2" alt="vlt Launches "reproduce": A New Tool Challenging the Limits of Package Provenance"
Security News
vlt Launches "reproduce": A New Tool Challenging the Limits of Package Provenance
vlt's new "reproduce" tool verifies npm packages against their source code, outperforming traditional provenance adoption in the JavaScript ecosystem.
coveo.analytics
Advanced tools
This project provides 2 ways to interact with the the Coveo Usage Analytics service.
This JavaScript client project provides a code snippet that website administrators can easily add to website pages to track pageview
events. The pageview
events are stored in a Coveo Usage Analytics table which content currently cannot be viewed in Usage Analytics reports and the visit browser to prevent performance degradation.
Initially, the pageview
events data will be used exclusively by the Coveo Reveal Recommendations feature (see Recommendations Feature). It is recommended that you start pushing pageview
events to the Coveo Usage Analytics service as soon as possible so that you get relevant items recommended.
Note: This Coveo code snippet is similar to the Google analytics one (analytics.js).
You need a Coveo Cloud API key that has the permission to write to the Usage Analytics service.
For Coveo Cloud V1, contact Coveo Support and ask to create an API key with the Write UA scope.
For Coveo Cloud V2, create an API key from the [administration console] (https://platform.cloud.coveo.com/admin/#/organization/api-access/) selecting the Edit check box for the Analytics data privilege (see API Access - Page).
Ask an administrator to add a code snippet like the following to all pages of your websites:
<script>
(function(c,o,v,e,O,u,a){
a='coveoua';c[a]=c[a]||function(){(c[a].q=c[a].q|| []).push(arguments)};
c[a].t=Date.now();u=o.createElement(v);u.async=1;u.src=e;
O=o.getElementsByTagName(v)[0];O.parentNode.insertBefore(u,O)
})(window,document,'script','https://static.cloud.coveo.com/coveo.analytics.js/1.0/coveoua.js')
coveoua('init', 'YOUR_API_KEY'); // Replace YOUR_API_KEY with your real key
coveoua('send', 'view', {
contentIdKey: '@permanentid',
contentIdValue: 'PERMANENT_ID_VALUE', // Replace PERMANENT_ID_VALUE with a unique value from your page.
contentType: 'product' // Optional
// ... more information ...
});
</script>
Make sure you replace YOUR_API_KEY
by the API key you got in the previous step.
The code snippet must contain contentIdKey
and contentIdValue
in order to identify items in the Coveo index. When you want to recommend specific types of content, you also need to add a contentType
parameter value.
Key | Value |
---|---|
contentIdKey | The Coveo index field name that will be used to identify the item. |
contentIdValue | The Coveo index field value that will be used to identify the item. |
contentType | [Optional] The type of the item to be tracked (e.g., 'Article'). |
Note: Do not copy the_ coveoua.js
_file as it can be updated anytime and you could experience compatibility issues.
a. In a web browser such as Chrome, navigate to a website page to which you added the code snippet.
b. In the browser developer tool, go the the Network tab.
c. Reload the page, in the Name panel, ensure that you see a view event sent to Coveo analytics.
Add the code snippet to all your website pages.
<script>
(function(c,o,v,e,O,u,a){
a='coveoua';c[a]=c[a]||function(){(c[a].q=c[a].q|| []).push(arguments)};
c[a].t=Date.now();u=o.createElement(v);u.async=1;u.src=e;
O=o.getElementsByTagName(v)[0];O.parentNode.insertBefore(u,O)
})(window,document,'script','https://static.cloud.coveo.com/coveo.analytics.js/1.0/coveoua.js')
coveoua('init', 'YOUR_API_KEY'); // Replace YOUR_API_KEY with your real key
</script>
You can now call the script using the following line:
coveoua('send', 'click', {
...
});
Refer to the Usage Analytics Write API section to see what types of events are supported and what payload you need to send.
You have to provide your own fetch
API compatible libraries in the global environment (see Isomorphic TypeScript, fetch, promises, ava and coverage).
npm install coveo.analytics isomorphic-fetch
import fetch from 'isomorphic-fetch'; // isomorphic-fetch modifies the global environment
import coveoanalytics from 'coveo.analytics';
// Create an API client
const client = new coveoanalytics.analytics.Client({ token : 'YOUR_API_KEY'})
// Send your event
client.sendCustomEvent({
eventType: "dog",
eventValue: "Hello! Yes! This is Dog!"
});
There are 3 available storage you can use to store view events client side.
Cookie storage, which supports top level domain storage. This means that events from a.foo.com will be available from b.foo.com. Cookies have the limitation of not being able to store a lot of data, especially if your page view that are stored are long.
Local storage, which allows to store much more information client side, but has the drawback of not being able to acess data across multiple top level domain.
Session storage, which has roughly the same limitation and capability as Local storage, except that it is cleared when the web browser tab is closed.
By default, the local storage option will automatically be chosen as the default storage, unless specified manually.
git clone
npm install
npm run build
# code code code
npm run test
# open pull request
MIT license (see LICENSE).
FAQs
π Coveo analytics client (node and browser compatible)
The npm package coveo.analytics receives a total of 14,433 weekly downloads. As such, coveo.analytics popularity was classified as popular.
We found that coveo.analytics demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago.Β It has 16 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
vlt's new "reproduce" tool verifies npm packages against their source code, outperforming traditional provenance adoption in the JavaScript ecosystem.
Research
Security News
Socket researchers uncovered a malicious PyPI package exploiting Deezerβs API to enable coordinated music piracy through API abuse and C2 server control.
Research
The Socket Research Team discovered a malicious npm package, '@ton-wallet/create', stealing cryptocurrency wallet keys from developers and users in the TON ecosystem.