require 'log4r' module VagrantPlugins module DockerProvider module Action class DestroyNetwork def initialize(app, env) @app = app @logger = Log4r::Logger.new('vagrant::plugins::docker::network') end def call(env) # If we are using a host VM, then don't worry about it machine = env[:machine] if machine.provider.host_vm? @logger.debug("Not setting up networks because docker host_vm is in use") return @app.call(env) end machine.config.vm.networks.each do |type, options| # We only handle private networks next if type != :private_network if options[:subnet] network_name = "vagrant_network_#{options[:subnet]}" else network_name = "vagrant_network" end if machine.provider.driver.existing_network?(network_name) && !machine.provider.driver.network_used?(network_name) env[:ui].info(I18n.t("docker_provider.network_destroy", network_name: network_name)) machine.provider.driver.rm_network(network_name) else @logger.debug("Network #{network_name} not found") end end @app.call(env) end end end end end