Modernise nodejs_package LWRP
authorTom Hughes <tom@compton.nu>
Wed, 22 Nov 2017 20:22:49 +0000 (20:22 +0000)
committerTom Hughes <tom@compton.nu>
Wed, 22 Nov 2017 20:22:49 +0000 (20:22 +0000)
cookbooks/nodejs/providers/package.rb [deleted file]
cookbooks/nodejs/resources/package.rb

diff --git a/cookbooks/nodejs/providers/package.rb b/cookbooks/nodejs/providers/package.rb
deleted file mode 100644 (file)
index 0ecd08e..0000000
+++ /dev/null
@@ -1,71 +0,0 @@
-#
-# Cookbook Name:: nodejs
-# Provider:: package
-#
-# Copyright 2013, OpenStreetMap Foundation
-#
-# Licensed under the Apache License, Version 2.0 (the "License");
-# you may not use this file except in compliance with the License.
-# You may obtain a copy of the License at
-#
-#     http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an "AS IS" BASIS,
-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-# See the License for the specific language governing permissions and
-# limitations under the License.
-#
-
-require "chef/mixin/shell_out"
-require "json"
-
-include Chef::Mixin::ShellOut
-
-use_inline_resources
-
-def load_current_resource
-  @packages = JSON.parse(shell_out("npm list --global --json").stdout)["dependencies"] || {}
-
-  @current_resource = Chef::Resource::NodejsPackage.new(new_resource.name)
-  @current_resource.package_name(new_resource.package_name)
-  if (package = @packages[@current_resource.package_name])
-    @current_resource.version(package["version"])
-  end
-  @current_resource
-end
-
-action :install do
-  package_name = if new_resource.version
-                   "#{new_resource.package_name}@#{new_resource.version}"
-                 else
-                   new_resource.package_name
-                 end
-
-  if !@packages.include?(new_resource.package_name)
-    converge_by "install #{package_name}" do
-      shell_out!("npm install --global #{package_name}")
-    end
-  elsif new_resource.version &&
-        new_resource.version != @current_resource.version
-    converge_by "update #{package_name}" do
-      shell_out!("npm install --global #{package_name}")
-    end
-  end
-end
-
-action :upgrade do
-  if @packages.include?(new_resource.package_name)
-    converge_by "update #{new_resource.package_name}" do
-      shell_out!("npm update --global #{new_resource.package_name}")
-    end
-  end
-end
-
-action :remove do
-  if @packages.include?(new_resource.package_name)
-    converge_by "remove #{new_resource.package_name}" do
-      shell_out!("npm remove --global #{new_resource.package_name}")
-    end
-  end
-end
index f62aecc84e44aed838248dd5560476bb51c4f528..db81c9ee662e9b11a5727d24cc57eb52d236cbfc 100644 (file)
 # limitations under the License.
 #
 
+require "chef/mixin/shell_out"
+require "json"
+
 default_action :install
 
-actions :install, :upgrade, :remove
+property :package, :kind_of => String, :name_attribute => true
+property :version, :kind_of => String
+
+action :install do
+  qualified_name = if new_resource.version
+                     "#{new_resource.package}@#{new_resource.version}"
+                   else
+                     new_resource.package
+                   end
+
+  if current_version.nil?
+    converge_by "install #{qualified_name}" do
+      shell_out!("npm install --global #{qualified_name}")
+    end
+  elsif new_resource.version &&
+        new_resource.version != current_version
+    converge_by "update #{qualified_name}" do
+      shell_out!("npm install --global #{qualified_name}")
+    end
+  end
+end
+
+action :upgrade do
+  unless current_version.nil?
+    converge_by "update #{new_resource.package}" do
+      shell_out!("npm update --global #{new_resource.package}")
+    end
+  end
+end
+
+action :remove do
+  unless current_version.nil?
+    converge_by "remove #{new_resource.package}" do
+      shell_out!("npm remove --global #{new_resource.package}")
+    end
+  end
+end
+
+action_class do
+  include Chef::Mixin::ShellOut
 
-attribute :package_name, :kind_of => String, :name_attribute => true
-attribute :version, :kind_of => String
+  def current_version
+    @current_version ||= JSON.parse(shell_out("npm list --global --json").stdout)
+                             .dig("dependencies", new_resource.package, "version")
+  end
+end