Class: SDM::GCP

Inherits:
Object
  • Object
show all
Defined in:
lib/models/porcelain.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(bind_interface: nil, egress_filter: nil, healthy: nil, id: nil, keyfile: nil, name: nil, port_override: nil, scopes: nil, secret_store_id: nil, subdomain: nil, tags: nil) ⇒ GCP

Returns a new instance of GCP.



4674
4675
4676
4677
4678
4679
4680
4681
4682
4683
4684
4685
4686
4687
4688
4689
4690
4691
4692
4693
4694
4695
4696
4697
4698
# File 'lib/models/porcelain.rb', line 4674

def initialize(
  bind_interface: nil,
  egress_filter: nil,
  healthy: nil,
  id: nil,
  keyfile: nil,
  name: nil,
  port_override: nil,
  scopes: nil,
  secret_store_id: nil,
  subdomain: nil,
  tags: nil
)
  @bind_interface = bind_interface == nil ? "" : bind_interface
  @egress_filter = egress_filter == nil ? "" : egress_filter
  @healthy = healthy == nil ? false : healthy
  @id = id == nil ? "" : id
  @keyfile = keyfile == nil ? "" : keyfile
  @name = name == nil ? "" : name
  @port_override = port_override == nil ? 0 : port_override
  @scopes = scopes == nil ? "" : scopes
  @secret_store_id = secret_store_id == nil ? "" : secret_store_id
  @subdomain = subdomain == nil ? "" : subdomain
  @tags = tags == nil ? SDM::_porcelain_zero_value_tags() : tags
end

Instance Attribute Details

#bind_interfaceObject

The bind interface is the IP address to which the port override of a resource is bound (for example, 127.0.0.1). It is automatically generated if not provided.



4652
4653
4654
# File 'lib/models/porcelain.rb', line 4652

def bind_interface
  @bind_interface
end

#egress_filterObject

A filter applied to the routing logic to pin datasource to nodes.



4654
4655
4656
# File 'lib/models/porcelain.rb', line 4654

def egress_filter
  @egress_filter
end

#healthyObject

True if the datasource is reachable and the credentials are valid.



4656
4657
4658
# File 'lib/models/porcelain.rb', line 4656

def healthy
  @healthy
end

#idObject

Unique identifier of the Resource.



4658
4659
4660
# File 'lib/models/porcelain.rb', line 4658

def id
  @id
end

#keyfileObject

The service account keyfile to authenticate with.



4660
4661
4662
# File 'lib/models/porcelain.rb', line 4660

def keyfile
  @keyfile
end

#nameObject

Unique human-readable name of the Resource.



4662
4663
4664
# File 'lib/models/porcelain.rb', line 4662

def name
  @name
end

#port_overrideObject

The local port used by clients to connect to this resource.



4664
4665
4666
# File 'lib/models/porcelain.rb', line 4664

def port_override
  @port_override
end

#scopesObject

Space separated scopes that this login should assume into when authenticating.



4666
4667
4668
# File 'lib/models/porcelain.rb', line 4666

def scopes
  @scopes
end

#secret_store_idObject

ID of the secret store containing credentials for this resource, if any.



4668
4669
4670
# File 'lib/models/porcelain.rb', line 4668

def secret_store_id
  @secret_store_id
end

#subdomainObject

Subdomain is the local DNS address. (e.g. app-prod1 turns into app-prod1.your-org-name.sdm.network)



4670
4671
4672
# File 'lib/models/porcelain.rb', line 4670

def subdomain
  @subdomain
end

#tagsObject

Tags is a map of key, value pairs.



4672
4673
4674
# File 'lib/models/porcelain.rb', line 4672

def tags
  @tags
end

Instance Method Details

#to_json(options = {}) ⇒ Object



4700
4701
4702
4703
4704
4705
4706
# File 'lib/models/porcelain.rb', line 4700

def to_json(options = {})
  hash = {}
  self.instance_variables.each do |var|
    hash[var.id2name.delete_prefix("@")] = self.instance_variable_get var
  end
  hash.to_json
end