Class: SkullIsland::Resources::JWTCredential

Inherits:
SkullIsland::Resource show all
Defined in:
lib/skull_island/resources/jwt_credential.rb

Overview

The JWTCredential resource class

Instance Attribute Summary

Attributes inherited from SkullIsland::Resource

#api_client, #entity, #errors

Class Method Summary collapse

Instance Method Summary collapse

Methods inherited from SkullIsland::Resource

all, cleanup_except, find, from_hash, gen_getter_method, gen_property_methods, gen_setter_method, get, immutable, #initialize, property, where

Methods included from Helpers::ResourceClass

#determine_getter_names, #determine_setter_names, #human, #i18n_key, #immutable?, #param_key, #properties, #route_key

Methods included from Helpers::Resource

#<=>, #datetime_from_params, #delayed_set, #destroy, #digest, #digest_properties, #find_by_digest, #fresh?, #host_regex, #id, #id_property, #immutable?, #import_update_or_skip, #lookup, #model_name, #new?, #persisted?, #postprocess_created_at, #postprocess_updated_at, #properties, #prune_for_save, #reload, #required_properties, #save, #supports_meta?, #tainted?, #to_param, #to_s, #update

Methods included from Validations::Resource

#validate_id, #validate_mutability, #validate_required_properties, #validate_tags

Constructor Details

This class inherits a constructor from SkullIsland::Resource

Class Method Details

.batch_import(data, verbose: false, test: false) ⇒ Object



20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
# File 'lib/skull_island/resources/jwt_credential.rb', line 20

def self.batch_import(data, verbose: false, test: false)
  raise(Exceptions::InvalidArguments) unless data.is_a?(Array)

  known_ids = []

  data.each_with_index do |resource_data, index|
    resource = new
    resource.algorithm = resource_data['algorithm']
    resource.delayed_set(:key, resource_data, 'key') if resource_data['key']
    resource.delayed_set(:secret, resource_data, 'secret') if resource_data['secret']
    if resource_data['rsa_public_key']
      resource.delayed_set(:rsa_public_key, resource_data, 'rsa_public_key')
    end
    resource.delayed_set(:consumer, resource_data, 'consumer')
    resource.import_update_or_skip(index: index, verbose: verbose, test: test)
    known_ids << resource.id
  end

  known_ids
end

.relative_uriObject



41
42
43
# File 'lib/skull_island/resources/jwt_credential.rb', line 41

def self.relative_uri
  'jwts'
end

Instance Method Details

#algorithmObject

The algorithm property



10
# File 'lib/skull_island/resources/jwt_credential.rb', line 10

property :algorithm, required: true, validate: true

#consumerObject

The consumer property



14
15
16
17
# File 'lib/skull_island/resources/jwt_credential.rb', line 14

property(
  :consumer,
  required: true, validate: true, preprocess: true, postprocess: true
)

#created_atObject

The created_at property



18
# File 'lib/skull_island/resources/jwt_credential.rb', line 18

property :created_at, read_only: true, postprocess: true

#export(options = {}) ⇒ Object



53
54
55
56
57
58
59
60
61
62
63
64
65
66
# File 'lib/skull_island/resources/jwt_credential.rb', line 53

def export(options = {})
  hash = { 'algorithm' => algorithm }
  hash['key'] = key if key
  hash['secret'] = secret if secret
  hash['rsa_public_key'] = rsa_public_key if rsa_public_key
  hash['consumer'] = "<%= lookup :consumer, '#{consumer.username}' %>" if consumer
  [*options[:exclude]].each do |exclude|
    hash.delete(exclude.to_s)
  end
  [*options[:include]].each do |inc|
    hash[inc.to_s] = send(inc.to_sym)
  end
  hash.reject { |_, value| value.nil? }
end

#keyObject

The key property



11
# File 'lib/skull_island/resources/jwt_credential.rb', line 11

property :key, validate: true

#modified_existing?Boolean

Keys can’t be updated, only created or deleted

Returns:

  • (Boolean)


69
70
71
# File 'lib/skull_island/resources/jwt_credential.rb', line 69

def modified_existing?
  false
end

#projectObject



73
74
75
# File 'lib/skull_island/resources/jwt_credential.rb', line 73

def project
  consumer ? consumer.project : nil
end

#relative_uriObject



45
46
47
# File 'lib/skull_island/resources/jwt_credential.rb', line 45

def relative_uri
  consumer ? "#{consumer.relative_uri}/jwt/#{id}" : nil
end

#rsa_public_keyObject

The rsa_public_key property



13
# File 'lib/skull_island/resources/jwt_credential.rb', line 13

property :rsa_public_key, validated: true

#save_uriObject



49
50
51
# File 'lib/skull_island/resources/jwt_credential.rb', line 49

def save_uri
  consumer ? "#{consumer.relative_uri}/jwt" : nil
end

#secretObject

The secret property



12
# File 'lib/skull_island/resources/jwt_credential.rb', line 12

property :secret, validated: true