All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.databricks.sdk.service.settings.IpAccessListsAPI Maven / Gradle / Ivy

The newest version!
// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT.
package com.databricks.sdk.service.settings;

import com.databricks.sdk.core.ApiClient;
import com.databricks.sdk.support.Generated;
import com.databricks.sdk.support.Paginator;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * IP Access List enables admins to configure IP access lists.
 *
 * 

IP access lists affect web application access and REST API access to this workspace only. If * the feature is disabled for a workspace, all access is allowed for this workspace. There is * support for allow lists (inclusion) and block lists (exclusion). * *

When a connection is attempted: 1. **First, all block lists are checked.** If the connection * IP address matches any block list, the connection is rejected. 2. **If the connection was not * rejected by block lists**, the IP address is compared with the allow lists. * *

If there is at least one allow list for the workspace, the connection is allowed only if the * IP address matches an allow list. If there are no allow lists for the workspace, all IP addresses * are allowed. * *

For all allow lists and block lists combined, the workspace supports a maximum of 1000 IP/CIDR * values, where one CIDR counts as a single value. * *

After changes to the IP access list feature, it can take a few minutes for changes to take * effect. */ @Generated public class IpAccessListsAPI { private static final Logger LOG = LoggerFactory.getLogger(IpAccessListsAPI.class); private final IpAccessListsService impl; /** Regular-use constructor */ public IpAccessListsAPI(ApiClient apiClient) { impl = new IpAccessListsImpl(apiClient); } /** Constructor for mocks */ public IpAccessListsAPI(IpAccessListsService mock) { impl = mock; } public CreateIpAccessListResponse create(String label, ListType listType) { return create(new CreateIpAccessList().setLabel(label).setListType(listType)); } /** * Create access list. * *

Creates an IP access list for this workspace. * *

A list can be an allow list or a block list. See the top of this file for a description of * how the server treats allow lists and block lists at runtime. * *

When creating or updating an IP access list: * *

* For all allow lists and block lists combined, the API supports a maximum of 1000 IP/CIDR * values, where one CIDR counts as a single value. Attempts to exceed that number return error * 400 with `error_code` value `QUOTA_EXCEEDED`. * If the new list would block the calling user's * current IP, error 400 is returned with `error_code` value `INVALID_STATE`. * *

It can take a few minutes for the changes to take effect. **Note**: Your new IP access list * has no effect until you enable the feature. See :method:workspaceconf/setStatus */ public CreateIpAccessListResponse create(CreateIpAccessList request) { return impl.create(request); } public void delete(String ipAccessListId) { delete(new DeleteIpAccessListRequest().setIpAccessListId(ipAccessListId)); } /** * Delete access list. * *

Deletes an IP access list, specified by its list ID. */ public void delete(DeleteIpAccessListRequest request) { impl.delete(request); } public FetchIpAccessListResponse get(String ipAccessListId) { return get(new GetIpAccessListRequest().setIpAccessListId(ipAccessListId)); } /** * Get access list. * *

Gets an IP access list, specified by its list ID. */ public FetchIpAccessListResponse get(GetIpAccessListRequest request) { return impl.get(request); } /** * Get access lists. * *

Gets all IP access lists for the specified workspace. */ public Iterable list() { return new Paginator<>( null, (Void v) -> impl.list(), ListIpAccessListResponse::getIpAccessLists, response -> null); } public void replace(String ipAccessListId, String label, ListType listType, boolean enabled) { replace( new ReplaceIpAccessList() .setIpAccessListId(ipAccessListId) .setLabel(label) .setListType(listType) .setEnabled(enabled)); } /** * Replace access list. * *

Replaces an IP access list, specified by its ID. * *

A list can include allow lists and block lists. See the top of this file for a description * of how the server treats allow lists and block lists at run time. When replacing an IP access * list: * For all allow lists and block lists combined, the API supports a maximum of 1000 * IP/CIDR values, where one CIDR counts as a single value. Attempts to exceed that number return * error 400 with `error_code` value `QUOTA_EXCEEDED`. * If the resulting list would block the * calling user's current IP, error 400 is returned with `error_code` value `INVALID_STATE`. It * can take a few minutes for the changes to take effect. Note that your resulting IP access list * has no effect until you enable the feature. See :method:workspaceconf/setStatus. */ public void replace(ReplaceIpAccessList request) { impl.replace(request); } public void update(String ipAccessListId) { update(new UpdateIpAccessList().setIpAccessListId(ipAccessListId)); } /** * Update access list. * *

Updates an existing IP access list, specified by its ID. * *

A list can include allow lists and block lists. See the top of this file for a description * of how the server treats allow lists and block lists at run time. * *

When updating an IP access list: * *

* For all allow lists and block lists combined, the API supports a maximum of 1000 IP/CIDR * values, where one CIDR counts as a single value. Attempts to exceed that number return error * 400 with `error_code` value `QUOTA_EXCEEDED`. * If the updated list would block the calling * user's current IP, error 400 is returned with `error_code` value `INVALID_STATE`. * *

It can take a few minutes for the changes to take effect. Note that your resulting IP access * list has no effect until you enable the feature. See :method:workspaceconf/setStatus. */ public void update(UpdateIpAccessList request) { impl.update(request); } public IpAccessListsService impl() { return impl; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy