]> git.donarmstrong.com Git - dsa-puppet.git/blobdiff - 3rdparty/modules/keystone/lib/puppet/provider/keystone_service/openstack.rb
add stackforge/keystone to 3rdparty
[dsa-puppet.git] / 3rdparty / modules / keystone / lib / puppet / provider / keystone_service / openstack.rb
diff --git a/3rdparty/modules/keystone/lib/puppet/provider/keystone_service/openstack.rb b/3rdparty/modules/keystone/lib/puppet/provider/keystone_service/openstack.rb
new file mode 100644 (file)
index 0000000..54e75f5
--- /dev/null
@@ -0,0 +1,98 @@
+require 'puppet/provider/keystone'
+
+Puppet::Type.type(:keystone_service).provide(
+  :openstack,
+  :parent => Puppet::Provider::Keystone
+) do
+
+  desc "Provider to manage keystone services."
+
+  def initialize(value={})
+    super(value)
+    @property_flush = {}
+  end
+
+  def create
+    properties = []
+    if resource[:description]
+      properties << '--description'
+      properties << resource[:description]
+    end
+    if resource[:type]
+      properties << '--type'
+      properties << resource[:type]
+    end
+    @instance = request('service', 'create', resource[:name], resource[:auth], properties)
+  end
+
+  def exists?
+    ! instance(resource[:name]).empty?
+  end
+
+  def destroy
+    request('service', 'delete', resource[:name], resource[:auth])
+  end
+
+
+  def description=(value)
+    raise(Puppet::Error, "Updating the service is not currently supported.")
+  end
+
+  def description
+    instance(resource[:name])[:description]
+  end
+
+
+  def type=(value)
+    raise(Puppet::Error, "Updating the service is not currently supported.")
+  end
+
+  def type
+    instance(resource[:name])[:type]
+  end
+
+
+  def id
+    instance(resource[:name])[:id]
+  end
+
+  def self.instances
+    list = request('service', 'list', nil, nil, '--long')
+    list.collect do |service|
+      new(
+        :name        => service[:name],
+        :ensure      => :present,
+        :type        => service[:type],
+        :description => service[:description],
+        :id          => service[:id]
+      )
+    end
+  end
+
+  def instances
+    instances = request('service', 'list', nil, resource[:auth], '--long')
+    instances.collect do |service|
+      {
+        :name        => service[:name],
+        :type        => service[:type],
+        :description => service[:description],
+        :id          => service[:id]
+      }
+    end
+  end
+
+  def instance(name)
+    @instance ||= instances.select { |instance| instance[:name] == name }.first || {}
+  end
+
+  def flush
+    options = []
+    if @property_flush
+      # There is a --description flag for the set command, but it does not work if the value is empty
+      (options << '--property' << "type=#{resource[:type]}") if @property_flush[:type]
+      (options << '--property' << "description=#{resource[:description]}") if @property_flush[:description]
+      request('project', 'set', resource[:name], resource[:auth], options) unless options.empty?
+    end
+  end
+
+end