- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
‎09-12-2025 11:32 AM
Hi Community,
I’m trying to figure out the best way to create multiple Requested Items (RITMs) from a single Catalog Item submission.
Use case:
We have one catalog item with several checkboxes. (It Systems, Information Security, Finance)
When the form is submitted, I want a separate RITM created for each selected checkbox.
Each RITM should contain the same variable values, but be assigned to a different group depending on which checkbox was selected.
All RITMs should roll up under the same REQ, and ideally be displayed on their own tabs within the request.
What I’ve tried so far:
Order Guides → but we want this to happen without extra clicks or navigating to multiple screens.
Cart APIs → I’ve tested a few approaches but haven’t been able to get them working for this use case (maybe I’m not setting them up correctly).
Workflow → I have a workflow triggered when the catalog item is submitted that checks each checkbox, but I don’t know how to branch it into separate RITMs.
Custom Action → I tried adding a custom action, but it doesn’t seem to show up as an option when I go to use it.
Has anyone successfully implemented this pattern before? My main focus is to drive this through Flow Designer. We have not implemented multiple RITMs in our environment before.
Any best practices, code samples, or pointers would be hugely appreciated.
Thanks
Philip H
Solved! Go to Solution.
- Labels:
-
Service Catalog
-
Service Portal
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
3 weeks ago
I wanted to share the solution I was able to build in Flow Designer without using any custom actions or scripting.
I started with a Service Catalog trigger, then used Get Catalog Variables to retrieve the specific variables I needed.
To associate multiple RITMs with the REQ, I added a Look Up Record on the sc_request table to retrieve the Sys ID of the parent request.
From there, I applied If / Else If conditions based on the catalog variable checkboxes:
If IT Systems is true → update the primary Request Item record.
If Finance is true → create a Request Item record.
If Information Security is true → create a Request Item record.
For the Else If conditions:
If Information Security is true and IT Systems is false → update the primary Request Item.
If Finance is true → create a Request Item record.
For the final Else condition:
If IT Systems is false and Finance is true → update the primary Request Item.
If Information Security is true → create a new Request Item record.
Finally, I used an Update Request Record step.
The tricky part was ensuring that updates to the REQ didn’t wipe out values when non-primary RITMs were being updated (since the primary has the flow context attached to it). My workaround was to use the Look Up Trigger Service Catalog Request Item record to pull values from there.
Attempting to populate the REQ directly from the catalog variables would cause errors, but pulling them from the trigger record worked reliably.
I hope this helps!
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
‎09-15-2025 02:07 PM
Run Script is not an action option for me. We need to select an action type first. Eg (Create record, Update Record).
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
‎09-15-2025 09:25 PM
Hi @phugill,
In Flow Designer, the "Run Script" option only appears if you create a Custom Action (or Subflow Action) with Action Type = Script.
Here’s how you can set it up properly:
Option 1: Use a Custom Action
Go to Flow Designer → Action → New.
Fill in:
Name: e.g. "Create Multi-RITM Request"
Application: Your scoped app / Global
Action type: -> Script
Define Inputs:
requested_for (Reference → User)
other_variable (String)
it_systems (Boolean)
infosec (Boolean)
finance (Boolean)
Define Outputs:
requestNumber (String)
Add a Script Step (now you’ll see "Run Script" because it’s a Script Action).
Paste the logic you already have.
This way, you’ll be able to call it from your Catalog Item Flow.
Option 2: Use Subflow (no Run Script directly)
If you’re creating a Subflow, you won’t see "Run Script" as a direct action — you only get record-based actions (Create, Update, Lookup, etc.).
In that case:
First, create a Custom Action (as above) to house your script.
Then, in your Subflow, add a step → Action → select your "Create Multi-RITM Request" action.
That keeps it clean and reusable.
So the path is:
Catalog Item Flow → Subflow → Custom Script Action (Run Script inside) → creates REQ + RITMs.
Please mark as Correct Answer/Helpful, if applicable.
ServiceNow Developer
Chiranjeevi
ServiceNow Developer | | ITSM | | ServiceNow Discovery | | Event Management | | Service Mapping | | CMDB
Please mark as Correct Answer/Helpful, if applicable.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
‎09-16-2025 06:25 PM
Have you reviewed my last comment? It follows what you said but I’m not sure why my action isn’t listed.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
3 weeks ago
I wanted to share the solution I was able to build in Flow Designer without using any custom actions or scripting.
I started with a Service Catalog trigger, then used Get Catalog Variables to retrieve the specific variables I needed.
To associate multiple RITMs with the REQ, I added a Look Up Record on the sc_request table to retrieve the Sys ID of the parent request.
From there, I applied If / Else If conditions based on the catalog variable checkboxes:
If IT Systems is true → update the primary Request Item record.
If Finance is true → create a Request Item record.
If Information Security is true → create a Request Item record.
For the Else If conditions:
If Information Security is true and IT Systems is false → update the primary Request Item.
If Finance is true → create a Request Item record.
For the final Else condition:
If IT Systems is false and Finance is true → update the primary Request Item.
If Information Security is true → create a new Request Item record.
Finally, I used an Update Request Record step.
The tricky part was ensuring that updates to the REQ didn’t wipe out values when non-primary RITMs were being updated (since the primary has the flow context attached to it). My workaround was to use the Look Up Trigger Service Catalog Request Item record to pull values from there.
Attempting to populate the REQ directly from the catalog variables would cause errors, but pulling them from the trigger record worked reliably.
I hope this helps!