Secure Identify Requests
To enhance the security of the Canny SDK, provide a user-specific hash in your request that allows Canny to verify that the authentication request came from your application.
1. Generate user hash on your server
NoteYou can find your secret API key in your company settings. This key is secret! Store it on your server and don't share it.
Node.jsC#GoJavaPHPPythonRubyimport crypto from 'crypto'; const APIKey = 'YOUR_API_KEY'; export default function generateCannyHash(user) { const hash = crypto.createHmac('sha256', APIKey) .update(user.id) .digest('hex'); return hash; }
2. Send user hash to Canny when identifying users
Canny('identify', { appID: 'YOUR_APP_ID', user: { created: new Date(viewer.created).toISOString(), // optional email: viewer.email, id: viewer.id, name: viewer.name, }, hash: viewer.userGeneratedHash, });
3. Enable setting in your company security settings
Once enabled, any requests without valid hashes will be rejected, ensuring that only verified users can authenticate. This blocks malicious actors from impersonating your users.
4. Verify that your identify request works as expected
Trigger the identify request by visiting your app and use your browser's dev tools to ensure that the Canny SDK isn't showing any errors in the console. If you see a "Canny: Skipping identify request" message, try clearing your site data or using a private/incognito window. If you run into an error that you can't figure out, contact us