import { axios } from "@pipedream/platform";
export default {
key: "servicenow-get-table-record-by-sysid",
name: "Get Table Record By SysId",
description: "Retrieves the record identified by the specified sys_id from the specified table.",
version: "0.3.1",
type: "action",
props: {
servicenow: {
type: "app",
app: "servicenow",
},
table_name: {
type: "string",
description: "The name of the table containing the record to retrieve.",
},
sys_id: {
type: "string",
description: "Unique identifier of the record to retrieve.",
},
api_version: {
type: "string",
description: "API version number. Version numbers identify the endpoint version that a URI accesses. By specifying a version number in your URIs, you can ensure that future updates to the REST API do not negatively impact your integration. Use `lastest` to use the latest REST endpoint for your instance version.",
optional: true,
options: [
"lastest",
"v1",
"v2",
],
},
request_format: {
type: "string",
description: "Format of REST request body",
optional: true,
options: [
"application/json",
"application/xml",
"text/xml",
],
},
response_format: {
type: "string",
description: "Format of REST response body.",
optional: true,
options: [
"application/json",
"application/xml",
"text/xml",
],
},
sysparm_display_value: {
type: "string",
description: "Return field display values (true), actual values (false), or both (all) (default: false).",
optional: true,
options: [
"true",
"false",
"all",
],
},
sysparm_exclude_reference_link: {
type: "boolean",
description: "True to exclude Table API links for reference fields (default: false).",
optional: true,
},
sysparm_fields: {
type: "string",
description: "A comma-separated list of fields to return in the response.",
optional: true,
},
sysparm_view: {
type: "string",
description: "Render the response according to the specified UI view (overridden by sysparm_fields).",
optional: true,
},
sysparm_query_no_domain: {
type: "boolean",
description: "True to access data across domains if authorized (default: false).",
optional: true,
},
},
async run({ $ }) {
if (!this.table_name || !this.sys_id) {
throw new Error("Must provide table_name, and sys_id parameters.");
}
var apiVersion = "";
if (this.api_version == "v1" || this.api_version == "v2") {
apiVersion = this.api_version + "/";
}
return await axios($, {
url: `https://${this.servicenow.$auth.instance_name}.service-now.com/api/now/${apiVersion}table/${this.table_name}/${this.sys_id}`,
headers: {
"Authorization": `Bearer ${this.servicenow.$auth.oauth_access_token}`,
"Accept": this.request_format || "application/json",
"Content-Type": this.response_format || "application/json",
},
params: {
sysparm_display_value: this.sysparm_display_value,
sysparm_exclude_reference_link: this.sysparm_exclude_reference_link,
sysparm_fields: this.sysparm_fields,
sysparm_view: this.sysparm_view,
sysparm_query_no_domain: this.sysparm_query_no_domain,
},
});
},
};