Skip to main content
Glama
updateAsset.ts1.74 kB
import { z } from 'zod'; import { createSuccessResponse, withErrorHandling, } from '../../utils/response.js'; import { BaseToolSchema, createToolClient } from '../../utils/tools.js'; import { AssetMetadataSchema } from '../../types/taxonomySchema.js'; import type { ContentfulConfig } from '../../config/types.js'; export const UpdateAssetToolParams = BaseToolSchema.extend({ assetId: z.string().describe('The ID of the asset to update'), fields: z .record(z.any()) .describe( 'The field values to update. Keys should be field IDs and values should be the field content. Will be merged with existing fields.', ), metadata: AssetMetadataSchema, }); type Params = z.infer<typeof UpdateAssetToolParams>; export function updateAssetTool(config: ContentfulConfig) { async function tool(args: Params) { const params = { spaceId: args.spaceId, environmentId: args.environmentId, assetId: args.assetId, }; const contentfulClient = createToolClient(config, args); // Get existing asset, merge fields, and update const existingAsset = await contentfulClient.asset.get(params); const allTags = [ ...(existingAsset.metadata?.tags || []), ...(args.metadata?.tags || []), ]; const allConcepts = [ ...(existingAsset.metadata?.concepts || []), ...(args.metadata?.concepts || []), ]; const updatedAsset = await contentfulClient.asset.update(params, { ...existingAsset, fields: { ...existingAsset.fields, ...args.fields }, metadata: { tags: allTags, concepts: allConcepts, }, }); return createSuccessResponse('Asset updated successfully', { updatedAsset }); } return withErrorHandling(tool, 'Error updating asset'); }

Latest Blog Posts

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/contentful/contentful-mcp-server'

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