2010-08-28 19:23:40 +00:00
|
|
|
# This file contains all of the internal errors in Vagrant's core
|
|
|
|
# commands, actions, etc.
|
|
|
|
|
2010-08-24 18:18:29 +00:00
|
|
|
module Vagrant
|
2010-09-23 17:04:52 +00:00
|
|
|
# This module contains all of the internal errors in Vagrant's core.
|
|
|
|
# These errors are _expected_ errors and as such don't typically represent
|
|
|
|
# bugs in Vagrant itself. These are meant as a way to detect errors and
|
|
|
|
# display them in a user-friendly way.
|
|
|
|
#
|
|
|
|
# # Defining a new Error
|
|
|
|
#
|
|
|
|
# To define a new error, inherit from {VagrantError}, which lets Vagrant
|
|
|
|
# know that this is an expected error, and also gives you some helpers for
|
|
|
|
# providing exit codes and error messages. An example is shown below, then
|
|
|
|
# it is explained:
|
|
|
|
#
|
|
|
|
# class MyError < Vagrant::Errors::VagrantError
|
|
|
|
# error_key "my_error"
|
|
|
|
# end
|
|
|
|
#
|
|
|
|
# This creates an error with an I18n error key of "my_error." {VagrantError}
|
|
|
|
# uses I18n to look up error messages, in the "vagrant.errors" namespace. So
|
|
|
|
# in the above, the error message would be the translation of "vagrant.errors.my_error"
|
|
|
|
#
|
|
|
|
# If you don't want to use I18n, you can override the {#initialize} method and
|
|
|
|
# set your own error message.
|
|
|
|
#
|
|
|
|
# # Raising an Error
|
|
|
|
#
|
|
|
|
# To raise an error, it is nothing special, just raise it like any normal
|
|
|
|
# exception:
|
|
|
|
#
|
|
|
|
# raise MyError.new
|
|
|
|
#
|
|
|
|
# Eventually this exception will bubble out to the `vagrant` binary which
|
|
|
|
# will show a nice error message. And if it is raised in the middle of a
|
|
|
|
# middleware sequence, then {Action::Warden} will catch it and begin the
|
|
|
|
# recovery process prior to exiting.
|
2010-08-27 06:21:28 +00:00
|
|
|
module Errors
|
|
|
|
# Main superclass of any errors in Vagrant. This provides some
|
|
|
|
# convenience methods for setting the status code and error key.
|
|
|
|
# The status code is used by the `vagrant` executable as the
|
|
|
|
# error code, and the error key is used as a default message from
|
|
|
|
# I18n.
|
|
|
|
class VagrantError < StandardError
|
2010-08-28 20:54:59 +00:00
|
|
|
@@used_codes = []
|
2010-08-28 19:23:40 +00:00
|
|
|
|
2010-08-27 06:21:28 +00:00
|
|
|
def self.status_code(code = nil)
|
2010-08-28 20:54:59 +00:00
|
|
|
if code
|
|
|
|
raise "Status code already in use: #{code}" if @@used_codes.include?(code)
|
|
|
|
@@used_codes << code
|
|
|
|
end
|
|
|
|
|
2010-08-27 06:21:28 +00:00
|
|
|
define_method(:status_code) { code }
|
|
|
|
end
|
|
|
|
|
2010-08-28 19:23:40 +00:00
|
|
|
def self.error_key(key=nil, namespace=nil)
|
2010-08-27 06:21:28 +00:00
|
|
|
define_method(:error_key) { key }
|
2010-09-01 15:27:29 +00:00
|
|
|
error_namespace(namespace) if namespace
|
|
|
|
end
|
|
|
|
|
|
|
|
def self.error_namespace(namespace)
|
|
|
|
define_method(:error_namespace) { namespace }
|
2010-08-27 06:21:28 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
def initialize(message=nil, *args)
|
2010-09-01 15:27:29 +00:00
|
|
|
message = { :_key => message } if message && !message.is_a?(Hash)
|
|
|
|
message = { :_key => error_key, :_namespace => error_namespace }.merge(message || {})
|
2010-09-01 23:15:24 +00:00
|
|
|
message = translate_error(message)
|
2010-09-01 15:27:29 +00:00
|
|
|
|
2010-08-27 06:21:28 +00:00
|
|
|
super
|
|
|
|
end
|
|
|
|
|
2010-09-01 15:27:29 +00:00
|
|
|
# The default error namespace which is used for the error key.
|
|
|
|
# This can be overridden here or by calling the "error_namespace"
|
|
|
|
# class method.
|
|
|
|
def error_namespace; "vagrant.errors"; end
|
|
|
|
|
|
|
|
# The key for the error message. This should be set using the
|
|
|
|
# {error_key} method but can be overridden here if needed.
|
2010-09-01 21:50:15 +00:00
|
|
|
def error_key; nil; end
|
2010-09-01 15:27:29 +00:00
|
|
|
|
2010-08-27 06:21:28 +00:00
|
|
|
protected
|
|
|
|
|
2010-09-01 15:27:29 +00:00
|
|
|
def translate_error(opts)
|
2010-09-01 23:15:24 +00:00
|
|
|
return nil if !opts[:_key]
|
2010-09-01 15:27:29 +00:00
|
|
|
I18n.t("#{opts[:_namespace]}.#{opts[:_key]}", opts)
|
2010-08-27 06:21:28 +00:00
|
|
|
end
|
2010-08-24 18:18:29 +00:00
|
|
|
end
|
2010-08-27 04:56:38 +00:00
|
|
|
|
2010-08-27 06:21:28 +00:00
|
|
|
class BaseVMNotFound < VagrantError
|
2010-08-28 20:54:59 +00:00
|
|
|
status_code(18)
|
2010-08-27 06:21:28 +00:00
|
|
|
error_key(:base_vm_not_found)
|
2010-08-27 04:56:38 +00:00
|
|
|
end
|
|
|
|
|
2010-08-28 19:31:55 +00:00
|
|
|
class BoxAlreadyExists < VagrantError
|
|
|
|
status_code(14)
|
|
|
|
error_key(:already_exists, "vagrant.actions.box.unpackage")
|
|
|
|
end
|
|
|
|
|
2010-08-28 19:23:40 +00:00
|
|
|
class BoxDownloadUnknownType < VagrantError
|
|
|
|
status_code(13)
|
|
|
|
error_key(:unknown_type, "vagrant.actions.box.download")
|
|
|
|
end
|
|
|
|
|
2010-08-27 06:21:28 +00:00
|
|
|
class BoxNotFound < VagrantError
|
|
|
|
status_code(2)
|
|
|
|
error_key(:box_not_found)
|
2010-08-27 04:56:38 +00:00
|
|
|
end
|
|
|
|
|
2010-08-31 02:39:11 +00:00
|
|
|
class BoxNotSpecified < VagrantError
|
|
|
|
status_code(22)
|
|
|
|
error_key(:not_specified, "vagrant.actions.vm.check_box")
|
|
|
|
end
|
|
|
|
|
|
|
|
class BoxSpecifiedDoesntExist < VagrantError
|
|
|
|
status_code(23)
|
|
|
|
error_key(:does_not_exist, "vagrant.actions.vm.check_box")
|
|
|
|
end
|
|
|
|
|
2011-12-11 05:49:00 +00:00
|
|
|
class BoxUnpackageFailure < VagrantError
|
|
|
|
status_code(57)
|
|
|
|
error_key(:untar_failure, "vagrant.actions.box.unpackage")
|
|
|
|
end
|
|
|
|
|
2010-08-28 19:31:55 +00:00
|
|
|
class BoxVerificationFailed < VagrantError
|
|
|
|
status_code(15)
|
|
|
|
error_key(:failed, "vagrant.actions.box.verify")
|
|
|
|
end
|
|
|
|
|
2010-08-27 06:21:28 +00:00
|
|
|
class CLIMissingEnvironment < VagrantError
|
|
|
|
status_code(1)
|
|
|
|
error_key(:cli_missing_env)
|
|
|
|
end
|
2010-08-27 04:56:38 +00:00
|
|
|
|
2010-09-05 17:57:33 +00:00
|
|
|
class ConfigValidationFailed < VagrantError
|
|
|
|
status_code(42)
|
|
|
|
error_key(:config_validation)
|
|
|
|
end
|
|
|
|
|
2010-10-07 01:57:39 +00:00
|
|
|
class DotfileIsDirectory < VagrantError
|
|
|
|
status_code(46)
|
|
|
|
error_key(:dotfile_is_directory)
|
|
|
|
end
|
|
|
|
|
2010-09-01 14:22:14 +00:00
|
|
|
class DownloaderFileDoesntExist < VagrantError
|
|
|
|
status_code(37)
|
|
|
|
error_key(:file_missing, "vagrant.downloaders.file")
|
|
|
|
end
|
|
|
|
|
|
|
|
class DownloaderHTTPSocketError < VagrantError
|
|
|
|
status_code(38)
|
|
|
|
error_key(:socket_error, "vagrant.downloaders.http")
|
|
|
|
end
|
|
|
|
|
2011-07-06 05:48:02 +00:00
|
|
|
class DownloaderHTTPStatusError < VagrantError
|
|
|
|
status_code(51)
|
|
|
|
error_key(:status_error, "vagrant.downloaders.http")
|
|
|
|
end
|
|
|
|
|
2011-07-09 22:57:24 +00:00
|
|
|
class EnvironmentLockedError < VagrantError
|
|
|
|
status_code(52)
|
|
|
|
error_key(:environment_locked)
|
|
|
|
end
|
|
|
|
|
2011-07-10 01:54:35 +00:00
|
|
|
class HomeDirectoryMigrationFailed < VagrantError
|
|
|
|
status_code(53)
|
|
|
|
error_key(:home_dir_migration_failed)
|
|
|
|
end
|
|
|
|
|
2011-12-11 01:10:02 +00:00
|
|
|
class HomeDirectoryNotAccessible < VagrantError
|
|
|
|
status_code(55)
|
|
|
|
error_key(:home_dir_not_accessible)
|
|
|
|
end
|
|
|
|
|
2010-08-31 03:07:50 +00:00
|
|
|
class ForwardPortAutolistEmpty < VagrantError
|
|
|
|
status_code(27)
|
|
|
|
error_key(:auto_empty, "vagrant.actions.vm.forward_ports")
|
|
|
|
end
|
|
|
|
|
|
|
|
class ForwardPortCollision < VagrantError
|
|
|
|
status_code(26)
|
|
|
|
error_key(:collision_error, "vagrant.actions.vm.forward_ports")
|
|
|
|
end
|
|
|
|
|
2010-08-27 06:21:28 +00:00
|
|
|
class MultiVMEnvironmentRequired < VagrantError
|
|
|
|
status_code(5)
|
|
|
|
error_key(:multi_vm_required)
|
|
|
|
end
|
2010-08-27 04:56:38 +00:00
|
|
|
|
2010-08-27 06:21:28 +00:00
|
|
|
class MultiVMTargetRequired < VagrantError
|
|
|
|
status_code(7)
|
|
|
|
error_key(:multi_vm_target_required)
|
|
|
|
end
|
2010-08-24 18:18:29 +00:00
|
|
|
|
2010-08-31 03:07:50 +00:00
|
|
|
class NetworkCollision < VagrantError
|
|
|
|
status_code(29)
|
|
|
|
error_key(:collides, "vagrant.actions.vm.network")
|
|
|
|
end
|
|
|
|
|
|
|
|
class NetworkNotFound < VagrantError
|
|
|
|
status_code(30)
|
|
|
|
error_key(:not_found, "vagrant.actions.vm.network")
|
|
|
|
end
|
|
|
|
|
2010-12-22 03:52:41 +00:00
|
|
|
# Note: This is a temporary error for Windows users while host-only
|
|
|
|
# networking doesn't quite work.
|
|
|
|
class NetworkNotImplemented < VagrantError
|
|
|
|
status_code(49)
|
|
|
|
error_key(:windows_not_implemented, "vagrant.actions.vm.network")
|
|
|
|
end
|
|
|
|
|
2010-08-31 03:07:50 +00:00
|
|
|
class NFSHostRequired < VagrantError
|
|
|
|
status_code(31)
|
|
|
|
error_key(:host_required, "vagrant.actions.vm.nfs")
|
|
|
|
end
|
|
|
|
|
|
|
|
class NFSNotSupported < VagrantError
|
|
|
|
status_code(32)
|
|
|
|
error_key(:not_supported, "vagrant.actions.vm.nfs")
|
|
|
|
end
|
|
|
|
|
|
|
|
class NFSNoHostNetwork < VagrantError
|
|
|
|
status_code(33)
|
|
|
|
error_key(:no_host_network, "vagrant.actions.vm.nfs")
|
|
|
|
end
|
|
|
|
|
2010-08-27 06:21:28 +00:00
|
|
|
class NoEnvironmentError < VagrantError
|
|
|
|
status_code(3)
|
|
|
|
error_key(:no_env)
|
|
|
|
end
|
2010-08-27 04:56:38 +00:00
|
|
|
|
2010-08-28 20:54:59 +00:00
|
|
|
class PackageIncludeMissing < VagrantError
|
|
|
|
status_code(20)
|
|
|
|
error_key(:include_file_missing, "vagrant.actions.general.package")
|
|
|
|
end
|
|
|
|
|
|
|
|
class PackageOutputExists < VagrantError
|
|
|
|
status_code(16)
|
|
|
|
error_key(:output_exists, "vagrant.actions.general.package")
|
|
|
|
end
|
|
|
|
|
|
|
|
class PackageRequiresDirectory < VagrantError
|
|
|
|
status_code(19)
|
|
|
|
error_key(:requires_directory, "vagrant.actions.general.package")
|
|
|
|
end
|
|
|
|
|
2010-09-01 14:13:37 +00:00
|
|
|
class PersistDotfileExists < VagrantError
|
|
|
|
status_code(34)
|
|
|
|
error_key(:dotfile_error, "vagrant.actions.vm.persist")
|
|
|
|
end
|
|
|
|
|
2011-12-11 05:29:11 +00:00
|
|
|
class SCPUnavailable < VagrantError
|
|
|
|
status_code(56)
|
|
|
|
error_key(:scp_unavailable)
|
|
|
|
end
|
|
|
|
|
2010-08-27 07:01:27 +00:00
|
|
|
class SSHAuthenticationFailed < VagrantError
|
|
|
|
status_code(11)
|
|
|
|
error_key(:ssh_authentication_failed)
|
|
|
|
end
|
|
|
|
|
2010-09-14 21:00:46 +00:00
|
|
|
class SSHConnectionRefused < VagrantError
|
|
|
|
status_code(43)
|
|
|
|
error_key(:ssh_connection_refused)
|
|
|
|
end
|
|
|
|
|
2010-08-27 07:05:03 +00:00
|
|
|
class SSHKeyBadPermissions < VagrantError
|
|
|
|
status_code(12)
|
|
|
|
error_key(:ssh_key_bad_permissions)
|
|
|
|
end
|
|
|
|
|
2011-01-14 08:36:49 +00:00
|
|
|
class SSHPortNotDetected < VagrantError
|
|
|
|
status_code(50)
|
|
|
|
error_key(:ssh_port_not_detected)
|
|
|
|
end
|
|
|
|
|
2010-09-30 06:47:17 +00:00
|
|
|
class SSHUnavailable < VagrantError
|
|
|
|
status_code(45)
|
|
|
|
error_key(:ssh_unavailable)
|
|
|
|
end
|
|
|
|
|
2010-08-27 06:51:30 +00:00
|
|
|
class SSHUnavailableWindows < VagrantError
|
|
|
|
status_code(10)
|
|
|
|
error_key(:ssh_unavailable_windows)
|
|
|
|
end
|
|
|
|
|
2010-09-01 21:50:15 +00:00
|
|
|
class VagrantInterrupt < VagrantError
|
|
|
|
status_code(40)
|
2010-09-02 01:07:47 +00:00
|
|
|
error_key(:interrupted)
|
2010-09-01 21:50:15 +00:00
|
|
|
end
|
|
|
|
|
2010-09-03 21:22:34 +00:00
|
|
|
class VagrantfileSyntaxError < VagrantError
|
|
|
|
status_code(41)
|
|
|
|
error_key(:vagrantfile_syntax_error)
|
|
|
|
end
|
|
|
|
|
2010-08-27 06:21:28 +00:00
|
|
|
class VirtualBoxInvalidVersion < VagrantError
|
2010-08-28 20:54:59 +00:00
|
|
|
status_code(17)
|
2010-08-27 06:21:28 +00:00
|
|
|
error_key(:virtualbox_invalid_version)
|
|
|
|
end
|
2010-08-27 04:56:38 +00:00
|
|
|
|
2010-08-27 06:21:28 +00:00
|
|
|
class VirtualBoxNotDetected < VagrantError
|
|
|
|
status_code(8)
|
|
|
|
error_key(:virtualbox_not_detected)
|
|
|
|
end
|
2010-08-27 04:56:38 +00:00
|
|
|
|
2010-12-19 04:50:32 +00:00
|
|
|
# Note that this is a subclass of VirtualBoxNotDetected, so developers
|
|
|
|
# who script Vagrant or use it as a library in any way can rescue from
|
|
|
|
# "VirtualBoxNotDetected" and catch both errors, which represent the
|
|
|
|
# same thing. This subclass simply has a specialized error message.
|
|
|
|
class VirtualBoxNotDetected_Win64 < VirtualBoxNotDetected
|
|
|
|
status_code(48)
|
|
|
|
error_key(:virtualbox_not_detected_win64)
|
|
|
|
end
|
|
|
|
|
2010-10-08 17:44:19 +00:00
|
|
|
class VMBaseMacNotSpecified < VagrantError
|
|
|
|
status_code(47)
|
|
|
|
error_key(:no_base_mac, "vagrant.actions.vm.match_mac")
|
|
|
|
end
|
|
|
|
|
2010-08-31 02:39:11 +00:00
|
|
|
class VMFailedToBoot < VagrantError
|
|
|
|
status_code(21)
|
|
|
|
error_key(:failed_to_boot, "vagrant.actions.vm.boot")
|
|
|
|
end
|
|
|
|
|
2010-08-31 03:07:50 +00:00
|
|
|
class VMImportFailure < VagrantError
|
|
|
|
status_code(28)
|
|
|
|
error_key(:failure, "vagrant.actions.vm.import")
|
|
|
|
end
|
|
|
|
|
2011-08-29 03:32:22 +00:00
|
|
|
class VMInaccessible < VagrantError
|
|
|
|
status_code(54)
|
|
|
|
error_key(:vm_inaccessible)
|
|
|
|
end
|
|
|
|
|
2010-08-27 06:21:28 +00:00
|
|
|
class VMNotCreatedError < VagrantError
|
|
|
|
status_code(6)
|
|
|
|
error_key(:vm_creation_required)
|
|
|
|
end
|
|
|
|
|
|
|
|
class VMNotFoundError < VagrantError
|
|
|
|
status_code(4)
|
|
|
|
error_key(:vm_not_found)
|
|
|
|
end
|
2010-08-31 02:39:11 +00:00
|
|
|
|
2010-09-30 06:37:24 +00:00
|
|
|
class VMNotRunningError < VagrantError
|
|
|
|
status_code(44)
|
|
|
|
error_key(:vm_not_running)
|
|
|
|
end
|
|
|
|
|
2010-08-31 02:39:11 +00:00
|
|
|
class VMPowerOffToPackage < VagrantError
|
|
|
|
status_code(24)
|
|
|
|
error_key(:power_off, "vagrant.actions.vm.export")
|
|
|
|
end
|
2010-09-01 21:26:53 +00:00
|
|
|
|
|
|
|
class VMSystemError < VagrantError
|
|
|
|
status_code(39)
|
|
|
|
error_namespace("vagrant.errors.system")
|
|
|
|
end
|
2010-08-27 04:56:38 +00:00
|
|
|
end
|
2010-08-24 18:18:29 +00:00
|
|
|
end
|