wso2.apim.catalog
Module wso2.apim.catalog
API
Declarations
ballerinax/wso2.apim.catalog Ballerina library
Ballerina WSO2 APIM Catalog Publisher
Overview
The Ballerina WSO2 APIM catalog publisher module includes ballerina service management tools for publishing service data to WSO2 API manager service catalogs.
Quickstart
- Add
import ballerinax/wso2.apim.catalog as _;
to the default module. - Add
remoteManagement=true
to[build-options]
section of the Ballerina.toml file. - Create Config.toml file if it does not exist, and add the following configurations.
Modify the configurations to match your WSO2 APIM manager.[ballerinax.wso2.apim.catalog] serviceUrl="<Url of the service catalog endpoint>" tokenUrl="<Url of the token endpoint>" username="<username>" password="<password>" clientId="<clientId>" clientSecret="<Client secret>"
- Run the project with the following command.
$ bal run
Examples
import ballerina/http; import ballerinax/wso2.apim.catalog as _; service /sales0 on new http:Listener(9000) { // implementation }
Useful links
- Chat live with us via our Discord server.
- Post all technical questions on Stack Overflow with the #ballerina tag.
Clientsdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
wso2.apim.catalog: Clientdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
This specifies a RESTful API for Service Catalog.
Constructordata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
Gets invoked to initialize the connector
.
init (ConnectionConfig config, string serviceUrl)
- config ConnectionConfig - The configurations to be used when initializing the
connector
- serviceUrl string "https://apis.wso2.com/api/service-catalog/v1" - URL of the target service
get servicesdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
function get services(string? name, string? version, "OAS"|"WSDL1"|"WSDL2"|"GRAPHQL_SDL"|"ASYNC_API"? definitionType, string? 'key, boolean shrink, "name"|"definitionType"? sortBy, "asc"|"desc"? sortOrder, int 'limit, int offset) returns ServiceList|error
Retrieve/search services
Parameters
- name string? (default ()) - Filter services by the name of the service
- version string? (default ()) - Filter services by version of the service
- definitionType "OAS"|"WSDL1"|"WSDL2"|"GRAPHQL_SDL"|"ASYNC_API"? (default ()) - Filter services by definitionType
- 'key string? (default ()) - Comma seperated keys of the services to check
- shrink boolean (default false) - If this set to true, a minimal set of fields will be provided for each service including the md5
- sortBy "name"|"definitionType"? (default ()) -
- sortOrder "asc"|"desc"? (default ()) -
- 'limit int (default 25) - Maximum limit of items to return.
- offset int (default 0) - Starting point within the complete list of items qualified.
Return Type
- ServiceList|error - Paginated matched list of services returned.
post servicesdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
function post services(ServiceSchema payload) returns Service|error
Add a new service to Service Catalog
Parameters
- payload ServiceSchema -
Return Type
get services/[string serviceId]data:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
Get details of a service
put services/[string serviceId]data:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
function put services/[string serviceId](ServiceSchema payload) returns Service|error
Update a service
Parameters
- payload ServiceSchema -
Return Type
delete services/[string serviceId]data:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
Delete a service
get services/[string serviceId]/definitiondata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
Retrieve a service definition
get services/[string serviceId]/usagedata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
Retrieve the API Info that use the given service
post services/'importdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
function post services/'import(Services_import_body payload, boolean overwrite) returns ServiceInfoList|error
Import a service
Parameters
- payload Services_import_body -
- overwrite boolean (default false) - Whether to overwrite if there is any existing service with the same name and version.
Return Type
- ServiceInfoList|error - Successful response with the imported service metadata.
get services/exportdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
Export a service
Parameters
- name string - Name of the service to export
- version string - Version of the service to export
Return Type
- byte[]|error - Successful response as the exported service as a zipped archive.
get settingsdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
Retrieve service catalog API settings
Authentication
Our REST APIs are protected using OAuth2 and access control is achieved through scopes. Before you start invoking the the API you need to obtain an access token with the required scopes. This guide will walk you through the steps that you will need to follow to obtain an access token. First you need to obtain the consumer key/secret key pair by calling the dynamic client registration (DCR) endpoint. You can add your preferred grant types in the payload. A Sample payload is shown below.
Enumsdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
wso2.apim.catalog: DefinitionTypedata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
Members
wso2.apim.catalog: SecurityTypedata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
Members
Listenersdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
wso2.apim.catalog: Listenerdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
attachdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
'startdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
function 'start() returns error?
gracefulStopdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
function gracefulStop() returns error?
immediateStopdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
function immediateStop() returns error?
detachdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
function detach(service object {} s) returns error?
Parameters
- s service object {} -
Annotationsdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
wso2.apim.catalog: ServiceCatalogConfigdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
Configurablesdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
wso2.apim.catalog: serviceUrldata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
wso2.apim.catalog: usernamedata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
wso2.apim.catalog: passworddata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
wso2.apim.catalog: clientIddata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
wso2.apim.catalog: clientSecretdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
wso2.apim.catalog: tokenUrldata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
wso2.apim.catalog: portdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
wso2.apim.catalog: clientSecureSocketpathdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
wso2.apim.catalog: clientSecureSocketpassworddata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
wso2.apim.catalog: serverCertdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
wso2.apim.catalog: scopesdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
Recordsdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
wso2.apim.catalog: APIInfodata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
Fields
- id? string -
- name? string -
- context? string -
- version? string -
- provider? string -
wso2.apim.catalog: APIListdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
Fields
- count? int - Number of APIs returned.
- list? APIInfo[] -
wso2.apim.catalog: ClientHttp1Settingsdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
Provides settings related to HTTP/1.x protocol.
Fields
- keepAlive KeepAlive(default http:KEEPALIVE_AUTO) - Specifies whether to reuse a connection for multiple requests
- chunking Chunking(default http:CHUNKING_AUTO) - The chunking behaviour of the request
- proxy? ProxyConfig - Proxy server related options
wso2.apim.catalog: ConnectionConfigdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
Provides a set of configurations for controlling the behaviours when communicating with a remote HTTP endpoint.
Fields
- auth OAuth2PasswordGrantConfig - Configurations related to client authentication
- httpVersion HttpVersion(default http:HTTP_2_0) - The HTTP version understood by the client
- http1Settings? ClientHttp1Settings - Configurations related to HTTP/1.x protocol
- http2Settings? ClientHttp2Settings - Configurations related to HTTP/2 protocol
- timeout decimal(default 60) - The maximum time to wait (in seconds) for a response before closing the connection
- forwarded string(default "disable") - The choice of setting
forwarded
/x-forwarded
header
- poolConfig? PoolConfiguration - Configurations associated with request pooling
- cache? CacheConfig - HTTP caching related configurations
- compression Compression(default http:COMPRESSION_AUTO) - Specifies the way of handling compression (
accept-encoding
) header
- circuitBreaker? CircuitBreakerConfig - Configurations associated with the behaviour of the Circuit Breaker
- retryConfig? RetryConfig - Configurations associated with retrying
- responseLimits? ResponseLimitConfigs - Configurations associated with inbound response size limits
- secureSocket? ClientSecureSocket - SSL/TLS-related options
- proxy? ProxyConfig - Proxy server related options
- validation boolean(default true) - Enables the inbound payload validation functionality which provided by the constraint package. Enabled by default
wso2.apim.catalog: Errordata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
Fields
- code int -
- message string - Error message.
- description? string - A detail description about the error message.
- moreInfo? string - Preferably an url with more details about the error.
- 'error? ErrorListItem[] - If there are more than one error list them out. For example, list out validation errors by each field.
wso2.apim.catalog: ErrorListItemdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
Fields
- code string -
- message string - Description about individual errors occurred
- description? string - A detail description about the error message.
wso2.apim.catalog: OAuth2PasswordGrantConfigdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
OAuth2 Password Grant Configs
Fields
- Fields Included from *OAuth2PasswordGrantConfig
- tokenUrl string
- username string
- password string
- clientId string
- clientSecret string
- scopes string|string[]
- refreshConfig RefreshConfig|"INFER_REFRESH_CONFIG"
- defaultTokenExpTime decimal
- clockSkew decimal
- optionalParams map<string>
- credentialBearer CredentialBearer
- clientConfig ClientConfiguration
- tokenUrl string(default "https://localhost:9443/oauth2/token") - Token URL
wso2.apim.catalog: Paginationdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
Fields
- offset? int -
- 'limit? int -
- total? int -
- next? string - Link to the next subset of resources qualified. Empty if no more resources are to be returned.
- previous? string - Link to the previous subset of resources qualified. Empty if current subset is the first subset returned.
wso2.apim.catalog: ProxyConfigdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
Proxy server configurations to be used with the HTTP client endpoint.
Fields
- host string(default "") - Host name of the proxy server
- port int(default 0) - Proxy server port
- userName string(default "") - Proxy server username
- password string(default "") - Proxy server password
wso2.apim.catalog: Servicedata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
Fields
- id? string -
- name string -
- description? string -
- version string -
- serviceKey? string -
- serviceUrl string -
- definitionType "OAS2"|"OAS3"|"WSDL1"|"WSDL2"|"GRAPHQL_SDL"|"ASYNC_API" - The type of the provided API definition
- securityType "BASIC"|"DIGEST"|"OAUTH2"|"X509"|"API_KEY"|"NONE" (default "NONE") - The security type of the endpoint
- mutualSSLEnabled boolean(default false) - Whether Mutual SSL is enabled for the endpoint
- usage? int - Number of usages of the service in APIs
- createdTime? string -
- lastUpdatedTime? string -
- md5? string -
- definitionUrl? string -
wso2.apim.catalog: ServiceArtifactdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
Fields
- name string -
- description string(default "") -
- version string(default "_") -
- serviceKey string -
- serviceUrl string -
- definitionType DefinitionType -
- securityType SecurityType(default "BASIC") -
- mutualSSLEnabled boolean(default false) -
- usage int(default 1) -
- createdTime string -
- lastUpdatedTime string -
- md5 string -
- definitionUrl string -
- definitionFileContent string(default "") -
wso2.apim.catalog: ServiceCatalogMetaDatadata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
Fields
- openApiDefinition byte[](default []) -
wso2.apim.catalog: ServiceInfodata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
Fields
- id? string -
- name? string -
- 'key? string -
- version? string -
- md5? string -
wso2.apim.catalog: ServiceInfoListdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
Fields
- count? int - MD5 hashes of services returned.
- list? ServiceInfo[] -
wso2.apim.catalog: ServiceListdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
Fields
- list? Service[] -
- pagination? Pagination -
wso2.apim.catalog: ServiceListExpandeddata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
Fields
- count? int - MD5 hashes of services returned.
- list? Service[] -
- pagination? Pagination -
wso2.apim.catalog: Services_import_bodydata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
Fields
- file record { fileContent byte[], fileName string } - Zip archive consisting of exported Application Configuration.
- verifier? string -
wso2.apim.catalog: ServiceSchemadata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
Fields
- serviceMetadata Service -
- definitionFile? record { fileContent byte[], fileName string } -
- inlineContent? string - Inline content of the document
wso2.apim.catalog: Settingsdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
Fields
- scopes? string[] -
wso2.apim.catalog: Verifierdata:image/s3,"s3://crabby-images/64a4a/64a4a52b2f4bf67d72ad3ea7eaa96c517a9bf56c" alt=""
Fields
- 'key string -
- md5 string -
Import
import ballerinax/wso2.apim.catalog;
Metadata
Released date: 5 months ago
Version: 1.0.0
Compatibility
Platform: java17
Ballerina version: 2201.10.0
GraalVM compatible: Yes
Pull count
Total: 5
Current verison: 5
Weekly downloads
Other versions
1.0.0