object template.update(object/array templates)
This method allows to update existing templates.
This method is only available to Admin and Super admin user types. Permissions to call the method can be revoked in user role settings. See User roles for more information.
(object/array) Template properties to be updated.
The templateid property must be defined for each template, all other properties are optional. Only the given properties will be updated, all others will remain unchanged.
Additionally to the standard template properties, the method accepts the following parameters.
| Parameter | Type | Description | 
|---|---|---|
| groups | object/array | Template groups to replace the current template groups the templates belong to. The template groups must have only the groupidproperty defined. | 
| tags | object/array | Template tags to replace the current template tags. | 
| macros | object/array | User macros to replace the current user macros on the given templates. | 
| templates | object/array | Templates to replace the currently linked templates. Templates that are not passed are only unlinked. The templates must have only the templateidproperty defined. | 
| templates_clear | object/array | Templates to unlink and clear from the given templates. The templates must have only the templateidproperty defined. | 
(object) Returns an object containing the IDs of the updated templates under the templateids property.
Change the technical name of the template to "Linux by Zabbix agent Custom", the visible name to "My template", and update the template description.
{  "jsonrpc": "2.0",  "method": "template.update",  "params": {  "templateid": "10086",  "host": "Linux by Zabbix agent Custom",  "name": "My template",  "description": "This is a custom Linux template."  },  "id": 1 }Response:
Replace all template groups for the given template with a different one.
{  "jsonrpc": "2.0",  "method": "template.update",  "params": {  "templateid": "10086",  "groups": [  {  "groupid": "24"  }   ]  },  "id": 1 }Response:
Replace all template tags with a different one.
{  "jsonrpc": "2.0",  "method": "template.update",  "params": {  "templateid": "10086",  "tags": [  {  "tag": "host-name",  "value": "{HOST.NAME}"  }  ]  },  "id": 1 }Response:
Replace all template macros with a different one.
{  "jsonrpc": "2.0",  "method": "template.update",  "params": {  "templateid": "10086",  "macros": [  {  "macro": "{$MY_MACRO}",  "value": "new_value"  }  ]  },  "id": 1 }Response:
Unlink (without clearing) all templates from the given template and link a different one to it.
{  "jsonrpc": "2.0",  "method": "template.update",  "params": {  "templateid": "10086",  "templates": [  {  "templateid": "10087"  }  ]  },  "id": 1 }Response:
Unlink and clear the given template from a specific linked template.
{  "jsonrpc": "2.0",  "method": "template.update",  "params": {  "templateid": "10086",  "templates_clear": [  {  "templateid": "10087"  }  ]  },  "id": 1 }Response:
CTemplate::update() in ui/include/classes/api/services/CTemplate.php.