/**
* UpdateBehaviorDefinition Handler - ABAP Behavior Definition Update via ADT API
*/
import type { IBehaviorDefinitionConfig } from '@mcp-abap-adt/adt-clients';
import { AdtClient } from '@mcp-abap-adt/adt-clients';
import type { HandlerContext } from '../../../lib/handlers/interfaces';
import { return_error, return_response } from '../../../lib/utils';
export const TOOL_DEFINITION = {
name: 'UpdateBehaviorDefinition',
description: 'Update source code of an ABAP Behavior Definition.',
inputSchema: {
type: 'object',
properties: {
name: {
type: 'string',
description: 'Behavior Definition name',
},
source_code: {
type: 'string',
description: 'New source code',
},
lock_handle: {
type: 'string',
description:
'Lock handle from LockObject. If not provided, will attempt to lock internally (not recommended for stateful flows).',
},
activate: {
type: 'boolean',
description: 'Activate after update. Default: true',
},
},
required: ['name', 'source_code'],
},
} as const;
interface UpdateBehaviorDefinitionArgs {
name: string;
source_code: string;
lock_handle?: string;
activate?: boolean;
}
export async function handleUpdateBehaviorDefinition(
context: HandlerContext,
params: any,
) {
const { connection, logger } = context;
const args: UpdateBehaviorDefinitionArgs = params;
if (!args.name || !args.source_code) {
return return_error(new Error('Missing required parameters'));
}
const name = args.name.toUpperCase();
// Get connection from session context (set by ProtocolHandler)
// Connection is managed and cached per session, with proper token refresh via AuthBroker
logger?.info(`Starting BDEF update: ${name}`);
try {
const client = new AdtClient(connection);
const shouldActivate = args.activate !== false;
let lockHandle = args.lock_handle;
// Lock if not provided - using types from adt-clients
if (!lockHandle) {
const lockConfig: Pick<IBehaviorDefinitionConfig, 'name'> = {
name,
};
lockHandle = await client.getBehaviorDefinition().lock(lockConfig);
}
// Update - using types from adt-clients
const updateConfig: Pick<IBehaviorDefinitionConfig, 'name' | 'sourceCode'> =
{
name,
sourceCode: args.source_code,
};
await client
.getBehaviorDefinition()
.update(updateConfig, { lockHandle: lockHandle });
// Unlock if we locked it internally - using types from adt-clients
if (!args.lock_handle) {
const unlockConfig: Pick<IBehaviorDefinitionConfig, 'name'> = {
name,
};
await client.getBehaviorDefinition().unlock(unlockConfig, lockHandle);
}
// Activate if requested - using types from adt-clients
if (shouldActivate) {
const activateConfig: Pick<IBehaviorDefinitionConfig, 'name'> = {
name,
};
await client.getBehaviorDefinition().activate(activateConfig);
}
const result = {
success: true,
name: name,
message: shouldActivate
? `Behavior Definition ${name} updated and activated successfully`
: `Behavior Definition ${name} updated successfully`,
};
return return_response({
data: JSON.stringify(result, null, 2),
status: 200,
statusText: 'OK',
headers: {},
config: {} as any,
});
} catch (error: any) {
logger?.error(`Error updating BDEF ${name}: ${error?.message || error}`);
return return_error(error);
}
}