osal.zinit #
a sal to work with zinit
Easy reliable way how to work with processes
Example
import freeflowuniverse.crystallib.osal.zinit
fn main() {
do() or { panic(err) }
}
fn do() ! {
mut z:=zinit.get()!
z.destroy()!
// name string @[required]
// cmd string @[required]
// cmd_file bool //if we wanna force to run it as a file which is given to bash -c (not just a cmd in zinit)
// cmd_stop string
// cmd_test string
// test_file bool
// after []string
// env map[string]string
// oneshot bool
p:=z.new(
name:'test'
cmd:'/bin/bash'
)!
output:=p.log()!
println(output)
p.check()! //will check the process is up and running
p.stop()!
}
protocol defined in
sal on top of https://github.com/threefoldtech/zinit/tree/master
https://github.com/threefoldtech/zinit/blob/master/docs/protocol.md
fn check #
fn check() bool
fn destroy #
fn destroy() !
remove all know services to zinit
fn new #
fn new() !Zinit
fn new_rpc_client #
fn new_rpc_client(args ZinitClientArgs) Client
fn new_stateless #
fn new_stateless(z ZinitConfig) !ZinitStateless
enum StartupManagerType #
enum StartupManagerType {
unknown
zinit
systemd
screen
}
enum ZProcessStatus #
enum ZProcessStatus {
unknown
init
ok
killed
error
blocked
spawned
}
struct Client #
struct Client {
socket_path string = '/var/run/zinit.sock'
}
these need to be all private (non pub)
struct ZProcess #
struct ZProcess {
pub:
name string = 'default'
pub mut:
cmd string // command to start
cmd_stop string // command to stop (optional)
cmd_test string // command line to test service is running
workdir string // where to execute the commands
status ZProcessStatus
pid int
after []string // list of service we depend on
env map[string]string
oneshot bool
start bool = true
restart bool = true // whether the process should be restarted on failure
description string // not used in zinit
}
fn (ZProcess) check #
fn (mut zp ZProcess) check() !
will check that process is running
fn (ZProcess) cmd #
fn (zp ZProcess) cmd() !string
fn (ZProcess) cmdstop #
fn (zp ZProcess) cmdstop() !string
fn (ZProcess) cmdtest #
fn (zp ZProcess) cmdtest() !string
fn (ZProcess) destroy #
fn (mut zp ZProcess) destroy() !
fn (ZProcess) isrunning #
fn (mut zp ZProcess) isrunning() !bool
will check that process is running
fn (ZProcess) load #
fn (mut zp ZProcess) load() !
fn (ZProcess) log #
fn (zp ZProcess) log() !string
check if process is running if yes return the log
fn (ZProcess) output_wait #
fn (mut zp ZProcess) output_wait(c_ string, timeoutsec int) !
how long to wait till the specified output shows up, timeout in sec
fn (ZProcess) start #
fn (zp ZProcess) start() !
fn (ZProcess) status #
fn (mut zp ZProcess) status() !ZProcessStatus
return status of process
enum ZProcessStatus {
unknown
init
ok
error
blocked
spawned
killed
}
fn (ZProcess) stop #
fn (mut zp ZProcess) stop() !
struct ZProcessNewArgs #
@[params]
struct ZProcessNewArgs {
pub mut:
name string @[required]
cmd string @[required]
cmd_stop string // command to stop (optional)
cmd_test string // command line to test service is running
workdir string // where to execute the commands
after []string // list of service we depend on
env map[string]string
oneshot bool
start bool = true
restart bool = true // whether the process should be restarted on failure
description string // not used in zinit
startuptype StartupManagerType
}
struct Zinit #
@[heap]
struct Zinit {
pub mut:
processes map[string]ZProcess
path pathlib.Path
pathcmds pathlib.Path
}
fn (Zinit) new #
fn (mut zinit Zinit) new(args_ ZProcessNewArgs) !ZProcess
will delete the process if it exists while starting
fn (Zinit) get #
fn (mut zinit Zinit) get(name_ string) !ZProcess
fn (Zinit) exists #
fn (mut zinit Zinit) exists(name_ string) bool
fn (Zinit) stop #
fn (mut zinit Zinit) stop(name string) !
fn (Zinit) start #
fn (mut zinit Zinit) start(name string) !
fn (Zinit) delete #
fn (mut zinit Zinit) delete(name string) !
fn (Zinit) load #
fn (mut self Zinit) load() !
fn (Zinit) names #
fn (mut self Zinit) names() []string
struct ZinitConfig #
@[params]
struct ZinitConfig {
path string = '/etc/zinit'
pathcmds string = '/etc/zinit/cmds'
}
struct ZinitStateless #
struct ZinitStateless {
pub mut:
client Client
path pathlib.Path
pathcmds pathlib.Path
}
fn (ZinitStateless) new #
fn (mut zinit ZinitStateless) new(args_ ZProcessNewArgs) !ZProcess
will delete the process if it exists while starting
fn (ZinitStateless) exists #
fn (zinit ZinitStateless) exists(name string) !bool
fn (ZinitStateless) stop #
fn (mut zinit ZinitStateless) stop(name string) !
fn (ZinitStateless) start #
fn (mut zinit ZinitStateless) start(name string) !
fn (ZinitStateless) running #
fn (mut zinit ZinitStateless) running(name string) !bool
fn (ZinitStateless) delete #
fn (mut zinit ZinitStateless) delete(name string) !
fn (ZinitStateless) names #
fn (mut self ZinitStateless) names() ![]string