Skip to content

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