mirror of
https://github.com/elastic/logstash.git
synced 2025-04-19 04:15:23 -04:00
Work done by @guyboertje and @ph Since JRuby 1.7.25 is now EOL we are migrating Logstash to use JRuby 9k and JDK8 only, Not much needed updating to make this work, its was mostly a drop in replacement from the previous version. The major point was the change in the implementation of Time in JRuby, JRuby now use `java.time` instead of joda time, this allow JRuby to have nanoseconds precision on time object.
69 lines
2.8 KiB
Ruby
69 lines
2.8 KiB
Ruby
# encoding: utf-8
|
|
require "pluginmanager/ui"
|
|
require "pluginmanager/bundler/logstash_injector"
|
|
require "pluginmanager/gem_installer"
|
|
require "pluginmanager/errors"
|
|
require "pluginmanager/pack_installer/pack"
|
|
require "bootstrap/util/compress"
|
|
require "rubygems/indexer"
|
|
|
|
module LogStash module PluginManager module PackInstaller
|
|
class Local
|
|
PACK_EXTENSION = ".zip"
|
|
LOGSTASH_PATTERN_RE = /logstash\/?/
|
|
|
|
attr_reader :local_file
|
|
|
|
def initialize(local_file)
|
|
@local_file = local_file
|
|
end
|
|
|
|
def execute
|
|
raise PluginManager::FileNotFoundError, "Can't file local file #{local_file}" unless ::File.exist?(local_file)
|
|
raise PluginManager::InvalidPackError, "Invalid format, the pack must be in zip format" unless valid_format?(local_file)
|
|
|
|
PluginManager.ui.info("Installing file: #{local_file}")
|
|
uncompressed_path = uncompress(local_file)
|
|
PluginManager.ui.debug("Pack uncompressed to #{uncompressed_path}")
|
|
pack = LogStash::PluginManager::PackInstaller::Pack.new(uncompressed_path)
|
|
raise PluginManager::InvalidPackError, "The pack must contains at least one plugin" unless pack.valid?
|
|
|
|
# Install the gems to make them available locally when bundler does his local resolution
|
|
post_install_messages = []
|
|
pack.gems.each do |packed_gem|
|
|
PluginManager.ui.debug("Installing, #{packed_gem.name}, version: #{packed_gem.version} file: #{packed_gem.file}")
|
|
post_install_messages << LogStash::PluginManager::GemInstaller::install(packed_gem.file, packed_gem.plugin?)
|
|
end
|
|
|
|
# Try to add the gems to the current gemfile and lock file, if successful
|
|
# both of them will be updated. This injector is similar to Bundler's own injector class
|
|
# minus the support for additionals source and doing local resolution only.
|
|
::Bundler::LogstashInjector.inject!(pack)
|
|
|
|
post_install_messages.compact.each do |message|
|
|
PluginManager.ui.info(message)
|
|
end
|
|
|
|
PluginManager.ui.info("Install successful")
|
|
rescue ::Bundler::BundlerError => e
|
|
raise PluginManager::InstallError.new(e), "An error occurred went installing plugins"
|
|
ensure
|
|
FileUtils.rm_rf(uncompressed_path) if uncompressed_path && Dir.exist?(uncompressed_path)
|
|
end
|
|
|
|
private
|
|
def uncompress(source)
|
|
temporary_directory = Stud::Temporary.pathname
|
|
LogStash::Util::Zip.extract(source, temporary_directory, LOGSTASH_PATTERN_RE)
|
|
temporary_directory
|
|
rescue Zip::Error => e
|
|
# OK Zip's handling of file is bit weird, if the file exist but is not a valid zip, it will raise
|
|
# a `Zip::Error` exception with a file not found message...
|
|
raise InvalidPackError, "Cannot uncompress the zip: #{source}"
|
|
end
|
|
|
|
def valid_format?(local_file)
|
|
::File.extname(local_file).downcase == PACK_EXTENSION
|
|
end
|
|
end
|
|
end end end
|