@caido/sdk-frontend
This is the reference for the frontend SDK used by frontend plugins. Caido is the main interface that provides access to various services and functionalities.
SDK
Caido<T, E>
Caido<
T
,E
>:object
Utilities for frontend plugins.
Type Parameters
Type Parameter | Default type |
---|---|
T extends BackendEndpoints | Record <string , never > |
E extends BackendEvents | Record <string , never > |
Type declaration
backend
backend:
BackendSDK
<T
,E
>
Utilities to interact with the backend plugin.
commandPalette
commandPalette:
CommandPaletteSDK
Utilities to interact with the command palette.
commands
commands:
CommandsSDK
Utilities to interact with commands
env
env:
EnvironmentSDK
Utilities to interact with the environment.
files
files:
FilesSDK
Utilities to interact with the Files page.
filters
filters:
FiltersSDK
Utilities to interact with Filters page.
findings
findings:
FindingsSDK
Utilities to interact with findings
graphql
graphql:
GraphqlSDK
Utilities to interact with the GraphQL API.
httpHistory
httpHistory:
HTTPHistorySDK
Utilities to interact with the HTTP History page.
intercept
intercept:
InterceptSDK
Utilities to interact with the Intercept page.
matchReplace
matchReplace:
MatchReplaceSDK
Utilities to interact with Match and Replace page.
menu
menu:
MenuSDK
Utilities to insert menu items and context-menus throughout the UI.
navigation
navigation:
NavigationSDK
Utilities to interact with navigation.
replay
replay:
ReplaySDK
Utilities to interact with the Replay page.
scopes
scopes:
ScopesSDK
Utilities to interact with scopes
search
search:
SearchSDK
Utilities to interact with the Search page.
shortcuts
shortcuts:
ShortcutsSDK
Utilities to interact with shortcuts.
sidebar
sidebar:
SidebarSDK
Utilities to interact with the sidebar.
sitemap
sitemap:
SitemapSDK
Utilities to interact with the Sitemap page.
storage
storage:
StorageSDK
Utilities to interact with frontend-plugin storage.
ui
ui:
UISDK
Utilities to create UI components.
window
window:
WindowSDK
Utilities to interact with the active page.
Backend
BackendEndpoints
BackendEndpoints:
object
Endpoints provided by the backend plugin.
Index Signature
[key
: string
]: (...args
: any
[]) => any
BackendEvents
BackendEvents:
object
Events emitted by the backend plugin.
Index Signature
[key
: string
]: (...args
: any
[]) => void
BackendSDK<T, E>
BackendSDK<
T
,E
>:{ [K in keyof T]: (args: Parameters<T[K]>) => PromisifiedReturnType<T[K]> }
&object
Utilities to interact with the backend plugin.
Type declaration
onEvent()
onEvent: <
K
>(event
:K
,callback
:E
[K
]) =>object
Subscribe to a backend event.
Type Parameters
Type Parameter |
---|
K extends keyof E |
Parameters
Parameter | Type | Description |
---|---|---|
event | K | The event to subscribe to. |
callback | E [K ] | The callback to call when the event is emitted. |
Returns
object
An object with a stop
method that can be called to stop listening to the event.
stop()
stop: () =>
void
Returns
void
Type Parameters
Type Parameter |
---|
T extends BackendEndpoints |
E extends BackendEvents |
UI
UISDK
UISDK:
object
Utilities to create UI components.
Type declaration
button()
button: (
options
?:object
) =>HTMLElement
Create a button.
Parameters
Parameter | Type | Description |
---|---|---|
options ? | { label : string ; leadingIcon : Icon ; size : "small" | "medium" | "large" ; trailingIcon : Icon ; variant : "primary" | "secondary" | "tertiary" ; } | Options for the button. |
options.label ? | string | The label of the button. |
options.leadingIcon ? | Icon | The leading icon of the button. |
options.size ? | "small" | "medium" | "large" | The size of the button. |
options.trailingIcon ? | Icon | The trailing icon of the button. |
options.variant ? | "primary" | "secondary" | "tertiary" | The variant of the button. |
Returns
HTMLElement
The button element.
Example
const deleteButton = sdk.ui.button({
variant: "primary",
label: "Delete",
trailingIcon: "fas fa-trash-can",
size: "small",
});
card()
card: (
options
?:object
) =>HTMLElement
Create a card.
Parameters
Parameter | Type | Description |
---|---|---|
options ? | { body : HTMLElement ; footer : HTMLElement ; header : HTMLElement ; } | Options for the card. |
options.body ? | HTMLElement | The body of the card. |
options.footer ? | HTMLElement | The footer of the card. |
options.header ? | HTMLElement | The header of the card. |
Returns
HTMLElement
The card element.
httpRequestEditor()
httpRequestEditor: () =>
HTTPRequestEditor
Create an HTTP request editor
Returns
The HTTP request editor.
httpResponseEditor()
httpResponseEditor: () =>
HTTPResponseEditor
Create an HTTP response editor
Returns
The HTTP response editor.
well()
well: (
options
?:object
) =>HTMLElement
Create a well.
Parameters
Parameter | Type | Description |
---|---|---|
options ? | { body : HTMLElement ; footer : HTMLElement ; header : HTMLElement ; } | Options for the well. |
options.body ? | HTMLElement | The body of the well. |
options.footer ? | HTMLElement | The footer of the well. |
options.header ? | HTMLElement | The header of the well. |
Returns
HTMLElement
The well element.
Scopes
Scope
Scope:
object
Represents a scope.
Type declaration
allowlist
allowlist:
string
[]
The list of included items.
denylist
denylist:
string
[]
The list of excluded items.
id
id:
ID
The unique ID of the scope.
name
name:
string
The name of the scope.
ScopesSDK
ScopesSDK:
object
Utilities to interact with scopes
Type declaration
createScope()
createScope: (
options
:object
) =>Promise
<Scope
|undefined
>
Create a scope.
Parameters
Parameter | Type | Description |
---|---|---|
options | { allowlist : string []; denylist : string []; name : string ; } | Options for the scope. |
options.allowlist | string [] | The list of included items in the scope. |
options.denylist | string [] | The list of excluded items in the scope. |
options.name | string | The name of the scope. |
Returns
Promise
<Scope
| undefined
>
The created scope.
Example
const newScope = await sdk.scopes.createScope({
name: "Example",
allowlist: ["*example.com", "*github.com"],
denylist: ["*caido.io"],
});
deleteScope()
deleteScope: (
id
:ID
) =>Promise
<boolean
>
Delete a scope.
Parameters
Parameter | Type | Description |
---|---|---|
id | ID | The id of the scope to delete. |
Returns
Promise
<boolean
>
Whether the scope was deleted.
getScopes()
getScopes: () =>
Scope
[]
Get all scopes.
Returns
Scope
[]
A list of scopes.
updateScope()
updateScope: (
id
:ID
,options
:object
) =>Promise
<Scope
|undefined
>
Update a scope.
Parameters
Parameter | Type | Description |
---|---|---|
id | ID | The id of the scope to update. |
options | { allowlist : string []; denylist : string []; name : string ; } | Options for the scope. |
options.allowlist ? | string [] | The list of included items in the scope. |
options.denylist ? | string [] | The list of excluded items in the scope. |
options.name ? | string | The name of the scope. |
Returns
Promise
<Scope
| undefined
>
The updated scope.
Findings
Finding
Finding:
object
Represents a https://docs.caido.io/reference/features/logging/findings|Finding.
Type declaration
description?
optional
description:string
The description of the finding.
host
host:
string
The host of the request attached to this finding
id
id:
ID
The ID of the finding.
path
path:
string
The path of the request attached to this finding
reporter
reporter:
string
The reporter of the finding.
title
title:
string
The title of the finding.
FindingsSDK
FindingsSDK:
object
Utilities to interact with findings
Type declaration
createFinding()
createFinding: (
requestId
:ID
,options
:object
) =>Promise
<Finding
|undefined
>
Create a Finding.
Parameters
Parameter | Type | Description |
---|---|---|
requestId | ID | The id of the request the finding is associated with. |
options | { dedupeKey : string ; description : string ; reporter : string ; title : string ; } | Options for the finding. |
options.dedupeKey ? | string | If a finding with the same deduplication key already exists, it will not create a new finding. |
options.description ? | string | The description of the finding. |
options.reporter | string | The reporter of the finding. |
options.title | string | The title of the finding. |
Returns
Promise
<Finding
| undefined
>
The created finding.
Commands
CommandContext
CommandContext:
CommandContextBase
|CommandContextRequestRow
|CommandContextRequest
|CommandContextResponse
Represents the context in which a command is executed.
CommandContextBase
CommandContextBase:
object
The base context for a command. This context is used for commands that are not executed in a specific context, such as via shortcuts and the command palette.
Type declaration
type
type:
"BaseContext"
CommandContextRequest
CommandContextRequest:
object
The context for a command that is executed on a request pane.
Type declaration
request
request:
object
The request that is currently open in the request pane.
request.host
host:
string
request.isTls
isTls:
boolean
request.path
path:
string
request.port
port:
number
request.query
query:
string
request.raw
raw:
string
selection
selection:
string
The currently selected text in the request pane.
type
type:
"RequestContext"
CommandContextRequestRow
CommandContextRequestRow:
object
The context for a command that is executed on a row in the request table.
Type declaration
requests
requests:
object
[]
The requests that are selected in the request table.
type
type:
"RequestRowContext"
CommandContextResponse
CommandContextResponse:
object
The context for a command that is executed on a response pane.
Type declaration
request
request:
object
The request that is associated with the response.
request.host
host:
string
request.id
id:
ID
request.isTls
isTls:
boolean
request.path
path:
string
request.port
port:
number
request.query
query:
string
response
response:
object
The response that is currently open in the response pane.
response.id
id:
ID
response.raw
raw:
string
response.roundtripTime
roundtripTime:
number
response.statusCode
statusCode:
number
selection
selection:
string
The currently selected text in the response pane.
type
type:
"ResponseContext"
CommandsSDK
CommandsSDK:
object
Utilities to interact with commands
Type declaration
register()
register: (
id
:CommandID
,options
:object
) =>void
Register a command.
Parameters
Parameter | Type | Description |
---|---|---|
id | CommandID | The id of the command. |
options | { group : string ; name : string ; run : (context : CommandContext ) => void ; when : (context : CommandContext ) => boolean ; } | Options for the command. |
options.group ? | string | The group this command belongs to. |
options.name | string | The name of the command. |
options.run | (context : CommandContext ) => void | The function to run when the command is executed. |
options.when ? | (context : CommandContext ) => boolean | A function to determine if the command is available. |
Returns
void
Example
sdk.commands.register("hello", {
name: "Print to console.",
run: () => console.log("Hello world!"),
group: "Custom Commands",
});
Menu
MenuItem
MenuItem:
RequestRowMenuItem
|SettingsMenuItem
|RequestMenuItem
|ResponseMenuItem
A content-menu item.
MenuSDK
MenuSDK:
object
Utilities to insert menu items and context-menus throughout the UI.
Type declaration
registerItem()
registerItem: (
item
:MenuItem
) =>void
Register a menu item.
Parameters
Parameter | Type | Description |
---|---|---|
item | MenuItem | The menu item to register. |
Returns
void
Example
sdk.menu.registerItem({
type: "Request",
commandId: "hello",
leadingIcon: "fas fa-hand",
});
RequestMenuItem
RequestMenuItem:
object
A context-menu item that appears when right-clicking a request pane.
Type declaration
commandId
commandId:
CommandID
The command ID to execute when the menu item is clicked.
leadingIcon?
optional
leadingIcon:string
The icon to display to the left of the menu item.
type
type:
"Request"
RequestRowMenuItem
RequestRowMenuItem:
object
A context-menu item that appears when right-clicking a request row.
Type declaration
commandId
commandId:
CommandID
The command ID to execute when the menu item is clicked.
leadingIcon?
optional
leadingIcon:string
The icon to display to the left of the menu item.
type
type:
"RequestRow"
ResponseMenuItem
ResponseMenuItem:
object
A context-menu item that appears when right-clicking a response pane.
Type declaration
commandId
commandId:
CommandID
The command ID to execute when the menu item is
leadingIcon?
optional
leadingIcon:string
The icon to display to the left of the menu item.
type
type:
"Response"
SettingsMenuItem
SettingsMenuItem:
object
A menu item that appears in the settings menu.
Type declaration
label
label:
string
The label of the menu item.
leadingIcon?
optional
leadingIcon:Icon
The Icon to display to the left of the menu item.
path
path:
string
The path that the user will be navigated to when the menu item is clicked The path must start with "/settings/".
type
type:
"Settings"
Navigation
NavigationSDK
NavigationSDK:
object
Utilities to interact with navigation.
Type declaration
addPage()
addPage: (
path
:string
,options
:object
) =>void
Add a page to the navigation.
Parameters
Parameter | Type | Description |
---|---|---|
path | string | The path of the page. |
options | { body : HTMLElement ; onEnter : () => void ; topbar : HTMLElement ; } | Options for the page. |
options.body | HTMLElement | The body of the page. |
options.onEnter ? | () => void | The callback to execute when the page is entered. |
options.topbar ? | HTMLElement | The topbar of the page. |
Returns
void
goTo()
goTo: (
path
:string
) =>void
Navigate to a path.
Parameters
Parameter | Type | Description |
---|---|---|
path | string | The path to navigate to. |
Returns
void
Example
sdk.navigation.goTo("/my-plugin-page");
Window
WindowSDK
WindowSDK:
object
Utilities to interact with the active page.
Type declaration
getActiveEditor()
getActiveEditor: () =>
Editor
|undefined
Get the active editor.
Returns
Editor
| undefined
The active editor.
showToast()
showToast: (
message
:string
,options
?:object
) =>void
Show a toast message.
Parameters
Parameter | Type | Description |
---|---|---|
message | string | The message to show. |
options ? | { duration : number ; variant : "success" | "error" | "warning" | "info" ; } | Options for the toast message. |
options.duration ? | number | The duration of the toast message in milliseconds. |
options.variant ? | "success" | "error" | "warning" | "info" | The variant of the toast message. |
Returns
void
Storage
StorageSDK
StorageSDK:
object
Utilities to interact with frontend-plugin storage.
Type declaration
get()
get: () =>
JSONValue
Get the storage.
Returns
The storage.
onChange()
onChange: (
callback
: (value
:JSONValue
) =>void
) =>void
Subscribe to storage changes.
Parameters
Parameter | Type | Description |
---|---|---|
callback | (value : JSONValue ) => void | The callback to call when the storage changes. |
Returns
void
set()
set: <
T
>(value
:JSONCompatible
<T
>) =>Promise
<void
>
Set the storage.
Type Parameters
Type Parameter |
---|
T |
Parameters
Parameter | Type | Description |
---|---|---|
value | JSONCompatible <T > | The value to set the storage to |
Returns
Promise
<void
>
A promise that resolves when the storage has been set.
Shortcuts
ShortcutsSDK
ShortcutsSDK:
object
Utilities to interact with shortcuts.
Type declaration
register()
register: (
commandId
:CommandID
,keys
:string
[]) =>void
Register a shortcut.
Parameters
Parameter | Type | Description |
---|---|---|
commandId | CommandID | The id of the command to run when the shortcut is triggered. |
keys | string [] | The keys of the shortcut. Check out hotkeys-js for the list of supported keys. |
Returns
void
Command Palette
CommandPaletteSDK
CommandPaletteSDK:
object
Utilities to interact with the command palette.
Type declaration
register()
register: (
commandId
:string
) =>void
Register a command.
Parameters
Parameter | Type | Description |
---|---|---|
commandId | string | The id of the command to register. |
Returns
void
Sidebar
SidebarItem
SidebarItem:
object
Represents a sidebar item.
Type declaration
setCount()
setCount: (
count
:number
) =>void
Set the value of a notification badge next to the sidebar item.
Parameters
Parameter | Type | Description |
---|---|---|
count | number | The number to display in the badge. A value of 0 will hide the badge. |
Returns
void
SidebarSDK
SidebarSDK:
object
Utilities to interact with the sidebar.
Type declaration
registerItem()
registerItem: (
name
:string
,path
:string
,options
?:object
) =>SidebarItem
Register a sidebar item.
Parameters
Parameter | Type | Description |
---|---|---|
name | string | The name of the sidebar item. |
path | string | The path that the user will be navigated to when the sidebar item is clicked. |
options ? | { group : string ; icon : Icon ; isExternal : boolean ; } | Options for the sidebar item. |
options.group ? | string | The group the sidebar item belongs to. |
options.icon ? | Icon | The Icon of the sidebar item. |
options.isExternal ? | boolean | Whether the path points to an external URL. |
Returns
The created sidebar item.
Example
sdk.sidebar.registerItem("My Plugin", "/my-plugin-page", {
icon: "fas fa-rocket",
});
Replay
ReplayCollection
ReplayCollection:
object
A collection in Replay.
Type declaration
id
id:
ID
The ID of the collection.
name
name:
string
The name of the collection.
sessionIds
sessionIds:
ID
[]
The sessions in the collection.
ReplaySDK
ReplaySDK:
object
Utilities to interact with Replay.
Type declaration
closeTab()
closeTab: (
sessionId
:ID
) =>void
Close a replay tab for the given session.
Parameters
Parameter | Type | Description |
---|---|---|
sessionId | ID | The ID of the session to close. |
Returns
void
getCollections()
getCollections: () =>
ReplayCollection
[]
Get the list of all replay collections.
Returns
The list of all replay collections.
getSessions()
getSessions: () =>
ReplaySession
[]
Get the list of all replay sessions.
Returns
The list of all replay sessions.
getTabs()
getTabs: () =>
ReplayTab
[]
Get the list of all open replay tabs.
Returns
The list of all open replay tabs.
openTab()
openTab: (
sessionId
:ID
) =>void
Open a replay tab for the given session.
Parameters
Parameter | Type | Description |
---|---|---|
sessionId | ID | The ID of the session to open. |
Returns
void
renameSession()
renameSession: (
id
:ID
,name
:string
) =>Promise
<ReplaySession
>
Rename a session.
Parameters
Parameter | Type | Description |
---|---|---|
id | ID | The ID of the session to rename. |
name | string | The new name of the session. |
Returns
Promise
<ReplaySession
>
The updated session.
ReplaySession
ReplaySession:
object
A session in Replay.
Type declaration
collectionId
collectionId:
ID
The ID of the collection the session belongs to.
id
id:
ID
The ID of the session.
name
name:
string
The name of the session.
ReplayTab
ReplayTab:
object
A replay tab.
Type declaration
sessionId
sessionId:
ID
The ID of the session associated with this tab.
HTTP History
HTTPHistorySDK
HTTPHistorySDK:
object
Utilities to interact with the HTTP History page.
Type declaration
getQuery()
getQuery: () =>
HTTPQL
Get the current HTTPQL query.
Returns
The current HTTPQL query.
getScopeId()
getScopeId: () =>
ID
|undefined
Get the current scope ID.
Returns
ID
| undefined
The current scope ID.
setQuery()
setQuery: (
query
:HTTPQL
) =>void
Set the HTTPQL query that will be applied on the HTTP History table results.
Parameters
Parameter | Type | Description |
---|---|---|
query | HTTPQL | The HTTPQL query. |
Returns
void
setScope()
setScope: (
id
:ID
|undefined
) =>Promise
<void
>
Set the current scope.
Parameters
Parameter | Type | Description |
---|---|---|
id | ID | undefined | The ID of the scope to set. |
Returns
Promise
<void
>
Search
SearchSDK
SearchSDK:
object
Utilities to interact with the Search page.
Type declaration
getQuery()
getQuery: () =>
HTTPQL
Get the current HTTPQL query.
Returns
The current HTTPQL query.
getScopeId()
getScopeId: () =>
ID
|undefined
Get the current scope ID.
Returns
ID
| undefined
The current scope ID.
setQuery()
setQuery: (
query
:HTTPQL
) =>void
Set the HTTPQL query that will be applied on the search table results.
Parameters
Parameter | Type | Description |
---|---|---|
query | HTTPQL | The HTTPQL query. |
Returns
void
setScope()
setScope: (
id
:ID
|undefined
) =>Promise
<void
>
Set the current scope.
Parameters
Parameter | Type | Description |
---|---|---|
id | ID | undefined | The ID of the scope to set. |
Returns
Promise
<void
>
Files
FilesSDK
FilesSDK:
object
SDK for interacting with the Files page.
Type declaration
create()
create: (
file
:File
) =>Promise
<HostedFile
>
Uploads a file to the host.
Parameters
Parameter | Type | Description |
---|---|---|
file | File | The file to upload. |
Returns
Promise
<HostedFile
>
The uploaded file.
delete()
delete: (
id
:string
) =>Promise
<void
>
Deletes a file from the host.
Parameters
Parameter | Type | Description |
---|---|---|
id | string | The ID of the file to delete. |
Returns
Promise
<void
>
The deleted file.
getAll()
getAll: () =>
HostedFile
[]
Gets all hosted files.
Returns
The files.
rename()
rename: (
id
:string
,name
:string
) =>Promise
<HostedFile
>
Renames a file on the host.
Parameters
Parameter | Type | Description |
---|---|---|
id | string | The ID of the file to rename. |
name | string | The new name of the file. |
Returns
Promise
<HostedFile
>
The renamed file.
HostedFile
HostedFile:
object
A hosted file.
Type declaration
createdAt
createdAt:
Date
The date the file was created.
id
id:
string
The ID of the file.
name
name:
string
The name of the file.
path
path:
string
The path of the file.
size
size:
number
The size of the file in bytes.
updatedAt
updatedAt:
Date
The date the file was updated.
Environment
EnvironmentSDK
EnvironmentSDK:
object
Utilities to interact with the environment.
Type declaration
getVar()
getVar: (
name
:string
) =>string
|undefined
Get the value of an environment variable.
Parameters
Parameter | Type | Description |
---|---|---|
name | string | The name of the environment variable. |
Returns
string
| undefined
The value of the environment variable.
getVars()
getVars: () =>
EnvironmentVariable
[]
Get all environment variables available in the global environment and the selected environment.
Returns
All environment variables.
Filters
Filter
Filter:
object
Represents a filter.
Type declaration
alias
alias:
string
The alias of the filter. This alias is used when referencing the filter in an HTTPQL query (e.g. preset:my-alias
).
id
id:
ID
The ID of the filter.
name
name:
string
The name of the filter.
query
query:
HTTPQL
The HTTPQL expression of the filter.
FiltersSDK
FiltersSDK:
object
SDK for interacting with the Filters page.
Type declaration
create()
create: (
options
:object
) =>Promise
<Filter
>
Creates a filter.
Parameters
Parameter | Type | Description |
---|---|---|
options | { alias : string ; name : string ; query : HTTPQL ; } | Options for the filter. |
options.alias | string | The alias of the filter. Used when referencing the filter in an HTTPQL query (e.g. preset:my-alias ). Should be unique and follow the format [a-zA-Z0-9_-]+ . |
options.name | string | The name of the filter. Should be unique. |
options.query | HTTPQL | The HTTPQL query of the filter. |
Returns
Promise
<Filter
>
The created filter.
delete()
delete: (
id
:ID
) =>Promise
<void
>
Deletes a filter.
Parameters
Parameter | Type | Description |
---|---|---|
id | ID | The ID of the filter to delete. |
Returns
Promise
<void
>
getAll()
getAll: () =>
Filter
[]
Gets all filters.
Returns
Filter
[]
The filters.
update()
Updates a filter.
Parameters
Parameter | Type | Description |
---|---|---|
id | ID | The ID of the filter to update. |
options | { alias : string ; name : string ; query : HTTPQL ; } | Options for the filter. |
options.alias | string | The alias of the filter. |
options.name | string | The name of the filter. |
options.query | HTTPQL | The HTTPQL query of the filter. |
Returns
Promise
<Filter
>
The updated filter.
Intercept
InterceptSDK
InterceptSDK:
object
Utilities to interact with the Intercept page.
Type declaration
getScopeId()
getScopeId: () =>
ID
|undefined
Get the current scope ID.
Returns
ID
| undefined
The current scope ID.
setScope()
setScope: (
id
:ID
|undefined
) =>void
Set the current scope.
Parameters
Parameter | Type |
---|---|
id | ID | undefined |
Returns
void
Match and Replace
MatchReplaceCollection
MatchReplaceCollection:
object
A collection in Match and Replace.
Type declaration
id
id:
ID
name
name:
string
ruleIds
ruleIds:
ID
[]
MatchReplaceRule
MatchReplaceRule:
object
A rule in Match and Replace.
Type declaration
collectionId
collectionId:
ID
The ID of the collection the rule belongs to.
id
id:
ID
The ID of the rule.
isEnabled
isEnabled:
boolean
Whether the rule is enabled.
isRegex
isRegex:
boolean
Whether the match term is a regex.
matchTerm
matchTerm:
string
The match term of the rule.
name
name:
string
The name of the rule.
query
query:
HTTPQL
The HTTPQL query to match the rule against. Only requests that match the query will be affected by the rule.
replaceTerm
replaceTerm:
string
The replace term of the rule.
strategy
strategy:
MatchReplaceStrategy
The strategy of the rule.
MatchReplaceSDK
MatchReplaceSDK:
object
Utilities to interact with the Match and Replace page.
Type declaration
createCollection()
createCollection: (
options
:object
) =>Promise
<MatchReplaceCollection
>
Create a collection.
Parameters
Parameter | Type | Description |
---|---|---|
options | { name : string ; } | The options for the collection. |
options.name | string | The name of the collection. |
Returns
Promise
<MatchReplaceCollection
>
createRule()
createRule: (
options
:object
) =>Promise
<MatchReplaceRule
>
Create a rule.
Parameters
Parameter | Type | Description |
---|---|---|
options | { collectionId : ID ; isEnabled : boolean ; isRegex : boolean ; matchTerm : string ; name : string ; query : HTTPQL ; replaceTerm : string ; strategy : MatchReplaceStrategy ; } | The options for the rule. |
options.collectionId | ID | The ID of the collection the rule belongs to. |
options.isEnabled | boolean | Whether the rule is enabled. |
options.isRegex | boolean | Whether the match term is a regex. |
options.matchTerm | string | The match term of the rule. |
options.name | string | The name of the rule. |
options.query | HTTPQL | The HTTPQL query to match the rule against. |
options.replaceTerm | string | The replace term of the rule. |
options.strategy | MatchReplaceStrategy | The strategy of the rule. |
Returns
Promise
<MatchReplaceRule
>
deleteCollection()
deleteCollection: (
id
:ID
) =>Promise
<void
>
Delete a collection.
Parameters
Parameter | Type | Description |
---|---|---|
id | ID | The ID of the collection. |
Returns
Promise
<void
>
deleteRule()
deleteRule: (
id
:ID
) =>Promise
<void
>
Delete a rule.
Parameters
Parameter | Type | Description |
---|---|---|
id | ID | The ID of the rule. |
Returns
Promise
<void
>
getActiveRules()
getActiveRules: () =>
MatchReplaceRule
[]
Get all active rules. Rules are ordered in priority from highest to lowest.
Returns
All active rules.
getCollections()
getCollections: () =>
MatchReplaceCollection
[]
Get all collections.
Returns
getRules()
getRules: () =>
MatchReplaceRule
[]
Get all rules.
Returns
All rules.
selectRule()
selectRule: (
id
:ID
|undefined
) =>void
Select a rule to be displayed in the UI.
Parameters
Parameter | Type | Description |
---|---|---|
id | ID | undefined | The ID of the rule, or undefined to clear the selection. |
Returns
void
updateCollection()
updateCollection: (
id
:ID
,options
:object
) =>Promise
<MatchReplaceCollection
>
Update a collection.
Parameters
Parameter | Type | Description |
---|---|---|
id | ID | The ID of the collection. |
options | { name : string ; } | The new values for the collection. |
options.name | string | The new name of the collection. |
Returns
Promise
<MatchReplaceCollection
>
updateRule()
updateRule: (
id
:ID
,options
:object
) =>Promise
<MatchReplaceRule
>
Update a rule.
Parameters
Parameter | Type | Description |
---|---|---|
id | ID | The ID of the rule. |
options | { isEnabled : boolean ; isRegex : boolean ; matchTerm : string ; name : string ; query : HTTPQL ; replaceTerm : string ; strategy : MatchReplaceStrategy ; } | The new values for the rule. |
options.isEnabled | boolean | Whether the rule is enabled. |
options.isRegex | boolean | Whether the match term is a regex. |
options.matchTerm | string | The new match term of the rule. |
options.name | string | The new name of the rule. |
options.query | HTTPQL | The new HTTPQL query of the rule. |
options.replaceTerm | string | The new replace term of the rule. |
options.strategy | MatchReplaceStrategy | The new strategy of the rule. |
Returns
Promise
<MatchReplaceRule
>
Other
CommandID
CommandID:
string
&object
A unique command identifier.
Type declaration
__commandId?
optional
__commandId:never
Example
"my-super-command"
Editor
Editor:
object
Generic editor interface.
Type declaration
focus()
focus: () =>
void
Focus the editor.
Returns
void
getEditorView()
getEditorView: () =>
EditorView
Get the editor view.
Returns
EditorView
The CodeMirror EditorView.
getSelectedText()
getSelectedText: () =>
string
Get the currently selected text of the editor.
Returns
string
isReadOnly()
isReadOnly: () =>
boolean
Check whether the editor is read-only.
Returns
boolean
Whether the editor is read-only.
replaceSelectedText()
replaceSelectedText: (
text
:string
) =>void
Replace the currently selected text of the editor.
Parameters
Parameter | Type | Description |
---|---|---|
text | string | The text to replace the selection with. |
Returns
void
EnvironmentVariable
EnvironmentVariable:
object
Type declaration
isSecret
isSecret:
boolean
Whether the environment variable is a secret.
name
name:
string
The name of the environment variable.
value
value:
string
The value of the environment variable.
HTTPQL
HTTPQL:
string
&object
An HTTPQL expression.
Type declaration
__httpql?
optional
__httpql:never
Example
`req.method.eq:"POST"`
HTTPRequestEditor
HTTPRequestEditor:
object
Type declaration
getEditorView()
getEditorView: () =>
EditorView
Get the editor view.
Returns
EditorView
The CodeMirror EditorView.
getElement()
getElement: () =>
HTMLElement
Get the editor element. Append this to your DOM to display the editor.
Returns
HTMLElement
The editor element.
HTTPResponseEditor
HTTPResponseEditor:
object
Type declaration
getEditorView()
getEditorView: () =>
EditorView
Get the editor view.
Returns
EditorView
The CodeMirror EditorView.
getElement()
getElement: () =>
HTMLElement
Get the editor element. Append this to your DOM to display the editor.
Returns
HTMLElement
The editor element.
Icon
Icon:
string
&object
A https://fontawesome.com/icons|FontAwesome icon class.
Type declaration
__icon?
optional
__icon:never
Example
"fas fa-rocket"
ID
ID:
string
&object
A unique Caido identifier per type.
Type declaration
__id?
optional
__id:never
JSONCompatible<T>
JSONCompatible<
T
>:unknown
extendsT
?never
:{ [P in keyof T]: T[P] extends JSONValue ? T[P] : T[P] extends NotAssignableToJson ? never : JSONCompatible<T[P]> }
Type Parameters
Type Parameter |
---|
T |
JSONPrimitive
JSONPrimitive:
string
|number
|boolean
|null
|undefined
JSONValue
JSONValue:
JSONPrimitive
|JSONValue
[] | {}
MatchReplaceStrategy
MatchReplaceStrategy:
"REQUEST_FIRST_LINE"
|"REQUEST_HEADER"
|"REQUEST_BODY"
|"RESPONSE_FIRST_LINE"
|"RESPONSE_HEADER"
|"RESPONSE_BODY"
NotAssignableToJson
NotAssignableToJson:
bigint
|symbol
|Function
PromisifiedReturnType<T>
PromisifiedReturnType<
T
>:ReturnType
<T
> extendsPromise
<infer U> ?Promise
<U
> :Promise
<ReturnType
<T
>>
Type Parameters
Type Parameter |
---|
T extends (...args : unknown []) => unknown |
Sitemap
SitemapSDK
SitemapSDK:
object
Utilities to interact with the Sitemap page.
Type declaration
getScopeId()
getScopeId: () =>
ID
|undefined
Get the current scope ID.
Returns
ID
| undefined
The current scope ID.
setScope()
setScope: (
id
:ID
|undefined
) =>void
Set the current scope.
Parameters
Parameter | Type | Description |
---|---|---|
id | ID | undefined | The ID of the scope to set. |
Returns
void