Class: SDM::SSHCert

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

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(allow_deprecated_key_exchanges: nil, bind_interface: nil, egress_filter: nil, healthy: nil, hostname: nil, id: nil, key_type: nil, name: nil, port: nil, port_forwarding: nil, port_override: nil, remote_identity_group_id: nil, remote_identity_healthcheck_username: nil, secret_store_id: nil, subdomain: nil, tags: nil, username: nil) ⇒ SSHCert

Returns a new instance of SSHCert.



8802
8803
8804
8805
8806
8807
8808
8809
8810
8811
8812
8813
8814
8815
8816
8817
8818
8819
8820
8821
8822
8823
8824
8825
8826
8827
8828
8829
8830
8831
8832
8833
8834
8835
8836
8837
8838
# File 'lib/models/porcelain.rb', line 8802

def initialize(
  allow_deprecated_key_exchanges: nil,
  bind_interface: nil,
  egress_filter: nil,
  healthy: nil,
  hostname: nil,
  id: nil,
  key_type: nil,
  name: nil,
  port: nil,
  port_forwarding: nil,
  port_override: nil,
  remote_identity_group_id: nil,
  remote_identity_healthcheck_username: nil,
  secret_store_id: nil,
  subdomain: nil,
  tags: nil,
  username: nil
)
  @allow_deprecated_key_exchanges = allow_deprecated_key_exchanges == nil ? false : allow_deprecated_key_exchanges
  @bind_interface = bind_interface == nil ? "" : bind_interface
  @egress_filter = egress_filter == nil ? "" : egress_filter
  @healthy = healthy == nil ? false : healthy
  @hostname = hostname == nil ? "" : hostname
  @id = id == nil ? "" : id
  @key_type = key_type == nil ? "" : key_type
  @name = name == nil ? "" : name
  @port = port == nil ? 0 : port
  @port_forwarding = port_forwarding == nil ? false : port_forwarding
  @port_override = port_override == nil ? 0 : port_override
  @remote_identity_group_id = remote_identity_group_id == nil ? "" : remote_identity_group_id
  @remote_identity_healthcheck_username = remote_identity_healthcheck_username == nil ? "" : remote_identity_healthcheck_username
  @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

#allow_deprecated_key_exchangesObject

Whether deprecated, insecure key exchanges are allowed for use to connect to the target ssh server.



8768
8769
8770
# File 'lib/models/porcelain.rb', line 8768

def allow_deprecated_key_exchanges
  @allow_deprecated_key_exchanges
end

#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.



8770
8771
8772
# File 'lib/models/porcelain.rb', line 8770

def bind_interface
  @bind_interface
end

#egress_filterObject

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



8772
8773
8774
# File 'lib/models/porcelain.rb', line 8772

def egress_filter
  @egress_filter
end

#healthyObject

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



8774
8775
8776
# File 'lib/models/porcelain.rb', line 8774

def healthy
  @healthy
end

#hostnameObject

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



8776
8777
8778
# File 'lib/models/porcelain.rb', line 8776

def hostname
  @hostname
end

#idObject

Unique identifier of the Resource.



8778
8779
8780
# File 'lib/models/porcelain.rb', line 8778

def id
  @id
end

#key_typeObject

The key type to use e.g. rsa-2048 or ed25519



8780
8781
8782
# File 'lib/models/porcelain.rb', line 8780

def key_type
  @key_type
end

#nameObject

Unique human-readable name of the Resource.



8782
8783
8784
# File 'lib/models/porcelain.rb', line 8782

def name
  @name
end

#portObject

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



8784
8785
8786
# File 'lib/models/porcelain.rb', line 8784

def port
  @port
end

#port_forwardingObject

Whether port forwarding is allowed through this server.



8786
8787
8788
# File 'lib/models/porcelain.rb', line 8786

def port_forwarding
  @port_forwarding
end

#port_overrideObject

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



8788
8789
8790
# File 'lib/models/porcelain.rb', line 8788

def port_override
  @port_override
end

#remote_identity_group_idObject

The ID of the remote identity group to use for remote identity connections.



8790
8791
8792
# File 'lib/models/porcelain.rb', line 8790

def remote_identity_group_id
  @remote_identity_group_id
end

#remote_identity_healthcheck_usernameObject

The username to use for healthchecks, when clients otherwise connect with their own remote identity username.



8792
8793
8794
# File 'lib/models/porcelain.rb', line 8792

def remote_identity_healthcheck_username
  @remote_identity_healthcheck_username
end

#secret_store_idObject

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



8794
8795
8796
# File 'lib/models/porcelain.rb', line 8794

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)



8796
8797
8798
# File 'lib/models/porcelain.rb', line 8796

def subdomain
  @subdomain
end

#tagsObject

Tags is a map of key, value pairs.



8798
8799
8800
# File 'lib/models/porcelain.rb', line 8798

def tags
  @tags
end

#usernameObject

The username to authenticate with.



8800
8801
8802
# File 'lib/models/porcelain.rb', line 8800

def username
  @username
end

Instance Method Details

#to_json(options = {}) ⇒ Object



8840
8841
8842
8843
8844
8845
8846
# File 'lib/models/porcelain.rb', line 8840

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