Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.


Include Page
REST V1 Authentication
REST V1 Authentication

...

Property NameTypeRequiredExample Property Value
SN_USER_NAMEStringYesusername
SN_PASSWORD*StringYespassword
SN_PORTIntegerYes1234
SN_APPROVED_SCRIPTStringNONo/rest/api/2/issue/{JIRA_ISSUE}
SN_REJECTED_SCRIPTStringNONo/browse/{JIRA_ISSUE}
SN_DONT_POLLBooleanNONo
SN_URLStringYeshttp://myjira.atlassian.net

...

Request

Parameter
Required
Type
Description
IdYesURLURL parameter for the Id which is used to find and return a Change Management System

Include Page
REST V1 CMS Instance Response
REST V1 CMS Instance Response

Response Codes

HTTP Code
Description
200Change Management System Instance was found and returned
400Bad request
401Authentication failure
403Authorization failure (no access to resource)
404Change Management System Instance not found
500Unexpected internal server error

Example

If we had a Change Management System in our database with an Id of 11101 with the following attributes

Code Block
themeEclipse
titleChange Management System - 11101
{
	"instanceId": 11101,
	"instanceCode": "CMS Code",
	"instanceName": "CMS Name",
	"cmsSystemId": 1,
	"description": "CMS example",
	"isActive": true,
	"properties":
	[
		{
			"propertyName": "SN_PASSWORD",
			"propertyValue": "ThePassword"
		},
		{
			"propertyNamecredentialId": 76592
		},
		{
			"propertyName": "SN_PORT",
			"propertyValue": "1234"
1234,
			"credentialId": null
		},
		{
			"propertyName": "SN_REJECTED_SCRIPT",
			"propertyValue": "rejectedScript.bat",
			"credentialId": null
		},
		{
			"propertyName": "SN_APPROVED_SCRIPT",
			"propertyValue": "approvedScript.bat",
			"credentialId": null
		},
		{
			"propertyName": "SN_DONT_POLL",
			"propertyValue": "true"
true,
			"credentialId": null
		},
		{
			"propertyName": "SN_URL",
			"propertyValue": "http://myServiceNow.atlassian.net",
			"credentialId": null
		},
		{
			"propertyName": "SN_USER_NAME",
			"propertyValue": "username",
			"credentialId": null
		}
	]
}

When we run a GET request at the following URLhttp://host:port/flexdeploy/rest/v1/topology/integrations/cmsinstance/11101

The GET request would return the following JSON Change Management System object

Code Block
themeEclipse
titleChange Management System - 11101
{
	"instanceId": 11101,
	"instanceCode": "CMS Code",
	"instanceName": "CMS Name",
	"cmsSystemId": 1,
	"description": "CMS example",
	"isActive": true,
	"properties":
	[
		{
			"propertyName": "SN_PASSWORD",
			"propertyValue": "*****",
			"credentialId": 76592
		},
		{
			"propertyName": "SN_PORT",
			"propertyValue": "1234"
1234,
			"credentialId": null
		},
		{
			"propertyName": "SN_REJECTED_SCRIPT",
			"propertyValue": "rejectedScript.bat",
			"credentialId": null
		},
		{
			"propertyName": "SN_APPROVED_SCRIPT",
			"propertyValue": "approvedScript.bat",
			"credentialId": null
		},
		{
			"propertyName": "SN_DONT_POLL",
			"propertyValue": "true"
true,
			"credentialId": null
		},
		{
			"propertyName": "SN_URL",
			"propertyValue": "http://myServiceNow.atlassian.net",
			"credentialId": null
		},
		{
			"propertyName": "SN_USER_NAME",
			"propertyValue": "username",
			"credentialId": null
		}
	]
}

GET (Using Query Parameters)

This GET service will return a list of Change Management Systems in the form of JSON objects based on the query parameters code, name, and Change Management System type. Change Management Systems are only returned if they match ALL of the specified query parameters. If no query parameters are given this request will return the entire list of Change Management Systems.

Info
titleAPI URL

http://host:port/flexdeploy/rest/v1/topology/integrations/cmsinstance?

Append the following character sequences to the above URL to specify Query parameters.
Use '&' between successive query parameters: 

instanceCode={code}

instanceName={name}

cmsSystemName={cmssystemname}

Examples:
To specify the code parameter only:

http://host:port/flexdeploy/rest/v1/topology/integrations/cmsinstance?instanceCode={code}

To specify the code and name parameters:

http://host:port/flexdeploy/rest/v1/topology/integrations/cmsinstance?instanceCode={code}&instanceName={name}

To specify the issue tracking system name only:

http://host:port/flexdeploy/rest/v1/topology/integrations/cmsinstance?cmsSystemName={cmssystemName}

...

Code Block
themeEclipse
titleChange Management System - 11101
[
	{
		"instanceId": 11101,
		"instanceCode": "CMSCODE",
		"instanceName": "CMSName",
		"cmsSystemId": 1,
		"description": "CMS example",
		"isActive": true,
		"properties":
		[
			{
				"propertyName": "SN_PASSWORD",
				"propertyValue": "ThePassword1Password1",
			},	"credentialId": 76592
			},
			{
				"propertyName": "SN_PORT",
				"propertyValue": 1234,
				"1234credentialId": null
			},
			{	
				"propertyName": "SN_REJECTED_SCRIPT",
				"propertyValue": "rejectedScript.bat",
				"credentialId": null
			},
			{
				"propertyName": "SN_APPROVED_SCRIPT",
				"propertyValue": "approvedScript.bat",
				"credentialId": null
			},
			{
				"propertyName": "SN_DONT_POLL",
				"propertyValue": "true"
true,
				"credentialId": null
			},
			{
				"propertyName": "SN_URL",
				"propertyValue": "http://myServiceNow.atlassian.net",
				"credentialId": null
			},
			{
				"propertyName": "SN_USER_NAME",
				"propertyValue": "username",
				"credentialId": null
			}
		]
	},
	{
		"instanceId": 11107,
		"instanceCode": "CMSCODE2",
		"instanceName": "CMSName2",
		"cmsSystemId": 1,
		"description": "the second CMS example",
		"isActive": true,
		"properties":
		[
			{
				"propertyName": "SN_PASSWORD",
				"propertyValue": "ThePassword2",
				"credentialId": 19520
			},
			{
				"propertyName": "SN_PORT",
				"propertyValue": "9876"
9876,
				"credentialId": null
			},
			{	
				"propertyName": "SN_REJECTED_SCRIPT",
				"propertyValue": "rejectedScript2.bat",
				"credentialId": null
			},
			{
				"propertyName": "SN_APPROVED_SCRIPT",
				"propertyValue": "approvedScript2.bat",
				"credentialId": null
			},
			{
				"propertyName": "SN_DONT_POLL",
				"propertyValue": true,
				"truecredentialId": null
			},
			{
				"propertyName": "SN_URL",
				"propertyValue": "http://myServiceNow2.atlassian.net",
				"credentialId": null
			},
			{
				"propertyName": "SN_USER_NAME",
				"propertyValue": "username2",
				"credentialId": null
			}
		]
	}
]

When we run a GET request at the following URL

http://host:port/flexdeploy/rest/v1/topology/integrations/cmsinstance?instanceName=CMSName

The GET request would return the  following JSON Change Management Instance object

Code Block
themeEclipse
titleChange Management System - 11101
[
	{
		"instanceId": 11101,
		"instanceCode": "CMSCODE",
		"instanceName": "CMSName",
		"cmsSystemId": 1,
		"description": "CMS example",
		"isActive": true,
		"properties":
		[
			{
				"propertyName": "SN_PASSWORD",
				"propertyValue": "ThePassword1*****",
			},	"credentialId": 76592
			},
			{
				"propertyName": "SN_PORT",
				"propertyValue": 1234,
				"1234credentialId": null
			},
			{	
				"propertyName": "SN_REJECTED_SCRIPT",
				"propertyValue": "rejectedScript.bat",
				"credentialId": null
			},
			{
				"propertyName": "SN_APPROVED_SCRIPT",
				"propertyValue": "approvedScript.bat",
				"credentialId": null
			},
			{
				"propertyName": "SN_DONT_POLL",
				"propertyValue": "true"
true,
				"credentialId": null
			},
			{
				"propertyName": "SN_URL",
				"propertyValue": "http://myServiceNow.atlassian.net",
				"credentialId": null
			},
			{
				"propertyName": "SN_USER_NAME",
				"propertyValue": "username",
				"credentialId": null
			}
		]
	}
]

POST

The POST service will create a new change management system with the same attributes as the given JSON object. 

...

Code Block
themeEclipse
titleChange Management System - 11101
{
		"instanceId": null,												
		"instanceCode": "CMS Code",
		"instanceName": "CMS Name",
		"cmsSystemId": 1,
		"description": "CMS Post",
		"isActive": true,
		"properties":
		[
			{
				"propertyName": "SN_PASSWORD",
				"propertyValue": "ThePassword",
				"credentialId": 76592
			},
			{
				"propertyName": "SN_PORT",
				"propertyValue": "1234"
1234,
				"credentialId": null
			},
			{	
				"propertyName": "SN_REJECTED_SCRIPT",
				"propertyValue": "rejectedScript.bat",
				"credentialId": null
			},
			{
				"propertyName": "SN_APPROVED_SCRIPT",
				"propertyValue": "approvedScript.bat",
				"credentialId": null
			},
			{
				"propertyName": "SN_DONT_POLL",
				"propertyValue": true,
				"truecredentialId": null
			},
			{
				"propertyName": "SN_URL",
				"propertyValue": "http://myServiceNow.atlassian.net",
				"credentialId": null
			},
			{
				"propertyName": "SN_USER_NAME",
				"propertyValue": "username",
				"credentialId": null
			}
		]
	}

the following Change Management System will be created in the database and returned. Notice the updated Instance Id field and hidden password.

Code Block
themeEclipse
titleChange Management System - 11101
{
		"instanceId": 11101,
		"instanceCode": "CMS Code",
		"instanceName": "CMS Name",
		"cmsSystemId": 1,
		"description": "CMS Post",
		"isActive": true,
		"properties":
		[
			{
				"propertyName": "SN_PASSWORD",
				"propertyValue": "*****",
				"credentialId": 76592
			},
			{
				"propertyName": "SN_PORT",
				"propertyValue": "1234",
			}	"credentialId": null
			},
			{	
				"propertyName": "SN_REJECTED_SCRIPT",
				"propertyValue": "rejectedScript.bat",
				"credentialId": null
			},
			{
				"propertyName": "SN_APPROVED_SCRIPT",
				"propertyValue": "approvedScript.bat",
				"credentialId": null
			},
			{
				"propertyName": "SN_DONT_POLL",
				"propertyValue": "true",
				"credentialId": null
			},
			{
				"propertyName": "SN_URL",
				"propertyValue": "http://myServiceNow.atlassian.net",
				"credentialId": null
			},
			{
				"propertyName": "SN_USER_NAME",
				"propertyValue": "username",
				"credentialId": null
			}
		]
	}

PUT

This PUT service will update all attributes of an Change Management System with the given Id based on the attributes of the supplied JSON object.

...

Request

Attributes
Type
Required
Description
instanceIdIntegerNoPrimary ID of the Change Management System, created when first making a Change Management System.
instanceCodeStringYesThe code of the Change Management System. Must be Unique
instanceNameStringYesThe name of the Change Management System. Must be Unique.
cmsSystemIdIntegerYesThe ID of the type of Change Management System.
descriptionStringNoThe description of the Change Management System.
isActiveBooleanNoWhether or not this Change Management System is active. Defaults to true.
propertiesList<Property>Dependent

The properties associated with the type of Change Management System: requirements depend on the Change Management System selected.

Values for properties not included in input will be cleared.

Include Page
REST V1 CMS Instance Response
REST V1 CMS Instance Response

Response Code

HTTP Code
Description
200Change Management System Updated
400Bad request
401Authentication failure
403Authorization failure (no access to resource)
404Change Management System not found
500Unexpected internal server error

Example

If we had a Change Management System in our database with an Id of 11223 and had the following attributes

Code Block
themeEclipse
titleChange Management System - 11223
{
		"instanceId": 11223,
		"instanceCode": "CMS Code",
		"instanceName": "CMS Name",
		"cmsSystemId": 1,
		"description": "JSON of data before a PUT has occurred",
		"isActive": true,
		"properties":
		[
			{
				"propertyName": "SN_PASSWORD",
				"propertyValue": "*****",
				"credentialId": 76592
			},
			{
				"propertyName": "SN_PORT",
				"propertyValue": "1234",
			},
				"credentialId": null
			},
			{	
				"propertyName": "SN_REJECTED_SCRIPT",
				"propertyValue": "rejectedScript.bat",
				"credentialId": null
			},
			{
				"propertyName": "SN_APPROVED_SCRIPT",
				"propertyValue": "approvedScript.bat",
				"credentialId": null
			},
			{
				"propertyName": "SN_DONT_POLL",
				"propertyValue": "true",
				"credentialId": null
			},
			{
				"propertyName": "SN_URL",
				"propertyValue": "http://myServiceNow.atlassian.net",
				"credentialId": null
			},
			{
				"propertyName": "SN_USER_NAME",
				"propertyValue": "username",
				"credentialId": null
			}
		]
	}

When we run a PUT request at the following URLhttp://host:port/flexdeploy/rest/v1/topology/integrations/cmsinstance/11223

And the PUT request receives the following JSON Change Management System object,

Code Block
themeEclipse
titleChange Management System - 11223
{
		"instanceId": null,
		"instanceCode": "New CMS Code",
		"instanceName": "New CMS Name",
		"cmsSystemId": 1,
		"description": "New CMS Description",
		"isActive": true,
		"properties":
		[
			{
				"propertyName": "SN_PASSWORD",
				"propertyValue": "newPassword",
				"credentialId": null
			},
			{
				"propertyName": "SN_PORT",
				"propertyValue": "1234"
1234,
				"credentialId": null
			},
			{	
				"propertyName": "SN_REJECTED_SCRIPT",
				"propertyValue": "rejectedScript.bat",
				"credentialId": null
			},
			{
				"propertyName": "SN_APPROVED_SCRIPT",
				"propertyValue": "approvedScript.bat",
				"credentialId": null
			},
			{
				"propertyName": "SN_DONT_POLL",
				"propertyValue": "true",
				"credentialId": null
			},
			{
				"propertyName": "SN_URL",
				"propertyValue": "http://myServiceNow.atlassian.net",
				"credentialId": null
			},
			{
				"propertyName": "SN_USER_NAME",
				"propertyValue": "newUser",
				"credentialId": null
			}
		]
}

The PUT request would then update the Change Management System with Id 11223 and return the  following JSON Change Management System object.

Code Block
themeEclipse
titleChange Management System - 11223
{
		"instanceId": 11223,
		"instanceCode": "New CMS Code",
		"instanceName": "New CMS Name",
		"cmsSystemId": 1,
		"description": "New CMS Description",
		"isActive": true,
		"properties":
		[
			{
				"propertyName": "SN_PASSWORD",
				"propertyValue": "****",
				"credentialId": 76592
			},
			{
				"propertyName": "SN_PORT",
				"propertyValue": "1234",
			},
			"credentialId": null
			},
			{	
				"propertyName": "SN_REJECTED_SCRIPT",
				"propertyValue": "rejectedScript.bat",
				"credentialId": null
			},
			{
				"propertyName": "SN_APPROVED_SCRIPT",
				"propertyValue": "approvedScript.bat",
				"credentialId": null
			},
			{
				"propertyName": "SN_DONT_POLL",
				"propertyValue": "true",
				"credentialId": null
			},
			{
				"propertyName": "SN_URL",
				"propertyValue": "http://myServiceNow.atlassian.net",
				"credentialId": null
			},
			{
				"propertyName": "SN_USER_NAME",
				"propertyValue": "newUser",
				"credentialId": null
			}
		]
}

PATCH

This PATCH service will update the information of the Change Management System of the specified Id with the non-null parameters of the JSON. The parameters that are null will not be changed in the Change Management System.

Info
titleAPI URL

http://host:port/flexdeploy/rest/v1/topology/integrations/cmsinstance/{Id}

...

HTTP Code
Description
200Change Management System Updated
400Bad request
401Authentication failure
403Authorization failure (no access to resource)
404Change Management System not found
500Unexpected internal server error

Example

If we had an Change Management System in our database with an Id of 11223 and had the following attributes

Code Block
themeEclipse
titleChange Management System - 11223
{
		"instanceId": 11223,
		"instanceCode": "NewCMSCode",
		"instanceName": "NewCMSName",
		"cmsSystemId": 1,
		"description": "JSON of data before a PATCH has occurred",
		"isActive": true,
		"properties":
		[
			{
				"propertyName": "SN_PASSWORD",
				"propertyValue": "ThePassword",
				"credentialId": 76592
			},
			{
				"propertyName": "SN_PORT",
				"propertyValue": 1234,
				"1234credentialId": null
			},
			{	
				"propertyName": "SN_REJECTED_SCRIPT",
				"propertyValue": "rejectedScript.bat",
				"credentialId": null
			},
			{
				"propertyName": "SN_APPROVED_SCRIPT",
				"propertyValue": "approvedScript.bat",
				"credentialId": null
			},
			{
				"propertyName": "SN_DONT_POLL",
				"propertyValue": "true",
				"credentialId": null
			},
			{
				"propertyName": "SN_URL",
				"propertyValue": "http://myServiceNow.atlassian.net",
				"credentialId": null
			},
			{
				"propertyName": "SN_USER_NAME",
				"propertyValue": "username",
				"credentialId": null
			}
		]
	}

When we run a PATCH request at the following URLhttp://host:port/flexdeploy/rest/v1/topology/integrations/cmsinstance/11223

And the PATCH request receives the following JSON Change Management System object,

Code Block
themeEclipse
titleChange Management System - 11223
{
	"instanceName": "NewNameFromPatch",
	"properties":
	[
		{
			"propertyName": "SN_PASSWORD",
			"propertyValue": "",
			"newpasswordcredentialId": 16925
		}
	]
}

The PATCH request would then update the Change Management System with Id 11223 and return the  the following JSON Change Management System object.

Code Block
themeEclipse
titleChange Management System - 11223
{
		"instanceId": 11223,
		"instanceCode": "CMS Code",
		"instanceName": "NewNameFromPatch",
		"cmsSystemId": 1,
		"description": "JSON of data before a PATCH has occurred",
		"isActive": true,
		"properties":
		[
			{
				"propertyName": "SN_PASSWORD",
				"propertyValue": "*****",
				"credentialId": 16925
			},
			{
				"propertyName": "SN_PORT",
				"propertyValue": "1234"
1234,
				"credentialId": null
			},
			{	
				"propertyName": "SN_REJECTED_SCRIPT",
				"propertyValue": "rejectedScript.bat",
				"credentialId": null
			},
			{
				"propertyName": "SN_APPROVED_SCRIPT",
				"propertyValue": "approvedScript.bat",
				"credentialId": null
			},
			{
				"propertyName": "SN_DONT_POLL",
				"propertyValue": "true",
				"credentialId": null
			},
			{
				"propertyName": "SN_URL",
				"propertyValue": "http://myServiceNow.atlassian.net",
				"credentialId": null
			},
			{
				"propertyName": "SN_USER_NAME",
				"propertyValue": "username",
				"credentialId": null
			}
		]
	}