api_integrations
Creates, updates, deletes, gets or lists an api_integrations
resource.
Overview
Name | api_integrations |
Type | Resource |
Id | snowflake.api_integration.api_integrations |
Fields
The following fields are returned by SELECT
queries:
- list_api_integrations
- fetch_api_integration
A Snowflake API integration object.
Name | Datatype | Description |
---|---|---|
name | string | Name of the API integration. (pattern: ^"([^"]|"")+"|[a-zA-Z_][a-zA-Z0-9_$]*$) |
api_allowed_prefixes | array | A comma-separated list of endpoints and resources that Snowflake can access. |
api_blocked_prefixes | array | A comma-separated list of endpoints and resources that are not allowed to be called from Snowflake. |
api_hook | object | |
comment | string | Comment for the API integration. |
created_on | string (date-time) | Date and time when the API integration was created. |
enabled | boolean | Whether the API integration is enabled. |
A Snowflake API integration object.
Name | Datatype | Description |
---|---|---|
name | string | Name of the API integration. (pattern: ^"([^"]|"")+"|[a-zA-Z_][a-zA-Z0-9_$]*$) |
api_allowed_prefixes | array | A comma-separated list of endpoints and resources that Snowflake can access. |
api_blocked_prefixes | array | A comma-separated list of endpoints and resources that are not allowed to be called from Snowflake. |
api_hook | object | |
comment | string | Comment for the API integration. |
created_on | string (date-time) | Date and time when the API integration was created. |
enabled | boolean | Whether the API integration is enabled. |
Methods
The following methods are available for this resource:
Name | Accessible by | Required Params | Optional Params | Description |
---|---|---|---|---|
list_api_integrations | select | endpoint | like | List API integrations |
fetch_api_integration | select | name , endpoint | Fetch an API integration | |
create_api_integration | insert | endpoint | createMode | Create an API integration |
create_or_alter_api_integration | replace | name , endpoint | Create an (or alter an existing) API integration. Note that API_KEY is not currently altered by this operation and is supported for a newly-created object only. Unsetting API_BLOCKED_PREFIXES is also unsupported. | |
delete_api_integration | delete | name , endpoint | ifExists | Delete an API integration |
Parameters
Parameters can be passed in the WHERE
clause of a query. Check the Methods section to see which parameters are required or optional for each operation.
Name | Datatype | Description |
---|---|---|
endpoint | string | Organization and Account Name (default: orgid-acctid) |
name | string | Identifier (i.e. name) for the resource. |
createMode | string | Query parameter allowing support for different modes of resource creation. Possible values include: - errorIfExists : Throws an error if you try to create a resource that already exists. - orReplace : Automatically replaces the existing resource with the current one. - ifNotExists : Creates a new resource when an alter is requested for a non-existent resource. |
ifExists | boolean | Query parameter that specifies how to handle the request for a resource that does not exist: - true : The endpoint does not throw an error if the resource does not exist. It returns a 200 success response, but does not take any action on the resource. - false : The endpoint throws an error if the resource doesn't exist. |
like | string | Query parameter to filter the command output by resource name. Uses case-insensitive pattern matching, with support for SQL wildcard characters. |
SELECT
examples
- list_api_integrations
- fetch_api_integration
List API integrations
SELECT
name,
api_allowed_prefixes,
api_blocked_prefixes,
api_hook,
comment,
created_on,
enabled
FROM snowflake.api_integration.api_integrations
WHERE endpoint = '{{ endpoint }}' -- required
AND like = '{{ like }}';
Fetch an API integration
SELECT
name,
api_allowed_prefixes,
api_blocked_prefixes,
api_hook,
comment,
created_on,
enabled
FROM snowflake.api_integration.api_integrations
WHERE name = '{{ name }}' -- required
AND endpoint = '{{ endpoint }}' -- required;
INSERT
examples
- create_api_integration
- Manifest
Create an API integration
INSERT INTO snowflake.api_integration.api_integrations (
data__name,
data__api_hook,
data__api_allowed_prefixes,
data__api_blocked_prefixes,
data__enabled,
data__comment,
endpoint,
createMode
)
SELECT
'{{ name }}' --required,
'{{ api_hook }}' --required,
'{{ api_allowed_prefixes }}' --required,
'{{ api_blocked_prefixes }}',
{{ enabled }} --required,
'{{ comment }}',
'{{ endpoint }}',
'{{ createMode }}'
;
# Description fields are for documentation purposes
- name: api_integrations
props:
- name: endpoint
value: string
description: Required parameter for the api_integrations resource.
- name: name
value: string
description: >
Name of the API integration.
- name: api_hook
value: object
- name: api_allowed_prefixes
value: array
description: >
A comma-separated list of endpoints and resources that Snowflake can access.
- name: api_blocked_prefixes
value: array
description: >
A comma-separated list of endpoints and resources that are not allowed to be called from Snowflake.
- name: enabled
value: boolean
description: >
Whether the API integration is enabled.
- name: comment
value: string
description: >
Comment for the API integration.
- name: createMode
value: string
description: Query parameter allowing support for different modes of resource creation. Possible values include: - `errorIfExists`: Throws an error if you try to create a resource that already exists. - `orReplace`: Automatically replaces the existing resource with the current one. - `ifNotExists`: Creates a new resource when an alter is requested for a non-existent resource.
REPLACE
examples
- create_or_alter_api_integration
Create an (or alter an existing) API integration. Note that API_KEY is not currently altered by this operation and is supported for a newly-created object only. Unsetting API_BLOCKED_PREFIXES is also unsupported.
REPLACE snowflake.api_integration.api_integrations
SET
data__name = '{{ name }}',
data__api_hook = '{{ api_hook }}',
data__api_allowed_prefixes = '{{ api_allowed_prefixes }}',
data__api_blocked_prefixes = '{{ api_blocked_prefixes }}',
data__enabled = {{ enabled }},
data__comment = '{{ comment }}'
WHERE
name = '{{ name }}' --required
AND endpoint = '{{ endpoint }}' --required
AND data__name = '{{ name }}' --required
AND data__api_hook = '{{ api_hook }}' --required
AND data__api_allowed_prefixes = '{{ api_allowed_prefixes }}' --required
AND data__enabled = {{ enabled }} --required;
DELETE
examples
- delete_api_integration
Delete an API integration
DELETE FROM snowflake.api_integration.api_integrations
WHERE name = '{{ name }}' --required
AND endpoint = '{{ endpoint }}' --required
AND ifExists = '{{ ifExists }}';