lib/fog/oraclecloud/models/java/instance.rb in fog-oraclecloud-0.1.3 vs lib/fog/oraclecloud/models/java/instance.rb in fog-oraclecloud-0.1.4
- old
+ new
@@ -2,37 +2,37 @@
module Fog
module OracleCloud
class Java
class Instance < Fog::Model
- identity :service_name, :aliases=>'name'
+ identity :service_name, :aliases=>['name', 'serviceName']
attribute :created_by
attribute :auto_update
- attribute :cluster_name
+ attribute :cluster_name, :aliases=>'clusterName'
attribute :compliance_status
attribute :compliance_status_desc
attribute :compute_site_name
attribute :content_url
attribute :creation_job_id
attribute :creation_time
attribute :db_associations
attribute :db_info
- attribute :db_servicename
+ attribute :db_service_name
attribute :deletion_job_id
attribute :description
- attribute :domain_mode
+ attribute :domain_mode, :aliases=>'domainMode'
attribute :edition
attribute :error_status_desc
attribute :fmw_control_url
attribute :last_modified_time
attribute :level
attribute :lifecycle_control_job_id
attribute :num_ip_reservations
- attribute :num_nodes
+ attribute :num_nodes, :aliases=>'managedServerCount'
attribute :options
attribute :otd_admin_url
attribute :otd_provisioned
attribute :otd_shape
attribute :otd_strorage_size
@@ -42,30 +42,105 @@
attribute :service_components
attribute :service_type
attribute :service_uri
attribute :shape
attribute :status
- attribute :subscription_type
+ attribute :subscription_type, :aliases=>['subscriptionType']
attribute :uri
attribute :version
attribute :wls_admin_url
attribute :wls_deployment_channel_port
attribute :wls_version, :aliases=>'wlsVersion'
+ attribute :domain_name, :aliases=>'domainName'
+ attribute :pdb_name, :aliases=>['pdbName', 'pdb_service_name']
# The following are only used to create an instance and are not returned in the list action
attribute :cloud_storage_container, :aliases=>'cloudStorageContainer'
attribute :cloud_storage_user, :aliases=>'cloudStorageUser'
- attribute :cloud_storage_password, :aliases=>'cloudStoragePassword'
- attribute :admin_user_name, :aliases=>'adminUserName'
- attribute :vm_public_key, :aliases=>'vmPublicKey'
+ attribute :cloud_storage_pwd, :aliases=>'cloudStoragePassword'
+ attribute :admin_username, :aliases=>'adminUserName'
+ attribute :admin_password, :aliases=>'adminPassword'
+ attribute :ssh_key, :aliases=>'vmPublicKey'
+ attribute :cloud_storage_container_if_missing, :aliases=>'cloudStorageContainerIfMissing'
+ attribute :enable_admin_console, :aliases=>'enableAdminConsole'
+ attribute :provision_otd, :aliases=>'provisionOTD'
+ attribute :sample_app_deployment_requested, :aliases=>'sampleAppDeploymentRequested'
+ attribute :admin_port, :aliases=>'adminPort'
+ attribute :app_dbs, :aliases=>'appDBs'
+ attribute :backup_volume_size, :aliases=>'backupVolumeSize'
+ attribute :content_port, :aliases=>'contentPort'
+ attribute :dba_name, :aliases=>'dbaName'
+ attribute :dba_password, :aliases=>'dbaPassword'
+ attribute :domain_partition_count, :aliases=>'domainPartitionCount'
+ attribute :domain_volume_size, :aliases=>'domainVolumeSize'
+ attribute :ip_reservations, :aliases=>'ipReservations'
+ attribute :ms_initial_heap_mb, :aliases=>'msInitialHeapMB'
+ attribute :ms_jvm_args, :aliases=>'msJvmArgs'
+ attribute :ms_max_heap_mb, :aliases=>'msMaxHeapMB'
+ attribute :ms_max_perm_mb, :aliases=>'msMaxPermMB'
+ attribute :ms_perm_mb, :aliases=>'msPermMb'
+ attribute :node_manager_password, :aliases=>'nodeManagerPassword'
+ attribute :node_manager_port, :aliases=>'nodeManagerPort'
+ attribute :node_manager_user_name, :aliases=>'nodeManagerUserName'
+ attribute :overwrite_ms_jvm_args, :aliases=>'overwriteMsJvmArgs'
+ attribute :secured_admin_port, :aliases=>'securedAdminPort'
+ attribute :secured_content_port, :aliases=>'securedContentPort'
# The following are used to delete an instance and are not returned in the list action
- attribute :dba_name
- attribute :dba_password
attribute :force_delete
+ def level=(value)
+ if %w(PAAS BASIC).include? value then
+ attributes[:level]=value
+ else
+ raise ArgumentError, "Invalid level. Valid values - PAAS or BASIC"
+ end
+ end
+
+ def subscription_type=(value)
+ if %w(HOURLY MONTHLY).include? value then
+ attributes[:subscription_type]=value
+ else
+ raise ArgumentError, "Invalid subscription type. Valid values - HOURLY or MONTHLY"
+ end
+ end
+
+ def domain_mode=(value)
+ if %w(DEVELOPMENT PRODUCTION).include? value then
+ attributes[:domain_mode]=value
+ else
+ raise ArgumentError, "Invalid domain mode. Valid values - DEVELOPMENT or PRODUCTION"
+ end
+ end
+
+ def edition=(value)
+ if %w(SE EE SUITE).include? value then
+ attributes[:edition]=value
+ else
+ raise ArgumentError, "Invalid edition. Valid values - SE, EE or SUITE"
+ end
+ end
+
+ def num_nodes=(value)
+ if [1, 2, 4, 8].include? value then
+ attributes[:num_nodes]=value
+ else
+ raise ArgumentError, "Invalid server count (#{value}). Valid values - 1, 2, 4 or 8"
+ end
+ end
+
+ def shape=(value)
+ if %w(oc3 oc4 oc5 oc6 oc1m oc2m oc3m oc4m).include? value then
+ attributes[:shape]=value
+ else
+ raise ArgumentError, "Invalid Shape. Valid values - oc3, oc4, oc5, oc6, oc1m, oc2m, oc3m or oc4m"
+ end
+ end
+
+
+
def initialize(attributes={})
level ||= 'PAAS'
subscription_type ||= 'HOURLY'
edition ||= 'EE'
@@ -91,23 +166,90 @@
def servers
service.servers.all(service_name)
end
- def destroy
+ def destroy
requires :service_name, :dba_name, :dba_password
service.delete_instance(service_name, dba_name, dba_password, :force_delete => force_delete).body
end
private
def create
- requires :service_name, :cloud_storage_container, :cloud_storage_user, :cloud_storage_password
+ requires :service_name, :dba_name, :dba_password, :db_service_name, :shape, :version, :ssh_key
- data = service.create_instance(service_name, cloud_storage_container, cloud_storage_user, cloud_storage_password, dba_name, dba_password, db_servicename, shape, version, vm_public_key,
- :level => level,
- :subscriptionType => subscription_type,
- :description => description)
+ #data = service.create_instance(service_name, cloud_storage_container, cloud_storage_user, cloud_storage_password, dba_name, dba_password, db_servicename, shape, version, vm_public_key,
+ # :level => level,
+ # :subscriptionType => subscription_type,
+ # :description => description)
+
+ if cloud_storage_container.nil? then
+ cloud_storage_if_missing = true
+ stor_name = "#{service_name}_Backup"
+ else
+ stor_name = cloud_storage_container
+ end
+ stor_user = cloud_storage_user || service.username
+ stor_pwd = cloud_storage_pwd || service.password
+
+ params = {
+ :serviceName => service_name,
+ :cloudStorageContainer => stor_name,
+ :cloudStoragePassword => stor_user,
+ :cloudStorageUser => stor_pwd,
+ :cloudStorageContainerIfMissing => cloud_storage_if_missing,
+ :description => description,
+ :enableAdminConsole => enable_admin_console.nil? ? true : enable_admin_console,
+ :provisionOTD => provision_otd.nil? ? true : provision_otd,
+ :sampleAppDeploymentRequested => sample_app_deployment_requested.nil? ? true : sample_app_deployment_requested,
+ :subscriptionType => subscription_type || 'HOURLY',
+ :level => level || 'PAAS',
+ }
+ options = {
+ :adminPassword => admin_password,
+ :adminPort => admin_port,
+ :adminUserName => admin_username,
+ :backupVolumeSize => backup_volume_size,
+ :clusterName => cluster_name,
+ :contentPort => content_port,
+ :dbaName => dba_name,
+ :dbaPassword => dba_password,
+ :dbServiceName => db_service_name,
+ :deploymentChannelPort => wls_deployment_channel_port,
+ :domainMode => domain_mode,
+ :domainName => domain_name,
+ :domainPartitionCount => domain_partition_count,
+ :domainVolumeSize => domain_volume_size,
+ :edition => edition || 'EE',
+ :ipReservations => ip_reservations,
+ :managedServerCount => num_nodes || 1,
+ :msInitialHeapMB => ms_initial_heap_mb,
+ :msJvmArgs => ms_jvm_args,
+ :msMaxHeapMB => ms_max_heap_mb,
+ :msMaxPermMB => ms_max_perm_mb,
+ :msPermMb => ms_perm_mb,
+ :nodeManagerPassword => node_manager_password,
+ :nodeManagerPort => node_manager_port,
+ :nodeManagerUserName => node_manager_user_name,
+ :overwriteMsJvmArgs => overwrite_ms_jvm_args,
+ :pdbName => pdb_name,
+ :securedAdminPort => secured_admin_port,
+ :securedContentPort => secured_content_port,
+ :shape => shape,
+ :VMsPublicKey => ssh_key,
+ :version => version
+ }
+
+ if app_dbs and app_dbs.is_a? Array and app_dbs.size >= 1
+ options[:appDBs] = []
+ app_dbs.each { |db| options[:appDBs].push({
+ :dbaName => db.username,
+ :dbaPassword => db.password,
+ :dbServiceName => db.service_name,
+ }) }
+ end
+ data = service.create_instance(params, options)
end
end
end