Class: Yast::NetworkServiceClass

Inherits:
Module
  • Object
show all
Includes:
Logger
Defined in:
library/network/src/modules/NetworkService.rb

Constant Summary collapse

BACKENDS =

network backend identification to service name mapping

{
  # <internal-id>        <service name>
  netconfig:       "network",
  network_manager: "NetworkManager",
  wicked:          "wicked"
}.freeze
BACKEND_PKG_NAMES =

network backend identification to its rpm package name mapping

{
  # <internal-id>        <service name>
  netconfig:       "sysconfig-network",
  network_manager: "NetworkManager",
  wicked:          "wicked"
}.freeze
DEFAULT_BACKEND =
:wicked

Instance Attribute Summary collapse

Instance Method Summary collapse

Instance Attribute Details

#cached_nameObject

Replies with currently selected network service name

Currently known backends: - :network_manager - not supported by YaST - :netconfig - supported - :wicked - supported (via its backward compatibility to ifup)


382
383
384
385
# File 'library/network/src/modules/NetworkService.rb', line 382

def cached_name
  Read()
  @cached_name
end

#current_nameObject

return [String, nil] current network backend identification, nil is valid value for "no service selected / running"


49
50
51
# File 'library/network/src/modules/NetworkService.rb', line 49

def current_name
  @current_name
end

Instance Method Details

#backend_available?(backend) ⇒ Boolean Also known as: is_backend_available

Checks if given network backend is available in the system


126
127
128
# File 'library/network/src/modules/NetworkService.rb', line 126

def backend_available?(backend)
  PackageSystem.Installed(BACKEND_PKG_NAMES[backend])
end

#backend_in_useSymbol?

Determines which backend is in use based on the network service. In an (auto)installation it returns the default backend except if systemd is running (live) where the systemd service can be checked.


195
196
197
198
199
200
201
202
203
204
205
206
207
# File 'library/network/src/modules/NetworkService.rb', line 195

def backend_in_use
  backend = nil

  if Stage.initial && !Systemd.Running
    backend = DEFAULT_BACKEND
    log.info "Running in installer/AutoYaST, use default: #{backend}"
  else
    service = Yast2::Systemd::Service.find("network")
    backend = BACKENDS.invert[service.name] if service
  end

  backend
end

#ConfirmNetworkManagerBoolean

Opens up a continue/cancel confirmation popup in the case when NetworkManager is enabled. User is informed that continuing the configuration may produce undefined results. If NetworkManager is not used, silently returns true.


287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
# File 'library/network/src/modules/NetworkService.rb', line 287

def ConfirmNetworkManager
  return true if @already_asked_for_NetworkManager || !network_manager?

  # TRANSLATORS: pop-up question when reading the service configuration
  cont = Popup.ContinueCancel(
    _(
      "Your network interfaces are currently controlled by NetworkManager\n" \
        "but the service to configure might not work well with it.\n" \
        "\n" \
        "Really continue?"
    )
  )
  Builtins.y2milestone(
    "Network is controlled by NetworkManager, user decided %1...",
    cont ? "to continue" : "not to continue"
  )
  @already_asked_for_NetworkManager = true

  cont
end

#disableObject

disables network service completely


182
183
184
185
186
187
188
# File 'library/network/src/modules/NetworkService.rb', line 182

def disable
  @cached_name = nil
  stop_service(@current_name)
  disable_service(@current_name)

  Read()
end

#disabled?Boolean Also known as: is_disabled


154
155
156
# File 'library/network/src/modules/NetworkService.rb', line 154

def disabled?
  cached_service?(nil)
end

#EnableDisableNowObject

Helper to apply a change of the network service


228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
# File 'library/network/src/modules/NetworkService.rb', line 228

def EnableDisableNow
  return if !Modified()

  if current_name
    stop_service(current_name)
    disable_service(current_name)
  end

  enable_service(cached_name) if cached_name

  @initialized = false
  Read()

  nil
end

#IsActiveObject

Reports if network service is active or not. It does not report if network is connected.


247
248
249
# File 'library/network/src/modules/NetworkService.rb', line 247

def IsActive
  RunSystemCtl("network", "is-active") == 0
end

#isNetworkRunningObject


308
309
310
# File 'library/network/src/modules/NetworkService.rb', line 308

def isNetworkRunning
  isNetworkv4Running || isNetworkv6Running
end

#isNetworkv4RunningObject

test for IPv4


313
314
315
316
317
318
319
320
321
322
323
324
325
# File 'library/network/src/modules/NetworkService.rb', line 313

def isNetworkv4Running
  net = SCR.Execute(
    path(".target.bash"),
    "/bin/ip addr | /usr/bin/grep -v '127.0.0\\|inet6' | /usr/bin/grep -c inet"
  )
  if net == 0
    Builtins.y2milestone("IPv4 network is running ...")
    return true
  else
    Builtins.y2milestone("IPv4 network is not running ...")
    return false
  end
end

#isNetworkv6RunningObject

test for IPv6


328
329
330
331
332
333
334
335
336
337
338
339
340
341
# File 'library/network/src/modules/NetworkService.rb', line 328

def isNetworkv6Running
  net = SCR.Execute(
    path(".target.bash"),
    "/bin/ip addr | /usr/bin/grep -v 'inet6 ::1\\|inet6 fe80' | /usr/bin/grep -c inet6"
  )

  if net == 0
    Builtins.y2milestone("IPv6 network is running ...")
    return true
  else
    Builtins.y2milestone("IPv6 network is not running ...")
    return false
  end
end

#mainObject


73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
# File 'library/network/src/modules/NetworkService.rb', line 73

def main
  Yast.import "NetworkConfig"
  Yast.import "Popup"
  Yast.import "Mode"
  Yast.import "Stage"
  Yast.import "PackageSystem"
  Yast.import "Systemd"

  textdomain "base"

  # if false, read needs to do work
  @initialized = false

  # Variable remembers that the question has been asked during this run already.
  # It avoids useless questions over and over again.
  @already_asked_for_NetworkManager = false
end

#ModifiedObject

Whether a network service change were requested


120
121
122
123
# File 'library/network/src/modules/NetworkService.rb', line 120

def Modified
  Read()
  @cached_name != @current_name
end

#netconfig?Boolean Also known as: is_netconfig


142
143
144
# File 'library/network/src/modules/NetworkService.rb', line 142

def netconfig?
  cached_service?(:netconfig)
end

#network_manager?Boolean Also known as: is_network_manager

Checks if configuration is managed by NetworkManager


136
137
138
# File 'library/network/src/modules/NetworkService.rb', line 136

def network_manager?
  cached_service?(:network_manager)
end

#ReadObject

Initialize module data


210
211
212
213
214
215
216
217
218
219
# File 'library/network/src/modules/NetworkService.rb', line 210

def Read
  return if @initialized

  @cached_name = @current_name = backend_in_use

  log.info "Current backend: #{@current_name}"
  @initialized = true

  nil
end

#ReloadOrRestartObject

Reload or restars the network service.


252
253
254
255
256
257
258
259
260
# File 'library/network/src/modules/NetworkService.rb', line 252

def ReloadOrRestart
  if Stage.initial    # inst-sys is not running systemd nor sysV init, so systemctl call
    # is not available and service has to be restarted directly

    wicked_restart
  else
    systemctl_reload_restart
  end
end

#reset!Object


221
222
223
224
225
# File 'library/network/src/modules/NetworkService.rb', line 221

def reset!
  @initialized = false
  @current_name = nil
  @cached_name = nil
end

#RestartObject

Restarts the network service


263
264
265
266
267
268
269
270
271
# File 'library/network/src/modules/NetworkService.rb', line 263

def Restart
  if Stage.initial
    wicked_restart
  else
    systemctl_restart
  end

  nil
end

#run_wicked(*params) ⇒ Object


108
109
110
111
112
113
114
115
116
# File 'library/network/src/modules/NetworkService.rb', line 108

def run_wicked(*params)
  cmd = "/usr/sbin/wicked #{params.map(&:shellescape).join(" ")}"
  ret = SCR.Execute(
    path(".target.bash"),
    cmd
  )

  Builtins.y2milestone("run_wicked: #{cmd} -> #{ret}")
end

#RunningNetworkPopupObject

If there is network running, return true. Otherwise show error popup depending on Stage and return false


346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
# File 'library/network/src/modules/NetworkService.rb', line 346

def RunningNetworkPopup
  network_running = isNetworkRunning

  log.info "RunningNetworkPopup #{network_running}"

  return true if network_running

  error_text = if Stage.initial
    _(
      "No running network detected.\n" \
      "Restart installation and configure network in Linuxrc\n" \
      "or continue without network."
    )
  else
    _(
      "No running network detected.\n" \
      "Configure network with YaST or Network Manager plug-in\n" \
      "and start this module again\n" \
      "or continue without network."
    )
  end

  ret = Popup.ContinueCancel(error_text)

  log.error "Network not runing!"
  ret
end

#RunSystemCtl(service, action, force: false) ⇒ Object

Helper to run systemctl actions

Raises:

  • (ArgumentError)

96
97
98
99
100
101
102
103
104
105
106
# File 'library/network/src/modules/NetworkService.rb', line 96

def RunSystemCtl(service, action, force: false)
  raise ArgumentError, "No network service defined." if service.nil?

  cmd = "/usr/bin/systemctl "\
    "#{force ? "--force" : ""} " \
    "#{action.shellescape} " \
    "#{service.shellescape}.service"
  ret = SCR.Execute(path(".target.bash_output"), cmd, "TERM" => "raw")
  Builtins.y2debug("RunSystemCtl: Command '%1' returned '%2'", cmd, ret)
  Ops.get_integer(ret, "exit", -1)
end

#StartStopObject

This is an old, confusing name for ReloadOrRestart() now


274
275
276
277
278
# File 'library/network/src/modules/NetworkService.rb', line 274

def StartStop
  ReloadOrRestart()

  nil
end

#use_netconfigObject


167
168
169
170
171
172
# File 'library/network/src/modules/NetworkService.rb', line 167

def use_netconfig
  Read()
  @cached_name = :netconfig

  nil
end

#use_network_managerObject


160
161
162
163
164
165
# File 'library/network/src/modules/NetworkService.rb', line 160

def use_network_manager
  Read()
  @cached_name = :network_manager

  nil
end

#use_wickedObject


174
175
176
177
178
179
# File 'library/network/src/modules/NetworkService.rb', line 174

def use_wicked
  Read()
  @cached_name = :wicked

  nil
end

#wicked?Boolean Also known as: is_wicked


148
149
150
# File 'library/network/src/modules/NetworkService.rb', line 148

def wicked?
  cached_service?(:wicked)
end