Class: SDM::SSH

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, proxy_cluster_id: nil, public_key: nil, secret_store_id: nil, subdomain: nil, tags: nil, username: nil) ⇒ SSH



10941
10942
10943
10944
10945
10946
10947
10948
10949
10950
10951
10952
10953
10954
10955
10956
10957
10958
10959
10960
10961
10962
10963
10964
10965
10966
10967
10968
10969
10970
10971
10972
10973
10974
10975
10976
10977
# File 'lib/models/porcelain.rb', line 10941

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,
  proxy_cluster_id: nil,
  public_key: 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
  @proxy_cluster_id = proxy_cluster_id == nil ? "" : proxy_cluster_id
  @public_key = public_key == nil ? "" : public_key
  @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.



10907
10908
10909
# File 'lib/models/porcelain.rb', line 10907

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.



10909
10910
10911
# File 'lib/models/porcelain.rb', line 10909

def bind_interface
  @bind_interface
end

#egress_filterObject

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



10911
10912
10913
# File 'lib/models/porcelain.rb', line 10911

def egress_filter
  @egress_filter
end

#healthyObject

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



10913
10914
10915
# File 'lib/models/porcelain.rb', line 10913

def healthy
  @healthy
end

#hostnameObject

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



10915
10916
10917
# File 'lib/models/porcelain.rb', line 10915

def hostname
  @hostname
end

#idObject

Unique identifier of the Resource.



10917
10918
10919
# File 'lib/models/porcelain.rb', line 10917

def id
  @id
end

#key_typeObject

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



10919
10920
10921
# File 'lib/models/porcelain.rb', line 10919

def key_type
  @key_type
end

#nameObject

Unique human-readable name of the Resource.



10921
10922
10923
# File 'lib/models/porcelain.rb', line 10921

def name
  @name
end

#portObject

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



10923
10924
10925
# File 'lib/models/porcelain.rb', line 10923

def port
  @port
end

#port_forwardingObject

Whether port forwarding is allowed through this server.



10925
10926
10927
# File 'lib/models/porcelain.rb', line 10925

def port_forwarding
  @port_forwarding
end

#port_overrideObject

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



10927
10928
10929
# File 'lib/models/porcelain.rb', line 10927

def port_override
  @port_override
end

#proxy_cluster_idObject

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



10929
10930
10931
# File 'lib/models/porcelain.rb', line 10929

def proxy_cluster_id
  @proxy_cluster_id
end

#public_keyObject

The public key to append to a server's authorized keys. This will be generated after resource creation.



10931
10932
10933
# File 'lib/models/porcelain.rb', line 10931

def public_key
  @public_key
end

#secret_store_idObject

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



10933
10934
10935
# File 'lib/models/porcelain.rb', line 10933

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)



10935
10936
10937
# File 'lib/models/porcelain.rb', line 10935

def subdomain
  @subdomain
end

#tagsObject

Tags is a map of key, value pairs.



10937
10938
10939
# File 'lib/models/porcelain.rb', line 10937

def tags
  @tags
end

#usernameObject

The username to authenticate with.



10939
10940
10941
# File 'lib/models/porcelain.rb', line 10939

def username
  @username
end

Instance Method Details

#to_json(options = {}) ⇒ Object



10979
10980
10981
10982
10983
10984
10985
# File 'lib/models/porcelain.rb', line 10979

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