Skip to main content
Glama

Payware MCP Server

Official
by payware
get-transaction-link.jsโ€ข4.66 kB
import { getTransactionDeepLink } from '../../shared/deep-links/api.js'; import { getPartnerIdSafe, getPrivateKeySafe } from '../../config/env.js'; /** * Get deep link for a payment institution transaction */ export const getTransactionLinkTool = { name: "payware_deep_links_get_transaction_link", description: `Get an active deep link for a transaction where the payment institution acts as source (SRC) or destination (DST). Returns a clickable URL that redirects to the payware mobile app. **Deep Link Format:** - Web URL: https://url.payware.eu/{transactionId} - Mobile Redirect: payware://{transactionId} **Use Cases:** - P2P payments initiated via messaging services - Transaction notifications with direct links - Transaction status sharing **Important Notes:** - Deep links are only supported in production environment - Link expiration is synchronized with the referenced transaction - Payment institutions only manage transaction links (no product links) - Traditional deep links that route to app content when app is installed`, inputSchema: { type: "object", properties: { transactionId: { type: "string", description: "The transaction identifier (e.g., 'pw7e4rCToG')", pattern: "^[a-zA-Z0-9]+$" }, partnerId: { type: "string", description: "Payment Institution Partner ID from payware dashboard. Uses PAYWARE_PARTNER_ID env var as default.", default: getPartnerIdSafe() }, privateKey: { type: "string", description: "RSA private key for JWT token creation. Uses environment-specific private key as default.", default: getPrivateKeySafe() } }, required: ["transactionId"] }, async handler(args) { const { transactionId, partnerId = getPartnerIdSafe(), privateKey = getPrivateKeySafe() } = args; if (!transactionId) { throw new Error("transactionId is required"); } if (!partnerId) { throw new Error("Partner ID is required. Provide via 'partnerId' parameter or set PAYWARE_PARTNER_ID environment variable."); } if (!privateKey) { throw new Error("Private key is required. Provide via 'privateKey' parameter or set PAYWARE_PRIVATE_KEY environment variable."); } try { const result = await getTransactionDeepLink({ transactionId, partnerType: 'payment_institution', partnerId, privateKey }); // Extract the URL - API returns either string directly or object with link property const linkUrl = typeof result.data === 'string' ? result.data : (result.data.link || result.data) return { content: [{ type: "text", text: `๐Ÿ”— **Transaction Deep Link Retrieved (Payment Institution)** **Deep Link Details:** - Transaction ID: ${transactionId} - Web URL: ${linkUrl} - Mobile Redirect: payware://${transactionId} **Payment Institution Info:** - Partner ID: ${partnerId} - Role: SRC/DST for P2P transactions **Link Information:** - Status: Active - Expiration: Synchronized with transaction - Platform: Production only **API Response:** \`\`\`json ${JSON.stringify(result.data, null, 2)} \`\`\` **API Call Details:** - Endpoint: GET ${result.requestInfo.url} - Status: ${result.requestInfo.statusCode} - Method: ${result.requestInfo.method} **Usage:** 1. Share the web URL: \`${linkUrl}\` 2. On mobile devices, it will redirect to: \`payware://${transactionId}\` 3. Link expires when the transaction expires 4. Use for P2P transaction notifications and sharing` }] }; } catch (error) { return { content: [{ type: "text", text: `โŒ **Failed to Get Transaction Deep Link (Payment Institution)** **Error Details:** - Transaction ID: ${transactionId} - Message: ${error.message} **Common Issues:** 1. **Transaction not found**: Check if transaction exists and is not expired 2. **Authentication failed**: Verify partner ID and private key 3. **Authorization failed**: Ensure PI is SRC or DST for this transaction 4. **Sandbox environment**: Deep links are production-only 5. **Invalid transaction ID**: Ensure transaction ID format is correct **Troubleshooting:** 1. Verify transaction exists using \`payware_transactions_get_transaction_status\` 2. Check if running in production environment 3. Ensure JWT authentication is working 4. Confirm payment institution role in transaction 5. Verify transaction is not expired` }] }; } } };

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/payware/mcp-server'

If you have feedback or need assistance with the MCP directory API, please join our Discord server