API call to create CI fails because of missing dependency

Geert Huylebro1
ServiceNow Employee
ServiceNow Employee

Hi,

when trying to create a CI (of class cmdb_ci_apache_web_server), the API call fails with the "error": "MISSING_DEPENDENCY".

The related message is "In payload no relations defined for dependent class [cmdb_ci_apache_web_server] that matches any containment/hosting rules: [cmdb_ci_appl >> Runs on >> cmdb_ci_hardware]."

 

Following is the body of the call: 

{
"attributes": {
"asset_tag": "tag_lx_web_app40",
"company": "ServiceNow",
"environment": "dev",
"name": "Apache Server @ lx_web_app40",
"type": "Apache",
"tcp_port": "80"
},
"source": "ServiceNow",
"inbound_relations":[
{
"type": "60bc4e22c0a8010e01f074cbe6bd73c3",
"target": "2f5a7e3c47cce15050235e17e26d43e0",
"cmdb_class_name": "cmdb_ci_linux_server"
}
]
}
 
in which type is the sys_id of the RunsOn::Runs relationship type.
The 'target' is the sys_id of the existing Linux server CI.
Anyone has any idea?
 
kr
Geert
2 ACCEPTED SOLUTIONS

In the meantime I have found another post, here on community that helped me in the right direction, and I have managed to do the CI creation using payload:

{
	"attributes": {
		"asset_tag": "tag_lx_web_app40",
		"company": "ServiceNow",
		"config_file": "/etc/httpd/httpd.conf",
		"environment": "dev",
		"name": "Apache Server @ lx_web_app40",
		"type": "Apache",
		"tcp_port": "80",
		"version": "2.4.54"
	},
	"depends_on": {
		"outbound_relations": {
			"type": "60bc4e22c0a8010e01f074cbe6bd73c3",
			"target": "539747cac0a801640163e60735fbbf6e"
		}

	},
	"source": "ServiceNow"
}

It seems there is a total disconnect between what exists and what is described in the documentation 😞

It seems in case of depending CIs one has to add an additional property to the payload: depends_on. And it has to contain the relationship that indicates the parent CI. As you can see you still have to add outbound relation, not an inbound one. Oh, for sure you will need to update "target" of "outbound_relations" to be that of the Linux (or whatever) server you have in your CMDB.

Here's the Linux server before calling the API:

2023-01-03-1.png

and here it is after calling the API:

2023-01-03-2.png

 

View solution in original post

Also, note that property "attributes" must contain the field names (config_file) not the field labels (Configuration file)!

View solution in original post

16 REPLIES 16

I would also make sure to provide all information necessary for a successful identification:

20221228-3.png

Geert Huylebro1
ServiceNow Employee
ServiceNow Employee

Hi,

thanks for the info

I've tried specifying the relationship as outbound, and added the three additional attributes, but with the same result

This is how the payload looks now:

GeertHuylebro1_0-1672728413646.png

 

The response is '400 Bad Request', indicating there's no relations defined.

So it looks like there is something missing in the definition of the outboud_relations in the payload.

GeertHuylebro1_1-1672728552935.png

 

kr

Geert

 

 

kr

Geert

 

The docs say that one must provide the parent sys_id in the payload when creating dependent CIs. However it does not say how to add that info to the payload.

Maybe ask that in the community in another question - people tend to hunt not-yet-unswered question, so I'm guessing no-one will look at this long thread - no points in sight :-).

In the meantime I have found another post, here on community that helped me in the right direction, and I have managed to do the CI creation using payload:

{
	"attributes": {
		"asset_tag": "tag_lx_web_app40",
		"company": "ServiceNow",
		"config_file": "/etc/httpd/httpd.conf",
		"environment": "dev",
		"name": "Apache Server @ lx_web_app40",
		"type": "Apache",
		"tcp_port": "80",
		"version": "2.4.54"
	},
	"depends_on": {
		"outbound_relations": {
			"type": "60bc4e22c0a8010e01f074cbe6bd73c3",
			"target": "539747cac0a801640163e60735fbbf6e"
		}

	},
	"source": "ServiceNow"
}

It seems there is a total disconnect between what exists and what is described in the documentation 😞

It seems in case of depending CIs one has to add an additional property to the payload: depends_on. And it has to contain the relationship that indicates the parent CI. As you can see you still have to add outbound relation, not an inbound one. Oh, for sure you will need to update "target" of "outbound_relations" to be that of the Linux (or whatever) server you have in your CMDB.

Here's the Linux server before calling the API:

2023-01-03-1.png

and here it is after calling the API:

2023-01-03-2.png

 

Geert Huylebro1
ServiceNow Employee
ServiceNow Employee

thanks,

I have seen that post as well but thought the 'depends_on' had to be replaced by the type of relationship, which in my case was 'RunsOn', but for which I didn't find any proper spelling...

 

Thanks for the help !