Skip to main content
GET
/
users
/
{userId}
/
analytics
cURL
curl --request GET \
  --url https://www.greenflash.ai/api/v1/users/{userId}/analytics \
  --header 'Authorization: Bearer <token>'
{
  "averageSentiment": {
    "label": "neutral",
    "score": 0.05
  },
  "averageFrustration": {
    "label": "moderate",
    "score": 0.38
  },
  "averageStruggle": {
    "label": "low",
    "score": 0.2
  },
  "conversationCount": 47,
  "averageQualityIndex": 6.8,
  "topTopics": [
    {
      "name": "billing",
      "count": 15
    },
    {
      "name": "account access",
      "count": 12
    },
    {
      "name": "feature questions",
      "count": 8
    }
  ],
  "lastConversationAt": "2025-10-14T16:22:00Z"
}

Authorizations

Authorization
string
header
required

Bearer authentication header of the form Bearer <token>, where <token> is your auth token.

Path Parameters

userId
string<uuid>
required

The user ID to get analytics for

Query Parameters

mode
enum<string>
default:insights

Analysis mode: "simple" returns only numeric aggregates (no rate limiting), "insights" includes topics, keywords, and recommendations (rate limited per tenant plan).

Available options:
simple,
insights
productId
string<uuid>

Filter analytics by product ID.

versionId
string<uuid>

Filter analytics by version ID.

Response

User analytics retrieved

averageUserSentiment
object
required

Average sentiment across all conversations.

averageChangeInUserSentiment
object
required

Distribution of sentiment changes.

averageFrustration
object
required

Average frustration level.

averageStruggle
object
required

Average struggle level.

averageCommercialIntent
object
required

Average commercial intent.

averageConversationRating
number | null
required

Average conversation rating.

averageConversationQualityIndex
number | null
required

Average conversation quality index.

summary
object
required

Structured participant profile summary.

totalConversations
number
required

Total number of conversations analyzed.

topics
object[]

Topics discussed (insights mode only).

keywords
object[]

Keywords extracted (insights mode only).