Class: SDM::PostgresEngine

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

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(after_read_ttl: nil, database: nil, hostname: nil, id: nil, key_rotation_interval_days: nil, name: nil, password: nil, policy: nil, port: nil, public_key: nil, secret_store_id: nil, secret_store_root_path: nil, tags: nil, tls: nil, ttl: nil, username: nil) ⇒ PostgresEngine



12385
12386
12387
12388
12389
12390
12391
12392
12393
12394
12395
12396
12397
12398
12399
12400
12401
12402
12403
12404
12405
12406
12407
12408
12409
12410
12411
12412
12413
12414
12415
12416
12417
12418
12419
# File 'lib/models/porcelain.rb', line 12385

def initialize(
  after_read_ttl: nil,
  database: nil,
  hostname: nil,
  id: nil,
  key_rotation_interval_days: nil,
  name: nil,
  password: nil,
  policy: nil,
  port: nil,
  public_key: nil,
  secret_store_id: nil,
  secret_store_root_path: nil,
  tags: nil,
  tls: nil,
  ttl: nil,
  username: nil
)
  @after_read_ttl = after_read_ttl == nil ? nil : after_read_ttl
  @database = database == nil ? "" : database
  @hostname = hostname == nil ? "" : hostname
  @id = id == nil ? "" : id
  @key_rotation_interval_days = key_rotation_interval_days == nil ? 0 : key_rotation_interval_days
  @name = name == nil ? "" : name
  @password = password == nil ? "" : password
  @policy = policy == nil ? nil : policy
  @port = port == nil ? 0 : port
  @public_key = public_key == nil ? "" : public_key
  @secret_store_id = secret_store_id == nil ? "" : secret_store_id
  @secret_store_root_path = secret_store_root_path == nil ? "" : secret_store_root_path
  @tags = tags == nil ? SDM::_porcelain_zero_value_tags() : tags
  @tls = tls == nil ? false : tls
  @ttl = ttl == nil ? nil : ttl
  @username = username == nil ? "" : username
end

Instance Attribute Details

#after_read_ttlObject

The default time-to-live duration of the password after it's read. Once the ttl has passed, a password will be rotated.



12353
12354
12355
# File 'lib/models/porcelain.rb', line 12353

def after_read_ttl
  @after_read_ttl
end

#databaseObject

Database is the database to verify credential against.



12355
12356
12357
# File 'lib/models/porcelain.rb', line 12355

def database
  @database
end

#hostnameObject

Hostname is the hostname or IP address of the Postgres server.



12357
12358
12359
# File 'lib/models/porcelain.rb', line 12357

def hostname
  @hostname
end

#idObject

Unique identifier of the Secret Engine.



12359
12360
12361
# File 'lib/models/porcelain.rb', line 12359

def id
  @id
end

#key_rotation_interval_daysObject

An interval of public/private key rotation for secret engine in days



12361
12362
12363
# File 'lib/models/porcelain.rb', line 12361

def key_rotation_interval_days
  @key_rotation_interval_days
end

#nameObject

Unique human-readable name of the Secret Engine.



12363
12364
12365
# File 'lib/models/porcelain.rb', line 12363

def name
  @name
end

#passwordObject

Password is the password to connect to the Postgres server.



12365
12366
12367
# File 'lib/models/porcelain.rb', line 12365

def password
  @password
end

#policyObject

Policy for password creation



12367
12368
12369
# File 'lib/models/porcelain.rb', line 12367

def policy
  @policy
end

#portObject

Port is the port number of the Postgres server.



12369
12370
12371
# File 'lib/models/porcelain.rb', line 12369

def port
  @port
end

#public_keyObject

Public key linked with a secret engine



12371
12372
12373
# File 'lib/models/porcelain.rb', line 12371

def public_key
  @public_key
end

#secret_store_idObject

Backing secret store identifier



12373
12374
12375
# File 'lib/models/porcelain.rb', line 12373

def secret_store_id
  @secret_store_id
end

#secret_store_root_pathObject

Backing Secret Store root path where managed secrets are going to be stored



12375
12376
12377
# File 'lib/models/porcelain.rb', line 12375

def secret_store_root_path
  @secret_store_root_path
end

#tagsObject

Tags is a map of key, value pairs.



12377
12378
12379
# File 'lib/models/porcelain.rb', line 12377

def tags
  @tags
end

#tlsObject

TLS enables TLS/SSL when connecting to the Postgres server.



12379
12380
12381
# File 'lib/models/porcelain.rb', line 12379

def tls
  @tls
end

#ttlObject

The default password time-to-live duration. Once the ttl has passed, a password will be rotated the next time it's requested.



12381
12382
12383
# File 'lib/models/porcelain.rb', line 12381

def ttl
  @ttl
end

#usernameObject

Username is the username to connect to the Postgres server.



12383
12384
12385
# File 'lib/models/porcelain.rb', line 12383

def username
  @username
end

Instance Method Details

#to_json(options = {}) ⇒ Object



12421
12422
12423
12424
12425
12426
12427
# File 'lib/models/porcelain.rb', line 12421

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