Sha256: 6508e2860ef9357b0f4e3516ffbab54c35a000a04bc9db83221bb2140bc3a496

Contents?: true

Size: 1.84 KB

Versions: 2

Compression:

Stored size: 1.84 KB

Contents

#
# Author:: Cary Penniman (<cary@rightscale.com>)
# Copyright:: Copyright (c) 2008 Opscode, Inc.
# License:: Apache License, Version 2.0
#
# 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.
#

class Chef

  class Provider

    class Log

      # Chef log provider, allows logging to chef's logs from recipes
      class ChefLog < Chef::Provider

        # ordered array of the log levels
        @@levels = [ :debug, :info, :warn, :error, :fatal ]

        # No concept of a 'current' resource for logs, this is a no-op
        #
        # === Return
        # true:: Always return true
        def load_current_resource
          true
        end

        # Write the log to Chef's log
        #
        # === Return
        # true:: Always return true
        def action_write
          Chef::Log.send(@new_resource.level, @new_resource.message)

          # resolve the integers for the current log levels
          global_level = Mixlib::Log::LEVELS.fetch(Chef::Log.level)
          resource_level = Mixlib::Log::LEVELS.fetch(@new_resource.level)

          # If the resource level is greater than or the same os the global
          # level, then it should have been written to the log.  Mark the
          # resource as updated.
          if resource_level >= global_level
            @new_resource.updated_by_last_action(true)
          end

        end

      end

    end

  end

end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
chef-12.0.0.alpha.0-x86-mingw32 lib/chef/provider/log.rb
chef-12.0.0.alpha.0 lib/chef/provider/log.rb