NeahNew/.next/server/app/api/rocket-chat/messages/route.js
2025-05-03 14:17:46 +02:00

243 lines
85 KiB
JavaScript

/*
* ATTENTION: An "eval-source-map" devtool has been used.
* This devtool is neither made for production nor for readable output files.
* It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools.
* If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
* or disable the default devtool with "devtool: false".
* If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
*/
(() => {
var exports = {};
exports.id = "app/api/rocket-chat/messages/route";
exports.ids = ["app/api/rocket-chat/messages/route"];
exports.modules = {
/***/ "(rsc)/./app/api/auth/[...nextauth]/route.ts":
/*!*********************************************!*\
!*** ./app/api/auth/[...nextauth]/route.ts ***!
\*********************************************/
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ GET: () => (/* binding */ handler),\n/* harmony export */ POST: () => (/* binding */ handler),\n/* harmony export */ authOptions: () => (/* binding */ authOptions)\n/* harmony export */ });\n/* harmony import */ var next_auth__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! next-auth */ \"(rsc)/./node_modules/next-auth/index.js\");\n/* harmony import */ var next_auth__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(next_auth__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var next_auth_providers_keycloak__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! next-auth/providers/keycloak */ \"(rsc)/./node_modules/next-auth/providers/keycloak.js\");\n/* harmony import */ var jwt_decode__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! jwt-decode */ \"(rsc)/./node_modules/jwt-decode/build/esm/index.js\");\n\n\n\nfunction getRequiredEnvVar(name) {\n const value = process.env[name];\n if (!value) {\n throw new Error(`Missing required environment variable: ${name}`);\n }\n return value;\n}\nasync function refreshAccessToken(token) {\n try {\n const response = await fetch(`${process.env.KEYCLOAK_ISSUER}/protocol/openid-connect/token`, {\n headers: {\n \"Content-Type\": \"application/x-www-form-urlencoded\"\n },\n body: new URLSearchParams({\n client_id: process.env.KEYCLOAK_CLIENT_ID,\n client_secret: process.env.KEYCLOAK_CLIENT_SECRET,\n grant_type: \"refresh_token\",\n refresh_token: token.refreshToken\n }),\n method: \"POST\"\n });\n const refreshedTokens = await response.json();\n if (!response.ok) {\n throw refreshedTokens;\n }\n return {\n ...token,\n accessToken: refreshedTokens.access_token,\n refreshToken: refreshedTokens.refresh_token ?? token.refreshToken,\n accessTokenExpires: Date.now() + refreshedTokens.expires_in * 1000\n };\n } catch (error) {\n console.error(\"Error refreshing access token:\", error);\n return {\n ...token,\n error: \"RefreshAccessTokenError\"\n };\n }\n}\nconst authOptions = {\n providers: [\n (0,next_auth_providers_keycloak__WEBPACK_IMPORTED_MODULE_1__[\"default\"])({\n clientId: getRequiredEnvVar(\"KEYCLOAK_CLIENT_ID\"),\n clientSecret: getRequiredEnvVar(\"KEYCLOAK_CLIENT_SECRET\"),\n issuer: getRequiredEnvVar(\"KEYCLOAK_ISSUER\"),\n authorization: {\n params: {\n scope: \"openid profile email roles\"\n }\n },\n profile (profile) {\n console.log('Keycloak profile callback:', {\n rawProfile: profile,\n rawRoles: profile.roles,\n realmAccess: profile.realm_access,\n groups: profile.groups\n });\n // Get roles from realm_access\n const roles = profile.realm_access?.roles || [];\n console.log('Profile callback raw roles:', roles);\n // Clean up roles by removing ROLE_ prefix and converting to lowercase\n const cleanRoles = roles.map((role)=>role.replace(/^ROLE_/, '').toLowerCase());\n console.log('Profile callback cleaned roles:', cleanRoles);\n return {\n id: profile.sub,\n name: profile.name ?? profile.preferred_username,\n email: profile.email,\n first_name: profile.given_name ?? '',\n last_name: profile.family_name ?? '',\n username: profile.preferred_username ?? profile.email?.split('@')[0] ?? '',\n role: cleanRoles\n };\n }\n })\n ],\n session: {\n strategy: \"jwt\",\n maxAge: 30 * 24 * 60 * 60\n },\n callbacks: {\n async jwt ({ token, account, profile }) {\n if (account && profile) {\n const keycloakProfile = profile;\n const roles = keycloakProfile.realm_access?.roles || [];\n const cleanRoles = roles.map((role)=>role.replace(/^ROLE_/, '').toLowerCase());\n token.accessToken = account.access_token ?? '';\n token.refreshToken = account.refresh_token ?? '';\n token.accessTokenExpires = account.expires_at ?? 0;\n token.sub = keycloakProfile.sub;\n token.role = cleanRoles;\n token.username = keycloakProfile.preferred_username ?? '';\n token.first_name = keycloakProfile.given_name ?? '';\n token.last_name = keycloakProfile.family_name ?? '';\n } else if (token.accessToken) {\n try {\n const decoded = (0,jwt_decode__WEBPACK_IMPORTED_MODULE_2__.jwtDecode)(token.accessToken);\n if (decoded.realm_access?.roles) {\n const roles = decoded.realm_access.roles;\n const cleanRoles = roles.map((role)=>role.replace(/^ROLE_/, '').toLowerCase());\n token.role = cleanRoles;\n }\n } catch (error) {\n console.error('Error decoding token:', error);\n }\n }\n if (Date.now() < token.accessTokenExpires * 1000) {\n return token;\n }\n return refreshAccessToken(token);\n },\n async session ({ session, token }) {\n if (token.error) {\n throw new Error(token.error);\n }\n const userRoles = Array.isArray(token.role) ? token.role : [];\n session.user = {\n id: token.sub ?? '',\n email: token.email ?? null,\n name: token.name ?? null,\n image: null,\n username: token.username ?? '',\n first_name: token.first_name ?? '',\n last_name: token.last_name ?? '',\n role: userRoles,\n nextcloudInitialized: false\n };\n session.accessToken = token.accessToken;\n return session;\n }\n },\n pages: {\n signIn: '/signin',\n error: '/signin'\n },\n debug: \"development\" === 'development'\n};\nconst handler = next_auth__WEBPACK_IMPORTED_MODULE_0___default()(authOptions);\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(rsc)/./app/api/auth/[...nextauth]/route.ts","mappings":"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","sources":["/home/alma/nextgen/Neah-mail/app/api/auth/[...nextauth]/route.ts"],"sourcesContent":["import NextAuth, { NextAuthOptions } from \"next-auth\";\nimport KeycloakProvider from \"next-auth/providers/keycloak\";\nimport { jwtDecode } from \"jwt-decode\";\n\ninterface KeycloakProfile {\n  sub: string;\n  email?: string;\n  name?: string;\n  roles?: string[];\n  preferred_username?: string;\n  given_name?: string;\n  family_name?: string;\n  realm_access?: {\n    roles: string[];\n  };\n}\n\ninterface DecodedToken {\n  realm_access?: {\n    roles: string[];\n  };\n  [key: string]: any;\n}\n\ndeclare module \"next-auth\" {\n  interface Session {\n    user: {\n      id: string;\n      name?: string | null;\n      email?: string | null;\n      image?: string | null;\n      username: string;\n      first_name: string;\n      last_name: string;\n      role: string[];\n      nextcloudInitialized?: boolean;\n    };\n    accessToken?: string;\n  }\n\n  interface JWT {\n    sub?: string;\n    accessToken?: string;\n    refreshToken?: string;\n    accessTokenExpires?: number;\n    role?: string[];\n    username?: string;\n    first_name?: string;\n    last_name?: string;\n    error?: string;\n    email?: string | null;\n    name?: string | null;\n  }\n}\n\nfunction getRequiredEnvVar(name: string): string {\n  const value = process.env[name];\n  if (!value) {\n    throw new Error(`Missing required environment variable: ${name}`);\n  }\n  return value;\n}\n\nasync function refreshAccessToken(token: JWT) {\n  try {\n    const response = await fetch(`${process.env.KEYCLOAK_ISSUER}/protocol/openid-connect/token`, {\n      headers: { \"Content-Type\": \"application/x-www-form-urlencoded\" },\n      body: new URLSearchParams({\n        client_id: process.env.KEYCLOAK_CLIENT_ID!,\n        client_secret: process.env.KEYCLOAK_CLIENT_SECRET!,\n        grant_type: \"refresh_token\",\n        refresh_token: token.refreshToken,\n      }),\n      method: \"POST\",\n    });\n\n    const refreshedTokens = await response.json();\n\n    if (!response.ok) {\n      throw refreshedTokens;\n    }\n\n    return {\n      ...token,\n      accessToken: refreshedTokens.access_token,\n      refreshToken: refreshedTokens.refresh_token ?? token.refreshToken,\n      accessTokenExpires: Date.now() + refreshedTokens.expires_in * 1000,\n    };\n  } catch (error) {\n    console.error(\"Error refreshing access token:\", error);\n    return {\n      ...token,\n      error: \"RefreshAccessTokenError\",\n    };\n  }\n}\n\nexport const authOptions: NextAuthOptions = {\n  providers: [\n    KeycloakProvider({\n      clientId: getRequiredEnvVar(\"KEYCLOAK_CLIENT_ID\"),\n      clientSecret: getRequiredEnvVar(\"KEYCLOAK_CLIENT_SECRET\"),\n      issuer: getRequiredEnvVar(\"KEYCLOAK_ISSUER\"),\n      authorization: {\n        params: {\n          scope: \"openid profile email roles\"\n        }\n      },\n      profile(profile) {\n        console.log('Keycloak profile callback:', {\n          rawProfile: profile,\n          rawRoles: profile.roles,\n          realmAccess: profile.realm_access,\n          groups: profile.groups\n        });\n\n        // Get roles from realm_access\n        const roles = profile.realm_access?.roles || [];\n        console.log('Profile callback raw roles:', roles);\n\n        // Clean up roles by removing ROLE_ prefix and converting to lowercase\n        const cleanRoles = roles.map((role: string) => \n          role.replace(/^ROLE_/, '').toLowerCase()\n        );\n\n        console.log('Profile callback cleaned roles:', cleanRoles);\n\n        return {\n          id: profile.sub,\n          name: profile.name ?? profile.preferred_username,\n          email: profile.email,\n          first_name: profile.given_name ?? '',\n          last_name: profile.family_name ?? '',\n          username: profile.preferred_username ?? profile.email?.split('@')[0] ?? '',\n          role: cleanRoles,\n        }\n      },\n    }),\n  ],\n  session: {\n    strategy: \"jwt\",\n    maxAge: 30 * 24 * 60 * 60, // 30 days\n  },\n  callbacks: {\n    async jwt({ token, account, profile }) {\n      if (account && profile) {\n        const keycloakProfile = profile as KeycloakProfile;\n        const roles = keycloakProfile.realm_access?.roles || [];\n        const cleanRoles = roles.map((role: string) => \n          role.replace(/^ROLE_/, '').toLowerCase()\n        );\n\n        token.accessToken = account.access_token ?? '';\n        token.refreshToken = account.refresh_token ?? '';\n        token.accessTokenExpires = account.expires_at ?? 0;\n        token.sub = keycloakProfile.sub;\n        token.role = cleanRoles;\n        token.username = keycloakProfile.preferred_username ?? '';\n        token.first_name = keycloakProfile.given_name ?? '';\n        token.last_name = keycloakProfile.family_name ?? '';\n      } else if (token.accessToken) {\n        try {\n          const decoded = jwtDecode<DecodedToken>(token.accessToken);\n          if (decoded.realm_access?.roles) {\n            const roles = decoded.realm_access.roles;\n            const cleanRoles = roles.map((role: string) => \n              role.replace(/^ROLE_/, '').toLowerCase()\n            );\n            token.role = cleanRoles;\n          }\n        } catch (error) {\n          console.error('Error decoding token:', error);\n        }\n      }\n\n      if (Date.now() < (token.accessTokenExpires as number) * 1000) {\n        return token;\n      }\n\n      return refreshAccessToken(token);\n    },\n    async session({ session, token }) {\n      if (token.error) {\n        throw new Error(token.error);\n      }\n\n      const userRoles = Array.isArray(token.role) ? token.role : [];\n      session.user = {\n        id: token.sub ?? '',\n        email: token.email ?? null,\n        name: token.name ?? null,\n        image: null,\n        username: token.username ?? '',\n        first_name: token.first_name ?? '',\n        last_name: token.last_name ?? '',\n        role: userRoles,\n        nextcloudInitialized: false,\n      };\n      session.accessToken = token.accessToken;\n\n      return session;\n    }\n  },\n  pages: {\n    signIn: '/signin',\n    error: '/signin',\n  },\n  debug: process.env.NODE_ENV === 'development',\n};\n\nconst handler = NextAuth(authOptions);\nexport { handler as GET, handler as POST };\n\ninterface JWT {\n  accessToken: string;\n  refreshToken: string;\n  accessTokenExpires: number;\n}\n\ninterface Profile {\n  sub?: string;\n  email?: string;\n  name?: string;\n  roles?: string[];\n}\n\n"],"names":["NextAuth","KeycloakProvider","jwtDecode","getRequiredEnvVar","name","value","process","env","Error","refreshAccessToken","token","response","fetch","KEYCLOAK_ISSUER","headers","body","URLSearchParams","client_id","KEYCLOAK_CLIENT_ID","client_secret","KEYCLOAK_CLIENT_SECRET","grant_type","refresh_token","refreshToken","method","refreshedTokens","json","ok","accessToken","access_token","accessTokenExpires","Date","now","expires_in","error","console","authOptions","providers","clientId","clientSecret","issuer","authorization","params","scope","profile","log","rawProfile","rawRoles","roles","realmAccess","realm_access","groups","cleanRoles","map","role","replace","toLowerCase","id","sub","preferred_username","email","first_name","given_name","last_name","family_name","username","split","session","strategy","maxAge","callbacks","jwt","account","keycloakProfile","expires_at","decoded","userRoles","Array","isArray","user","image","nextcloudInitialized","pages","signIn","debug","handler","GET","POST"],"ignoreList":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(rsc)/./app/api/auth/[...nextauth]/route.ts\n");
/***/ }),
/***/ "(rsc)/./app/api/rocket-chat/messages/route.ts":
/*!***********************************************!*\
!*** ./app/api/rocket-chat/messages/route.ts ***!
\***********************************************/
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ GET: () => (/* binding */ GET)\n/* harmony export */ });\n/* harmony import */ var next_auth__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! next-auth */ \"(rsc)/./node_modules/next-auth/index.js\");\n/* harmony import */ var next_auth__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(next_auth__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _app_api_auth_nextauth_route__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @/app/api/auth/[...nextauth]/route */ \"(rsc)/./app/api/auth/[...nextauth]/route.ts\");\n/* harmony import */ var next_server__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! next/server */ \"(rsc)/./node_modules/next/dist/api/server.js\");\n\n\n\n// Helper function to get user token using admin credentials\nasync function getUserToken(baseUrl) {\n try {\n // Step 1: Use admin token to authenticate\n const adminHeaders = {\n 'X-Auth-Token': process.env.ROCKET_CHAT_TOKEN,\n 'X-User-Id': process.env.ROCKET_CHAT_USER_ID,\n 'Content-Type': 'application/json'\n };\n // Step 2: Create user token using admin credentials\n const createTokenResponse = await fetch(`${baseUrl}/api/v1/users.createToken`, {\n method: 'POST',\n headers: adminHeaders\n });\n if (!createTokenResponse.ok) {\n console.error('Failed to create user token:', createTokenResponse.status);\n return null;\n }\n const tokenData = await createTokenResponse.json();\n return {\n authToken: tokenData.data.authToken,\n userId: tokenData.data.userId\n };\n } catch (error) {\n console.error('Error getting user token:', error);\n return null;\n }\n}\nasync function GET(request) {\n try {\n const session = await (0,next_auth__WEBPACK_IMPORTED_MODULE_0__.getServerSession)(_app_api_auth_nextauth_route__WEBPACK_IMPORTED_MODULE_1__.authOptions);\n if (!session?.user?.email) {\n console.error('No valid session or email found');\n return next_server__WEBPACK_IMPORTED_MODULE_2__.NextResponse.json({\n messages: []\n }, {\n status: 200\n });\n }\n const baseUrl = \"https://parole.slm-lab.net/channel/City\"?.split('/channel')[0];\n if (!baseUrl) {\n console.error('Failed to get Rocket.Chat base URL');\n return next_server__WEBPACK_IMPORTED_MODULE_2__.NextResponse.json({\n error: 'Server configuration error'\n }, {\n status: 500\n });\n }\n console.log('Using Rocket.Chat base URL:', baseUrl);\n // Step 1: Use admin token to authenticate\n const adminHeaders = {\n 'X-Auth-Token': process.env.ROCKET_CHAT_TOKEN,\n 'X-User-Id': process.env.ROCKET_CHAT_USER_ID,\n 'Content-Type': 'application/json'\n };\n // Step 2: Get the current user's Rocket.Chat ID\n const username = session.user.email.split('@')[0];\n if (!username) {\n console.error('No username found in session email');\n return next_server__WEBPACK_IMPORTED_MODULE_2__.NextResponse.json({\n messages: []\n }, {\n status: 200\n });\n }\n // Get all users to find the current user\n const usersResponse = await fetch(`${baseUrl}/api/v1/users.list`, {\n method: 'GET',\n headers: adminHeaders\n });\n if (!usersResponse.ok) {\n console.error('Failed to get users list:', usersResponse.status);\n return next_server__WEBPACK_IMPORTED_MODULE_2__.NextResponse.json({\n messages: []\n }, {\n status: 200\n });\n }\n const usersData = await usersResponse.json();\n console.log('Users list response:', {\n success: usersData.success,\n count: usersData.count,\n usersCount: usersData.users?.length\n });\n // Find the current user in the list\n const currentUser = usersData.users.find((user)=>user.username === username || user.emails?.some((email)=>email.address === session.user.email));\n if (!currentUser) {\n console.error('User not found in users list');\n return next_server__WEBPACK_IMPORTED_MODULE_2__.NextResponse.json({\n messages: []\n }, {\n status: 200\n });\n }\n console.log('Found Rocket.Chat user:', {\n username: currentUser.username,\n id: currentUser._id\n });\n // Step 3: Create a token for the current user\n const createTokenResponse = await fetch(`${baseUrl}/api/v1/users.createToken`, {\n method: 'POST',\n headers: adminHeaders,\n body: JSON.stringify({\n userId: currentUser._id\n })\n });\n if (!createTokenResponse.ok) {\n console.error('Failed to create user token:', createTokenResponse.status);\n const errorText = await createTokenResponse.text();\n console.error('Create token error details:', errorText);\n return next_server__WEBPACK_IMPORTED_MODULE_2__.NextResponse.json({\n messages: []\n }, {\n status: 200\n });\n }\n const tokenData = await createTokenResponse.json();\n // Use the user's token for subsequent requests\n const userHeaders = {\n 'X-Auth-Token': tokenData.data.authToken,\n 'X-User-Id': currentUser._id,\n 'Content-Type': 'application/json'\n };\n // Step 4: Get user's subscriptions using user token\n const subscriptionsResponse = await fetch(`${baseUrl}/api/v1/subscriptions.get`, {\n method: 'GET',\n headers: userHeaders\n });\n if (!subscriptionsResponse.ok) {\n console.error('Failed to get subscriptions:', subscriptionsResponse.status);\n const errorText = await subscriptionsResponse.text();\n console.error('Subscriptions error details:', errorText);\n return next_server__WEBPACK_IMPORTED_MODULE_2__.NextResponse.json({\n messages: []\n }, {\n status: 200\n });\n }\n const subscriptionsData = await subscriptionsResponse.json();\n if (!subscriptionsData.success || !Array.isArray(subscriptionsData.update)) {\n console.error('Invalid subscriptions response structure');\n return next_server__WEBPACK_IMPORTED_MODULE_2__.NextResponse.json({\n messages: []\n }, {\n status: 200\n });\n }\n // Filter subscriptions for the current user\n const userSubscriptions = subscriptionsData.update.filter((sub)=>{\n // Only include rooms with unread messages or alerts\n if (!(sub.unread > 0 || sub.alert)) {\n return false;\n }\n // Include all types of rooms the user is subscribed to\n return [\n 'd',\n 'c',\n 'p'\n ].includes(sub.t);\n });\n console.log('Filtered user subscriptions:', {\n userId: currentUser._id,\n username: currentUser.username,\n totalSubscriptions: userSubscriptions.length,\n subscriptionDetails: userSubscriptions.map((sub)=>({\n type: sub.t,\n name: sub.fname || sub.name,\n rid: sub.rid,\n alert: sub.alert,\n unread: sub.unread,\n userMentions: sub.userMentions\n }))\n });\n const messages = [];\n const processedRooms = new Set();\n const latestMessagePerRoom = {};\n // Step 5: Fetch messages using user token\n for (const subscription of userSubscriptions){\n try {\n // Determine the correct endpoint and parameters based on room type\n let endpoint;\n switch(subscription.t){\n case 'c':\n endpoint = 'channels.messages';\n break;\n case 'p':\n endpoint = 'groups.messages';\n break;\n case 'd':\n endpoint = 'im.messages';\n break;\n default:\n continue;\n }\n const queryParams = new URLSearchParams({\n roomId: subscription.rid,\n count: String(Math.max(subscription.unread, 5)) // Fetch at least the number of unread messages\n });\n const messagesResponse = await fetch(`${baseUrl}/api/v1/${endpoint}?${queryParams}`, {\n method: 'GET',\n headers: userHeaders\n });\n if (!messagesResponse.ok) {\n console.error(`Failed to get messages for room ${subscription.name}:`, messagesResponse.status);\n continue;\n }\n const messageData = await messagesResponse.json();\n console.log(`Messages for room ${subscription.fname || subscription.name}:`, {\n success: messageData.success,\n count: messageData.count,\n hasMessages: messageData.messages?.length > 0\n });\n if (messageData.success && messageData.messages?.length > 0) {\n // Filter out system messages and join notifications for channels\n const validMessages = messageData.messages.filter((message)=>{\n // Skip messages sent by the current user\n if (message.u._id === currentUser._id) {\n return false;\n }\n // For channels, apply strict filtering\n if (subscription.t === 'c') {\n if (!message.msg || // No message text\n message.t || // System message\n !message.u || // No user info\n message.msg.includes('has joined the channel') || message.msg.includes('has left the channel') || message.msg.includes('added') || message.msg.includes('removed')) {\n return false;\n }\n }\n return true;\n });\n // Only process the latest valid message from this room\n if (validMessages.length > 0) {\n // Get the latest message (they should already be sorted by timestamp)\n const latestMessage = validMessages[0];\n const messageUser = latestMessage.u || {};\n const username = messageUser.username || 'unknown';\n // Skip if this is our own message (double-check)\n if (messageUser._id === currentUser._id) {\n continue;\n }\n // Get proper display names\n let roomDisplayName = subscription.fname || subscription.name;\n let userDisplayName = messageUser.name || username;\n // Handle call messages\n let messageText = latestMessage.msg || '';\n if (messageText.includes('started a call')) {\n messageText = '📞 Call received';\n }\n // Format timestamp\n const timestamp = new Date(latestMessage.ts);\n const now = new Date();\n let formattedTime = '';\n if (isNaN(timestamp.getTime())) {\n formattedTime = 'Invalid Date';\n } else if (timestamp.toDateString() === now.toDateString()) {\n formattedTime = timestamp.toLocaleTimeString('fr-FR', {\n hour: '2-digit',\n minute: '2-digit'\n });\n } else {\n formattedTime = timestamp.toLocaleDateString('fr-FR', {\n day: '2-digit',\n month: 'short'\n });\n }\n // Create initials for the sender\n const initials = userDisplayName.split(' ').map((n)=>n[0]).slice(0, 2).join('').toUpperCase();\n const processedMessage = {\n id: latestMessage._id,\n text: messageText,\n timestamp: formattedTime,\n rawTimestamp: latestMessage.ts,\n roomName: roomDisplayName,\n roomType: subscription.t,\n sender: {\n _id: messageUser._id,\n username: username,\n name: userDisplayName,\n initials: initials,\n color: getAvatarColor(username)\n },\n isOwnMessage: messageUser._id === currentUser._id,\n room: {\n id: subscription.rid,\n type: subscription.t,\n name: roomDisplayName,\n isChannel: subscription.t === 'c',\n isPrivateGroup: subscription.t === 'p',\n isDirect: subscription.t === 'd',\n link: `${baseUrl}/${subscription.t === 'd' ? 'direct' : subscription.t === 'p' ? 'group' : 'channel'}/${subscription.name}`,\n unread: subscription.unread,\n alert: subscription.alert,\n userMentions: subscription.userMentions\n }\n };\n // Store this message if it's the latest for this room\n if (!latestMessagePerRoom[subscription.rid] || new Date(latestMessage.ts).getTime() > new Date(latestMessagePerRoom[subscription.rid].rawTimestamp).getTime()) {\n latestMessagePerRoom[subscription.rid] = processedMessage;\n }\n }\n }\n } catch (error) {\n console.error(`Error fetching messages for room ${subscription.name}:`, error);\n continue;\n }\n }\n // Convert the latest messages object to an array and sort by timestamp\n const sortedMessages = Object.values(latestMessagePerRoom).sort((a, b)=>{\n const dateA = new Date(a.rawTimestamp);\n const dateB = new Date(b.rawTimestamp);\n return dateB.getTime() - dateA.getTime();\n }).slice(0, 10);\n return next_server__WEBPACK_IMPORTED_MODULE_2__.NextResponse.json({\n messages: sortedMessages,\n total: Object.keys(latestMessagePerRoom).length,\n hasMore: Object.keys(latestMessagePerRoom).length > 10\n }, {\n status: 200\n });\n } catch (error) {\n console.error('Error in messages endpoint:', error);\n return next_server__WEBPACK_IMPORTED_MODULE_2__.NextResponse.json({\n messages: [],\n total: 0,\n hasMore: false\n }, {\n status: 200\n });\n }\n}\n// Helper function to generate consistent avatar colors\nfunction getAvatarColor(username) {\n const colors = [\n '#FF7452',\n '#4CAF50',\n '#2196F3',\n '#9C27B0',\n '#FF9800',\n '#00BCD4',\n '#795548',\n '#607D8B' // Blue Grey\n ];\n // Generate a consistent index based on username\n const index = username.split('').reduce((acc, char)=>acc + char.charCodeAt(0), 0) % colors.length;\n return colors[index];\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(rsc)/./app/api/rocket-chat/messages/route.ts","mappings":"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","sources":["/home/alma/nextgen/Neah-mail/app/api/rocket-chat/messages/route.ts"],"sourcesContent":["import { getServerSession } from \"next-auth\";\nimport { authOptions } from \"@/app/api/auth/[...nextauth]/route\";\nimport { NextResponse } from \"next/server\";\n\n// Helper function to get user token using admin credentials\nasync function getUserToken(baseUrl: string) {\n  try {\n    // Step 1: Use admin token to authenticate\n    const adminHeaders = {\n      'X-Auth-Token': process.env.ROCKET_CHAT_TOKEN!,\n      'X-User-Id': process.env.ROCKET_CHAT_USER_ID!,\n      'Content-Type': 'application/json'\n    };\n\n    // Step 2: Create user token using admin credentials\n    const createTokenResponse = await fetch(`${baseUrl}/api/v1/users.createToken`, {\n      method: 'POST',\n      headers: adminHeaders\n    });\n\n    if (!createTokenResponse.ok) {\n      console.error('Failed to create user token:', createTokenResponse.status);\n      return null;\n    }\n\n    const tokenData = await createTokenResponse.json();\n    return {\n      authToken: tokenData.data.authToken,\n      userId: tokenData.data.userId\n    };\n  } catch (error) {\n    console.error('Error getting user token:', error);\n    return null;\n  }\n}\n\nexport async function GET(request: Request) {\n  try {\n    const session = await getServerSession(authOptions);\n    \n    if (!session?.user?.email) {\n      console.error('No valid session or email found');\n      return NextResponse.json({ messages: [] }, { status: 200 });\n    }\n\n    const baseUrl = process.env.NEXT_PUBLIC_IFRAME_PAROLE_URL?.split('/channel')[0];\n    if (!baseUrl) {\n      console.error('Failed to get Rocket.Chat base URL');\n      return NextResponse.json({ error: 'Server configuration error' }, { status: 500 });\n    }\n\n    console.log('Using Rocket.Chat base URL:', baseUrl);\n\n    // Step 1: Use admin token to authenticate\n    const adminHeaders = {\n      'X-Auth-Token': process.env.ROCKET_CHAT_TOKEN!,\n      'X-User-Id': process.env.ROCKET_CHAT_USER_ID!,\n      'Content-Type': 'application/json'\n    };\n\n    // Step 2: Get the current user's Rocket.Chat ID\n    const username = session.user.email.split('@')[0];\n    if (!username) {\n      console.error('No username found in session email');\n      return NextResponse.json({ messages: [] }, { status: 200 });\n    }\n\n    // Get all users to find the current user\n    const usersResponse = await fetch(`${baseUrl}/api/v1/users.list`, {\n      method: 'GET',\n      headers: adminHeaders\n    });\n\n    if (!usersResponse.ok) {\n      console.error('Failed to get users list:', usersResponse.status);\n      return NextResponse.json({ messages: [] }, { status: 200 });\n    }\n\n    const usersData = await usersResponse.json();\n    console.log('Users list response:', {\n      success: usersData.success,\n      count: usersData.count,\n      usersCount: usersData.users?.length\n    });\n\n    // Find the current user in the list\n    const currentUser = usersData.users.find((user: any) => \n      user.username === username || user.emails?.some((email: any) => email.address === session.user.email)\n    );\n\n    if (!currentUser) {\n      console.error('User not found in users list');\n      return NextResponse.json({ messages: [] }, { status: 200 });\n    }\n\n    console.log('Found Rocket.Chat user:', {\n      username: currentUser.username,\n      id: currentUser._id\n    });\n\n    // Step 3: Create a token for the current user\n    const createTokenResponse = await fetch(`${baseUrl}/api/v1/users.createToken`, {\n      method: 'POST',\n      headers: adminHeaders,\n      body: JSON.stringify({\n        userId: currentUser._id\n      })\n    });\n\n    if (!createTokenResponse.ok) {\n      console.error('Failed to create user token:', createTokenResponse.status);\n      const errorText = await createTokenResponse.text();\n      console.error('Create token error details:', errorText);\n      return NextResponse.json({ messages: [] }, { status: 200 });\n    }\n\n    const tokenData = await createTokenResponse.json();\n    \n    // Use the user's token for subsequent requests\n    const userHeaders = {\n      'X-Auth-Token': tokenData.data.authToken,\n      'X-User-Id': currentUser._id,\n      'Content-Type': 'application/json'\n    };\n\n    // Step 4: Get user's subscriptions using user token\n    const subscriptionsResponse = await fetch(`${baseUrl}/api/v1/subscriptions.get`, {\n      method: 'GET',\n      headers: userHeaders\n    });\n\n    if (!subscriptionsResponse.ok) {\n      console.error('Failed to get subscriptions:', subscriptionsResponse.status);\n      const errorText = await subscriptionsResponse.text();\n      console.error('Subscriptions error details:', errorText);\n      return NextResponse.json({ messages: [] }, { status: 200 });\n    }\n\n    const subscriptionsData = await subscriptionsResponse.json();\n\n    if (!subscriptionsData.success || !Array.isArray(subscriptionsData.update)) {\n      console.error('Invalid subscriptions response structure');\n      return NextResponse.json({ messages: [] }, { status: 200 });\n    }\n\n    // Filter subscriptions for the current user\n    const userSubscriptions = subscriptionsData.update.filter((sub: any) => {\n      // Only include rooms with unread messages or alerts\n      if (!(sub.unread > 0 || sub.alert)) {\n        return false;\n      }\n      // Include all types of rooms the user is subscribed to\n      return ['d', 'c', 'p'].includes(sub.t);\n    });\n\n    console.log('Filtered user subscriptions:', {\n      userId: currentUser._id,\n      username: currentUser.username,\n      totalSubscriptions: userSubscriptions.length,\n      subscriptionDetails: userSubscriptions.map((sub: any) => ({\n        type: sub.t,\n        name: sub.fname || sub.name,\n        rid: sub.rid,\n        alert: sub.alert,\n        unread: sub.unread,\n        userMentions: sub.userMentions\n      }))\n    });\n\n    const messages: any[] = [];\n    const processedRooms = new Set();\n    const latestMessagePerRoom: { [key: string]: any } = {};\n\n    // Step 5: Fetch messages using user token\n    for (const subscription of userSubscriptions) {\n      try {\n        // Determine the correct endpoint and parameters based on room type\n        let endpoint;\n        switch (subscription.t) {\n          case 'c':\n            endpoint = 'channels.messages';\n            break;\n          case 'p':\n            endpoint = 'groups.messages';\n            break;\n          case 'd':\n            endpoint = 'im.messages';\n            break;\n          default:\n            continue;\n        }\n\n        const queryParams = new URLSearchParams({\n          roomId: subscription.rid,\n          count: String(Math.max(subscription.unread, 5))  // Fetch at least the number of unread messages\n        });\n        \n        const messagesResponse = await fetch(\n          `${baseUrl}/api/v1/${endpoint}?${queryParams}`, {\n            method: 'GET',\n            headers: userHeaders\n          }\n        );\n\n        if (!messagesResponse.ok) {\n          console.error(`Failed to get messages for room ${subscription.name}:`, messagesResponse.status);\n          continue;\n        }\n\n        const messageData = await messagesResponse.json();\n        console.log(`Messages for room ${subscription.fname || subscription.name}:`, {\n          success: messageData.success,\n          count: messageData.count,\n          hasMessages: messageData.messages?.length > 0\n        });\n\n        if (messageData.success && messageData.messages?.length > 0) {\n          // Filter out system messages and join notifications for channels\n          const validMessages = messageData.messages.filter((message: any) => {\n            // Skip messages sent by the current user\n            if (message.u._id === currentUser._id) {\n              return false;\n            }\n\n            // For channels, apply strict filtering\n            if (subscription.t === 'c') {\n              if (!message.msg || // No message text\n                  message.t || // System message\n                  !message.u || // No user info\n                  message.msg.includes('has joined the channel') ||\n                  message.msg.includes('has left the channel') ||\n                  message.msg.includes('added') ||\n                  message.msg.includes('removed')) {\n                return false;\n              }\n            }\n            return true;\n          });\n\n          // Only process the latest valid message from this room\n          if (validMessages.length > 0) {\n            // Get the latest message (they should already be sorted by timestamp)\n            const latestMessage = validMessages[0];\n            const messageUser = latestMessage.u || {};\n            const username = messageUser.username || 'unknown';\n            \n            // Skip if this is our own message (double-check)\n            if (messageUser._id === currentUser._id) {\n              continue;\n            }\n            \n            // Get proper display names\n            let roomDisplayName = subscription.fname || subscription.name;\n            let userDisplayName = messageUser.name || username;\n            \n            // Handle call messages\n            let messageText = latestMessage.msg || '';\n            if (messageText.includes('started a call')) {\n              messageText = '📞 Call received';\n            }\n            \n            // Format timestamp\n            const timestamp = new Date(latestMessage.ts);\n            const now = new Date();\n            let formattedTime = '';\n            \n            if (isNaN(timestamp.getTime())) {\n              formattedTime = 'Invalid Date';\n            } else if (timestamp.toDateString() === now.toDateString()) {\n              formattedTime = timestamp.toLocaleTimeString('fr-FR', { \n                hour: '2-digit', \n                minute: '2-digit' \n              });\n            } else {\n              formattedTime = timestamp.toLocaleDateString('fr-FR', {\n                day: '2-digit',\n                month: 'short'\n              });\n            }\n\n            // Create initials for the sender\n            const initials = userDisplayName\n              .split(' ')\n              .map((n: string) => n[0])\n              .slice(0, 2)\n              .join('')\n              .toUpperCase();\n\n            const processedMessage = {\n              id: latestMessage._id,\n              text: messageText,\n              timestamp: formattedTime,\n              rawTimestamp: latestMessage.ts,\n              roomName: roomDisplayName,\n              roomType: subscription.t,\n              sender: {\n                _id: messageUser._id,\n                username: username,\n                name: userDisplayName,\n                initials: initials,\n                color: getAvatarColor(username)\n              },\n              isOwnMessage: messageUser._id === currentUser._id,\n              room: {\n                id: subscription.rid,\n                type: subscription.t,\n                name: roomDisplayName,\n                isChannel: subscription.t === 'c',\n                isPrivateGroup: subscription.t === 'p',\n                isDirect: subscription.t === 'd',\n                link: `${baseUrl}/${subscription.t === 'd' ? 'direct' : subscription.t === 'p' ? 'group' : 'channel'}/${subscription.name}`,\n                unread: subscription.unread,\n                alert: subscription.alert,\n                userMentions: subscription.userMentions\n              }\n            };\n\n            // Store this message if it's the latest for this room\n            if (!latestMessagePerRoom[subscription.rid] || \n                new Date(latestMessage.ts).getTime() > new Date(latestMessagePerRoom[subscription.rid].rawTimestamp).getTime()) {\n              latestMessagePerRoom[subscription.rid] = processedMessage;\n            }\n          }\n        }\n      } catch (error) {\n        console.error(`Error fetching messages for room ${subscription.name}:`, error);\n        continue;\n      }\n    }\n\n    // Convert the latest messages object to an array and sort by timestamp\n    const sortedMessages = Object.values(latestMessagePerRoom)\n      .sort((a, b) => {\n        const dateA = new Date(a.rawTimestamp);\n        const dateB = new Date(b.rawTimestamp);\n        return dateB.getTime() - dateA.getTime();\n      })\n      .slice(0, 10);\n\n    return NextResponse.json({\n      messages: sortedMessages,\n      total: Object.keys(latestMessagePerRoom).length,\n      hasMore: Object.keys(latestMessagePerRoom).length > 10\n    }, { status: 200 });\n  } catch (error) {\n    console.error('Error in messages endpoint:', error);\n    return NextResponse.json({ messages: [], total: 0, hasMore: false }, { status: 200 });\n  }\n}\n\n// Helper function to generate consistent avatar colors\nfunction getAvatarColor(username: string): string {\n  const colors = [\n    '#FF7452', // Coral\n    '#4CAF50', // Green\n    '#2196F3', // Blue\n    '#9C27B0', // Purple\n    '#FF9800', // Orange\n    '#00BCD4', // Cyan\n    '#795548', // Brown\n    '#607D8B'  // Blue Grey\n  ];\n  \n  // Generate a consistent index based on username\n  const index = username\n    .split('')\n    .reduce((acc, char) => acc + char.charCodeAt(0), 0) % colors.length;\n  \n  return colors[index];\n} "],"names":["getServerSession","authOptions","NextResponse","getUserToken","baseUrl","adminHeaders","process","env","ROCKET_CHAT_TOKEN","ROCKET_CHAT_USER_ID","createTokenResponse","fetch","method","headers","ok","console","error","status","tokenData","json","authToken","data","userId","GET","request","session","user","email","messages","NEXT_PUBLIC_IFRAME_PAROLE_URL","split","log","username","usersResponse","usersData","success","count","usersCount","users","length","currentUser","find","emails","some","address","id","_id","body","JSON","stringify","errorText","text","userHeaders","subscriptionsResponse","subscriptionsData","Array","isArray","update","userSubscriptions","filter","sub","unread","alert","includes","t","totalSubscriptions","subscriptionDetails","map","type","name","fname","rid","userMentions","processedRooms","Set","latestMessagePerRoom","subscription","endpoint","queryParams","URLSearchParams","roomId","String","Math","max","messagesResponse","messageData","hasMessages","validMessages","message","u","msg","latestMessage","messageUser","roomDisplayName","userDisplayName","messageText","timestamp","Date","ts","now","formattedTime","isNaN","getTime","toDateString","toLocaleTimeString","hour","minute","toLocaleDateString","day","month","initials","n","slice","join","toUpperCase","processedMessage","rawTimestamp","roomName","roomType","sender","color","getAvatarColor","isOwnMessage","room","isChannel","isPrivateGroup","isDirect","link","sortedMessages","Object","values","sort","a","b","dateA","dateB","total","keys","hasMore","colors","index","reduce","acc","char","charCodeAt"],"ignoreList":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(rsc)/./app/api/rocket-chat/messages/route.ts\n");
/***/ }),
/***/ "(rsc)/./node_modules/next/dist/build/webpack/loaders/next-app-loader/index.js?name=app%2Fapi%2Frocket-chat%2Fmessages%2Froute&page=%2Fapi%2Frocket-chat%2Fmessages%2Froute&appPaths=&pagePath=private-next-app-dir%2Fapi%2Frocket-chat%2Fmessages%2Froute.ts&appDir=%2Fhome%2Falma%2Fnextgen%2FNeah-mail%2Fapp&pageExtensions=tsx&pageExtensions=ts&pageExtensions=jsx&pageExtensions=js&rootDir=%2Fhome%2Falma%2Fnextgen%2FNeah-mail&isDev=true&tsconfigPath=tsconfig.json&basePath=&assetPrefix=&nextConfigOutput=&preferredRegion=&middlewareConfig=e30%3D!":
/*!****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/next/dist/build/webpack/loaders/next-app-loader/index.js?name=app%2Fapi%2Frocket-chat%2Fmessages%2Froute&page=%2Fapi%2Frocket-chat%2Fmessages%2Froute&appPaths=&pagePath=private-next-app-dir%2Fapi%2Frocket-chat%2Fmessages%2Froute.ts&appDir=%2Fhome%2Falma%2Fnextgen%2FNeah-mail%2Fapp&pageExtensions=tsx&pageExtensions=ts&pageExtensions=jsx&pageExtensions=js&rootDir=%2Fhome%2Falma%2Fnextgen%2FNeah-mail&isDev=true&tsconfigPath=tsconfig.json&basePath=&assetPrefix=&nextConfigOutput=&preferredRegion=&middlewareConfig=e30%3D! ***!
\****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ patchFetch: () => (/* binding */ patchFetch),\n/* harmony export */ routeModule: () => (/* binding */ routeModule),\n/* harmony export */ serverHooks: () => (/* binding */ serverHooks),\n/* harmony export */ workAsyncStorage: () => (/* binding */ workAsyncStorage),\n/* harmony export */ workUnitAsyncStorage: () => (/* binding */ workUnitAsyncStorage)\n/* harmony export */ });\n/* harmony import */ var next_dist_server_route_modules_app_route_module_compiled__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! next/dist/server/route-modules/app-route/module.compiled */ \"(rsc)/./node_modules/next/dist/server/route-modules/app-route/module.compiled.js\");\n/* harmony import */ var next_dist_server_route_modules_app_route_module_compiled__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(next_dist_server_route_modules_app_route_module_compiled__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var next_dist_server_route_kind__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! next/dist/server/route-kind */ \"(rsc)/./node_modules/next/dist/server/route-kind.js\");\n/* harmony import */ var next_dist_server_lib_patch_fetch__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! next/dist/server/lib/patch-fetch */ \"(rsc)/./node_modules/next/dist/server/lib/patch-fetch.js\");\n/* harmony import */ var next_dist_server_lib_patch_fetch__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(next_dist_server_lib_patch_fetch__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _home_alma_nextgen_Neah_mail_app_api_rocket_chat_messages_route_ts__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./app/api/rocket-chat/messages/route.ts */ \"(rsc)/./app/api/rocket-chat/messages/route.ts\");\n\n\n\n\n// We inject the nextConfigOutput here so that we can use them in the route\n// module.\nconst nextConfigOutput = \"\"\nconst routeModule = new next_dist_server_route_modules_app_route_module_compiled__WEBPACK_IMPORTED_MODULE_0__.AppRouteRouteModule({\n definition: {\n kind: next_dist_server_route_kind__WEBPACK_IMPORTED_MODULE_1__.RouteKind.APP_ROUTE,\n page: \"/api/rocket-chat/messages/route\",\n pathname: \"/api/rocket-chat/messages\",\n filename: \"route\",\n bundlePath: \"app/api/rocket-chat/messages/route\"\n },\n resolvedPagePath: \"/home/alma/nextgen/Neah-mail/app/api/rocket-chat/messages/route.ts\",\n nextConfigOutput,\n userland: _home_alma_nextgen_Neah_mail_app_api_rocket_chat_messages_route_ts__WEBPACK_IMPORTED_MODULE_3__\n});\n// Pull out the exports that we need to expose from the module. This should\n// be eliminated when we've moved the other routes to the new format. These\n// are used to hook into the route.\nconst { workAsyncStorage, workUnitAsyncStorage, serverHooks } = routeModule;\nfunction patchFetch() {\n return (0,next_dist_server_lib_patch_fetch__WEBPACK_IMPORTED_MODULE_2__.patchFetch)({\n workAsyncStorage,\n workUnitAsyncStorage\n });\n}\n\n\n//# sourceMappingURL=app-route.js.map//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvbmV4dC9kaXN0L2J1aWxkL3dlYnBhY2svbG9hZGVycy9uZXh0LWFwcC1sb2FkZXIvaW5kZXguanM/bmFtZT1hcHAlMkZhcGklMkZyb2NrZXQtY2hhdCUyRm1lc3NhZ2VzJTJGcm91dGUmcGFnZT0lMkZhcGklMkZyb2NrZXQtY2hhdCUyRm1lc3NhZ2VzJTJGcm91dGUmYXBwUGF0aHM9JnBhZ2VQYXRoPXByaXZhdGUtbmV4dC1hcHAtZGlyJTJGYXBpJTJGcm9ja2V0LWNoYXQlMkZtZXNzYWdlcyUyRnJvdXRlLnRzJmFwcERpcj0lMkZob21lJTJGYWxtYSUyRm5leHRnZW4lMkZOZWFoLW1haWwlMkZhcHAmcGFnZUV4dGVuc2lvbnM9dHN4JnBhZ2VFeHRlbnNpb25zPXRzJnBhZ2VFeHRlbnNpb25zPWpzeCZwYWdlRXh0ZW5zaW9ucz1qcyZyb290RGlyPSUyRmhvbWUlMkZhbG1hJTJGbmV4dGdlbiUyRk5lYWgtbWFpbCZpc0Rldj10cnVlJnRzY29uZmlnUGF0aD10c2NvbmZpZy5qc29uJmJhc2VQYXRoPSZhc3NldFByZWZpeD0mbmV4dENvbmZpZ091dHB1dD0mcHJlZmVycmVkUmVnaW9uPSZtaWRkbGV3YXJlQ29uZmlnPWUzMCUzRCEiLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7QUFBK0Y7QUFDdkM7QUFDcUI7QUFDa0I7QUFDL0Y7QUFDQTtBQUNBO0FBQ0Esd0JBQXdCLHlHQUFtQjtBQUMzQztBQUNBLGNBQWMsa0VBQVM7QUFDdkI7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTtBQUNBLFlBQVk7QUFDWixDQUFDO0FBQ0Q7QUFDQTtBQUNBO0FBQ0EsUUFBUSxzREFBc0Q7QUFDOUQ7QUFDQSxXQUFXLDRFQUFXO0FBQ3RCO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDMEY7O0FBRTFGIiwic291cmNlcyI6WyIiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQXBwUm91dGVSb3V0ZU1vZHVsZSB9IGZyb20gXCJuZXh0L2Rpc3Qvc2VydmVyL3JvdXRlLW1vZHVsZXMvYXBwLXJvdXRlL21vZHVsZS5jb21waWxlZFwiO1xuaW1wb3J0IHsgUm91dGVLaW5kIH0gZnJvbSBcIm5leHQvZGlzdC9zZXJ2ZXIvcm91dGUta2luZFwiO1xuaW1wb3J0IHsgcGF0Y2hGZXRjaCBhcyBfcGF0Y2hGZXRjaCB9IGZyb20gXCJuZXh0L2Rpc3Qvc2VydmVyL2xpYi9wYXRjaC1mZXRjaFwiO1xuaW1wb3J0ICogYXMgdXNlcmxhbmQgZnJvbSBcIi9ob21lL2FsbWEvbmV4dGdlbi9OZWFoLW1haWwvYXBwL2FwaS9yb2NrZXQtY2hhdC9tZXNzYWdlcy9yb3V0ZS50c1wiO1xuLy8gV2UgaW5qZWN0IHRoZSBuZXh0Q29uZmlnT3V0cHV0IGhlcmUgc28gdGhhdCB3ZSBjYW4gdXNlIHRoZW0gaW4gdGhlIHJvdXRlXG4vLyBtb2R1bGUuXG5jb25zdCBuZXh0Q29uZmlnT3V0cHV0ID0gXCJcIlxuY29uc3Qgcm91dGVNb2R1bGUgPSBuZXcgQXBwUm91dGVSb3V0ZU1vZHVsZSh7XG4gICAgZGVmaW5pdGlvbjoge1xuICAgICAgICBraW5kOiBSb3V0ZUtpbmQuQVBQX1JPVVRFLFxuICAgICAgICBwYWdlOiBcIi9hcGkvcm9ja2V0LWNoYXQvbWVzc2FnZXMvcm91dGVcIixcbiAgICAgICAgcGF0aG5hbWU6IFwiL2FwaS9yb2NrZXQtY2hhdC9tZXNzYWdlc1wiLFxuICAgICAgICBmaWxlbmFtZTogXCJyb3V0ZVwiLFxuICAgICAgICBidW5kbGVQYXRoOiBcImFwcC9hcGkvcm9ja2V0LWNoYXQvbWVzc2FnZXMvcm91dGVcIlxuICAgIH0sXG4gICAgcmVzb2x2ZWRQYWdlUGF0aDogXCIvaG9tZS9hbG1hL25leHRnZW4vTmVhaC1tYWlsL2FwcC9hcGkvcm9ja2V0LWNoYXQvbWVzc2FnZXMvcm91dGUudHNcIixcbiAgICBuZXh0Q29uZmlnT3V0cHV0LFxuICAgIHVzZXJsYW5kXG59KTtcbi8vIFB1bGwgb3V0IHRoZSBleHBvcnRzIHRoYXQgd2UgbmVlZCB0byBleHBvc2UgZnJvbSB0aGUgbW9kdWxlLiBUaGlzIHNob3VsZFxuLy8gYmUgZWxpbWluYXRlZCB3aGVuIHdlJ3ZlIG1vdmVkIHRoZSBvdGhlciByb3V0ZXMgdG8gdGhlIG5ldyBmb3JtYXQuIFRoZXNlXG4vLyBhcmUgdXNlZCB0byBob29rIGludG8gdGhlIHJvdXRlLlxuY29uc3QgeyB3b3JrQXN5bmNTdG9yYWdlLCB3b3JrVW5pdEFzeW5jU3RvcmFnZSwgc2VydmVySG9va3MgfSA9IHJvdXRlTW9kdWxlO1xuZnVuY3Rpb24gcGF0Y2hGZXRjaCgpIHtcbiAgICByZXR1cm4gX3BhdGNoRmV0Y2goe1xuICAgICAgICB3b3JrQXN5bmNTdG9yYWdlLFxuICAgICAgICB3b3JrVW5pdEFzeW5jU3RvcmFnZVxuICAgIH0pO1xufVxuZXhwb3J0IHsgcm91dGVNb2R1bGUsIHdvcmtBc3luY1N0b3JhZ2UsIHdvcmtVbml0QXN5bmNTdG9yYWdlLCBzZXJ2ZXJIb29rcywgcGF0Y2hGZXRjaCwgIH07XG5cbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWFwcC1yb3V0ZS5qcy5tYXAiXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/next/dist/build/webpack/loaders/next-app-loader/index.js?name=app%2Fapi%2Frocket-chat%2Fmessages%2Froute&page=%2Fapi%2Frocket-chat%2Fmessages%2Froute&appPaths=&pagePath=private-next-app-dir%2Fapi%2Frocket-chat%2Fmessages%2Froute.ts&appDir=%2Fhome%2Falma%2Fnextgen%2FNeah-mail%2Fapp&pageExtensions=tsx&pageExtensions=ts&pageExtensions=jsx&pageExtensions=js&rootDir=%2Fhome%2Falma%2Fnextgen%2FNeah-mail&isDev=true&tsconfigPath=tsconfig.json&basePath=&assetPrefix=&nextConfigOutput=&preferredRegion=&middlewareConfig=e30%3D!\n");
/***/ }),
/***/ "(rsc)/./node_modules/next/dist/build/webpack/loaders/next-flight-client-entry-loader.js?server=true!":
/*!******************************************************************************************************!*\
!*** ./node_modules/next/dist/build/webpack/loaders/next-flight-client-entry-loader.js?server=true! ***!
\******************************************************************************************************/
/***/ (() => {
/***/ }),
/***/ "(ssr)/./node_modules/next/dist/build/webpack/loaders/next-flight-client-entry-loader.js?server=true!":
/*!******************************************************************************************************!*\
!*** ./node_modules/next/dist/build/webpack/loaders/next-flight-client-entry-loader.js?server=true! ***!
\******************************************************************************************************/
/***/ (() => {
/***/ }),
/***/ "../app-render/after-task-async-storage.external":
/*!***********************************************************************************!*\
!*** external "next/dist/server/app-render/after-task-async-storage.external.js" ***!
\***********************************************************************************/
/***/ ((module) => {
"use strict";
module.exports = require("next/dist/server/app-render/after-task-async-storage.external.js");
/***/ }),
/***/ "../app-render/work-async-storage.external":
/*!*****************************************************************************!*\
!*** external "next/dist/server/app-render/work-async-storage.external.js" ***!
\*****************************************************************************/
/***/ ((module) => {
"use strict";
module.exports = require("next/dist/server/app-render/work-async-storage.external.js");
/***/ }),
/***/ "./work-unit-async-storage.external":
/*!**********************************************************************************!*\
!*** external "next/dist/server/app-render/work-unit-async-storage.external.js" ***!
\**********************************************************************************/
/***/ ((module) => {
"use strict";
module.exports = require("next/dist/server/app-render/work-unit-async-storage.external.js");
/***/ }),
/***/ "assert":
/*!*************************!*\
!*** external "assert" ***!
\*************************/
/***/ ((module) => {
"use strict";
module.exports = require("assert");
/***/ }),
/***/ "buffer":
/*!*************************!*\
!*** external "buffer" ***!
\*************************/
/***/ ((module) => {
"use strict";
module.exports = require("buffer");
/***/ }),
/***/ "crypto":
/*!*************************!*\
!*** external "crypto" ***!
\*************************/
/***/ ((module) => {
"use strict";
module.exports = require("crypto");
/***/ }),
/***/ "events":
/*!*************************!*\
!*** external "events" ***!
\*************************/
/***/ ((module) => {
"use strict";
module.exports = require("events");
/***/ }),
/***/ "http":
/*!***********************!*\
!*** external "http" ***!
\***********************/
/***/ ((module) => {
"use strict";
module.exports = require("http");
/***/ }),
/***/ "https":
/*!************************!*\
!*** external "https" ***!
\************************/
/***/ ((module) => {
"use strict";
module.exports = require("https");
/***/ }),
/***/ "next/dist/compiled/next-server/app-page.runtime.dev.js":
/*!*************************************************************************!*\
!*** external "next/dist/compiled/next-server/app-page.runtime.dev.js" ***!
\*************************************************************************/
/***/ ((module) => {
"use strict";
module.exports = require("next/dist/compiled/next-server/app-page.runtime.dev.js");
/***/ }),
/***/ "next/dist/compiled/next-server/app-route.runtime.dev.js":
/*!**************************************************************************!*\
!*** external "next/dist/compiled/next-server/app-route.runtime.dev.js" ***!
\**************************************************************************/
/***/ ((module) => {
"use strict";
module.exports = require("next/dist/compiled/next-server/app-route.runtime.dev.js");
/***/ }),
/***/ "querystring":
/*!******************************!*\
!*** external "querystring" ***!
\******************************/
/***/ ((module) => {
"use strict";
module.exports = require("querystring");
/***/ }),
/***/ "url":
/*!**********************!*\
!*** external "url" ***!
\**********************/
/***/ ((module) => {
"use strict";
module.exports = require("url");
/***/ }),
/***/ "util":
/*!***********************!*\
!*** external "util" ***!
\***********************/
/***/ ((module) => {
"use strict";
module.exports = require("util");
/***/ }),
/***/ "zlib":
/*!***********************!*\
!*** external "zlib" ***!
\***********************/
/***/ ((module) => {
"use strict";
module.exports = require("zlib");
/***/ })
};
;
// load runtime
var __webpack_require__ = require("../../../../webpack-runtime.js");
__webpack_require__.C(exports);
var __webpack_exec__ = (moduleId) => (__webpack_require__(__webpack_require__.s = moduleId))
var __webpack_exports__ = __webpack_require__.X(0, ["vendor-chunks/next","vendor-chunks/jose","vendor-chunks/next-auth","vendor-chunks/openid-client","vendor-chunks/@babel","vendor-chunks/oauth","vendor-chunks/preact","vendor-chunks/uuid","vendor-chunks/yallist","vendor-chunks/preact-render-to-string","vendor-chunks/cookie","vendor-chunks/oidc-token-hash","vendor-chunks/@panva","vendor-chunks/jwt-decode"], () => (__webpack_exec__("(rsc)/./node_modules/next/dist/build/webpack/loaders/next-app-loader/index.js?name=app%2Fapi%2Frocket-chat%2Fmessages%2Froute&page=%2Fapi%2Frocket-chat%2Fmessages%2Froute&appPaths=&pagePath=private-next-app-dir%2Fapi%2Frocket-chat%2Fmessages%2Froute.ts&appDir=%2Fhome%2Falma%2Fnextgen%2FNeah-mail%2Fapp&pageExtensions=tsx&pageExtensions=ts&pageExtensions=jsx&pageExtensions=js&rootDir=%2Fhome%2Falma%2Fnextgen%2FNeah-mail&isDev=true&tsconfigPath=tsconfig.json&basePath=&assetPrefix=&nextConfigOutput=&preferredRegion=&middlewareConfig=e30%3D!")));
module.exports = __webpack_exports__;
})();