Class: SDM::Redshift

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, database: nil, egress_filter: nil, healthy: nil, hostname: nil, id: nil, name: nil, override_database: nil, password: nil, port: nil, port_override: nil, proxy_cluster_id: nil, secret_store_id: nil, subdomain: nil, tags: nil, username: nil) ⇒ Redshift



11947
11948
11949
11950
11951
11952
11953
11954
11955
11956
11957
11958
11959
11960
11961
11962
11963
11964
11965
11966
11967
11968
11969
11970
11971
11972
11973
11974
11975
11976
11977
11978
11979
11980
11981
# File 'lib/models/porcelain.rb', line 11947

def initialize(
  bind_interface: nil,
  database: nil,
  egress_filter: nil,
  healthy: nil,
  hostname: nil,
  id: nil,
  name: nil,
  override_database: nil,
  password: nil,
  port: nil,
  port_override: nil,
  proxy_cluster_id: nil,
  secret_store_id: nil,
  subdomain: nil,
  tags: nil,
  username: nil
)
  @bind_interface = bind_interface == nil ? "" : bind_interface
  @database = database == nil ? "" : database
  @egress_filter = egress_filter == nil ? "" : egress_filter
  @healthy = healthy == nil ? false : healthy
  @hostname = hostname == nil ? "" : hostname
  @id = id == nil ? "" : id
  @name = name == nil ? "" : name
  @override_database = override_database == nil ? false : override_database
  @password = password == nil ? "" : password
  @port = port == nil ? 0 : port
  @port_override = port_override == nil ? 0 : port_override
  @proxy_cluster_id = proxy_cluster_id == nil ? "" : proxy_cluster_id
  @secret_store_id = secret_store_id == nil ? "" : secret_store_id
  @subdomain = subdomain == nil ? "" : subdomain
  @tags = tags == nil ? SDM::_porcelain_zero_value_tags() : tags
  @username = username == nil ? "" : username
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.



11915
11916
11917
# File 'lib/models/porcelain.rb', line 11915

def bind_interface
  @bind_interface
end

#databaseObject

The initial database to connect to. This setting does not by itself prevent switching to another database after connecting.



11917
11918
11919
# File 'lib/models/porcelain.rb', line 11917

def database
  @database
end

#egress_filterObject

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



11919
11920
11921
# File 'lib/models/porcelain.rb', line 11919

def egress_filter
  @egress_filter
end

#healthyObject

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



11921
11922
11923
# File 'lib/models/porcelain.rb', line 11921

def healthy
  @healthy
end

#hostnameObject

The host to dial to initiate a connection from the egress node to this resource.



11923
11924
11925
# File 'lib/models/porcelain.rb', line 11923

def hostname
  @hostname
end

#idObject

Unique identifier of the Resource.



11925
11926
11927
# File 'lib/models/porcelain.rb', line 11925

def id
  @id
end

#nameObject

Unique human-readable name of the Resource.



11927
11928
11929
# File 'lib/models/porcelain.rb', line 11927

def name
  @name
end

#override_databaseObject

If set, the database configured cannot be changed by users. This setting is not recommended for most use cases, as some clients will insist their database has changed when it has not, leading to user confusion.



11929
11930
11931
# File 'lib/models/porcelain.rb', line 11929

def override_database
  @override_database
end

#passwordObject

The password to authenticate with.



11931
11932
11933
# File 'lib/models/porcelain.rb', line 11931

def password
  @password
end

#portObject

The port to dial to initiate a connection from the egress node to this resource.



11933
11934
11935
# File 'lib/models/porcelain.rb', line 11933

def port
  @port
end

#port_overrideObject

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



11935
11936
11937
# File 'lib/models/porcelain.rb', line 11935

def port_override
  @port_override
end

#proxy_cluster_idObject

ID of the proxy cluster for this resource, if any.



11937
11938
11939
# File 'lib/models/porcelain.rb', line 11937

def proxy_cluster_id
  @proxy_cluster_id
end

#secret_store_idObject

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



11939
11940
11941
# File 'lib/models/porcelain.rb', line 11939

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)



11941
11942
11943
# File 'lib/models/porcelain.rb', line 11941

def subdomain
  @subdomain
end

#tagsObject

Tags is a map of key, value pairs.



11943
11944
11945
# File 'lib/models/porcelain.rb', line 11943

def tags
  @tags
end

#usernameObject

The username to authenticate with.



11945
11946
11947
# File 'lib/models/porcelain.rb', line 11945

def username
  @username
end

Instance Method Details

#to_json(options = {}) ⇒ Object



11983
11984
11985
11986
11987
11988
11989
# File 'lib/models/porcelain.rb', line 11983

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