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

As for how an IRE payload, used with the API or the REST end-point, should look like, you could consult the REST API reference or the (script) API reference. Knowledge about how Discovery classification (to a lesser extent) and identification works will also help greatly.

Geert Huylebro1
ServiceNow Employee
ServiceNow Employee

I indeed checked the REST API Documentation to create the payload.

Comparing the payload I use to the documentation, there's nothing I can see what is missing, and why it doesn't work

Could you point me to that document?

PS : I'm running a POST call to https://<instancename>/api/now/cmdb/instance/cmdb_ci_apache_web_server

Oh, I see. Perhaps the problem is that the "mandatory" (dependent) relationship for Apache Web Servers is the "Runs on" one, which is an "outbound" relationship not an "inbound" relationship:

20221228-1.png20221228-2.png

Hint: CI Class Manager is your friend, when dealing with CMDB/IRE.

I'd try changing the payload to contain an outbound relationship for the Apache Web Server.