Public IPs

Public IP addresses are used to communicate over the Internet. Examples of these include AWS Elastic IPs and OpenStack Floating IPs. This class inherits from TopLevelResource and has direct access to the resource’s database object. The following attributes are directly accessible:

attr resource_id:
 The primary resource identifier that takes the form of a prefix followed by numbers and letters
attr organization_service_id:
 The ID of the parent organization service (cloud)
attr region_name:
 The region that the public IP resides in
attr public_ip:The publicly accessible IP address
attr private_ip:
 The private IP that this public IP will pass through to
attr domain:The domain associated with this public IP
attr network_interface_resource_id:
 The resource ID of the network interface the IP is associated to
attr allocation_id:
 The provider allocation ID of the public IP
attr association_id:
 The provider association ID
attr allocation_type:
 Denotes an ephemeral vs persistent IP address
class DivvyResource.Resources.publicip.PublicIp(resource_id)

Bases: DivvyResource.Resources.toplevelresource.TopLevelResource

IP Address operations (Elastic/Floating/Public IPs)

Delete this resource. If wrapped in a with JobQueue() block, this will queue the deletion job to the wrapped queue, otherwise it
calls immediately.

Retrieve the attached instance (Resource object)


Retrieve the network interface (Resource object) this IP is attached to, or None if not attached

static get_db_class()

Retrieve the domain of the resource (eg: vpc)

static get_provider_id_field()

Public IPs are not named by the user. We return the ip address itself

static get_resource_name_field()
static get_resource_type()
handle_resource_created(user_resource_id=None, project_resource_id=None)

This should be called when a resource is created/discovered after the basic data is added to the database. This gives an opportunity for post-addition hooks (assignment to projects/groups, alerts, etc)


This should be called when a resource is destroyed before the basic data is removed from the database. This gives an opportunity for pre-destruction hooks (removal from projects/groups, alerts, etc)

handle_resource_modified(resource, *args, **kwargs)

This should be called when a resource is modified after the new data has been updated in the DB session This gives an opportunity for post-modification hooks

top_level_resource = True