This commit is contained in:
2025-08-16 17:45:04 +02:00
parent de60c5f78e
commit 5825640c2c
98 changed files with 3115 additions and 2120 deletions

View File

@@ -2,27 +2,33 @@ module golang
import freeflowuniverse.herolib.core.playbook { PlayBook }
import freeflowuniverse.herolib.ui.console
import json
import freeflowuniverse.herolib.osal.startupmanager
import freeflowuniverse.herolib.osal.zinit
__global (
golang_global map[string]&GolangInstaller
golang_default string
)
/////////FACTORY
@[params]
pub struct ArgsGet {
pub mut:
name string
name string = 'default'
}
pub fn get(args_ ArgsGet) !&GolangInstaller {
pub fn new(args ArgsGet) !&GolangInstaller {
return &GolangInstaller{}
}
pub fn get(args ArgsGet) !&GolangInstaller {
return new(args)!
}
pub fn play(mut plbook PlayBook) ! {
if !plbook.exists(filter: 'golang.') {
return
}
mut install_actions := plbook.find(filter: 'golang.configure')!
if install_actions.len > 0 {
return error("can't configure golang, because no configuration allowed for this installer.")
}
mut other_actions := plbook.find(filter: 'golang.')!
for other_action in other_actions {
if other_action.name in ['destroy', 'install', 'build'] {
@@ -44,28 +50,6 @@ pub fn play(mut plbook PlayBook) ! {
//////////////////////////# LIVE CYCLE MANAGEMENT FOR INSTALLERS ///////////////////////////////////
////////////////////////////////////////////////////////////////////////////////////////////////////
fn startupmanager_get(cat zinit.StartupManagerType) !startupmanager.StartupManager {
// unknown
// screen
// zinit
// tmux
// systemd
match cat {
.zinit {
console.print_debug('startupmanager: zinit')
return startupmanager.get(cat: .zinit)!
}
.systemd {
console.print_debug('startupmanager: systemd')
return startupmanager.get(cat: .systemd)!
}
else {
console.print_debug('startupmanager: auto')
return startupmanager.get()!
}
}
}
@[params]
pub struct InstallArgs {
pub mut:
@@ -91,12 +75,4 @@ pub fn (mut self GolangInstaller) destroy() ! {
// switch instance to be used for golang
pub fn switch(name string) {
golang_default = name
}
// helpers
@[params]
pub struct DefaultConfigArgs {
instance string = 'default'
}

View File

@@ -2,27 +2,33 @@ module nodejs
import freeflowuniverse.herolib.core.playbook { PlayBook }
import freeflowuniverse.herolib.ui.console
import json
import freeflowuniverse.herolib.osal.startupmanager
import freeflowuniverse.herolib.osal.zinit
__global (
nodejs_global map[string]&NodeJS
nodejs_default string
)
/////////FACTORY
@[params]
pub struct ArgsGet {
pub mut:
name string
name string = 'default'
}
pub fn get(args_ ArgsGet) !&NodeJS {
pub fn new(args ArgsGet) !&NodeJS {
return &NodeJS{}
}
pub fn get(args ArgsGet) !&NodeJS {
return new(args)!
}
pub fn play(mut plbook PlayBook) ! {
if !plbook.exists(filter: 'nodejs.') {
return
}
mut install_actions := plbook.find(filter: 'nodejs.configure')!
if install_actions.len > 0 {
return error("can't configure nodejs, because no configuration allowed for this installer.")
}
mut other_actions := plbook.find(filter: 'nodejs.')!
for other_action in other_actions {
if other_action.name in ['destroy', 'install', 'build'] {
@@ -44,28 +50,6 @@ pub fn play(mut plbook PlayBook) ! {
//////////////////////////# LIVE CYCLE MANAGEMENT FOR INSTALLERS ///////////////////////////////////
////////////////////////////////////////////////////////////////////////////////////////////////////
fn startupmanager_get(cat zinit.StartupManagerType) !startupmanager.StartupManager {
// unknown
// screen
// zinit
// tmux
// systemd
match cat {
.zinit {
console.print_debug('startupmanager: zinit')
return startupmanager.get(cat: .zinit)!
}
.systemd {
console.print_debug('startupmanager: systemd')
return startupmanager.get(cat: .systemd)!
}
else {
console.print_debug('startupmanager: auto')
return startupmanager.get()!
}
}
}
@[params]
pub struct InstallArgs {
pub mut:
@@ -86,12 +70,4 @@ pub fn (mut self NodeJS) destroy() ! {
// switch instance to be used for nodejs
pub fn switch(name string) {
nodejs_default = name
}
// helpers
@[params]
pub struct DefaultConfigArgs {
instance string = 'default'
}

View File

@@ -2,27 +2,33 @@ module python
import freeflowuniverse.herolib.core.playbook { PlayBook }
import freeflowuniverse.herolib.ui.console
import json
import freeflowuniverse.herolib.osal.startupmanager
import freeflowuniverse.herolib.osal.zinit
__global (
python_global map[string]&PythonInstaller
python_default string
)
/////////FACTORY
@[params]
pub struct ArgsGet {
pub mut:
name string
name string = 'default'
}
pub fn get(args_ ArgsGet) !&PythonInstaller {
pub fn new(args ArgsGet) !&PythonInstaller {
return &PythonInstaller{}
}
pub fn get(args ArgsGet) !&PythonInstaller {
return new(args)!
}
pub fn play(mut plbook PlayBook) ! {
if !plbook.exists(filter: 'python.') {
return
}
mut install_actions := plbook.find(filter: 'python.configure')!
if install_actions.len > 0 {
return error("can't configure python, because no configuration allowed for this installer.")
}
mut other_actions := plbook.find(filter: 'python.')!
for other_action in other_actions {
if other_action.name in ['destroy', 'install', 'build'] {
@@ -44,28 +50,6 @@ pub fn play(mut plbook PlayBook) ! {
//////////////////////////# LIVE CYCLE MANAGEMENT FOR INSTALLERS ///////////////////////////////////
////////////////////////////////////////////////////////////////////////////////////////////////////
fn startupmanager_get(cat zinit.StartupManagerType) !startupmanager.StartupManager {
// unknown
// screen
// zinit
// tmux
// systemd
match cat {
.zinit {
console.print_debug('startupmanager: zinit')
return startupmanager.get(cat: .zinit)!
}
.systemd {
console.print_debug('startupmanager: systemd')
return startupmanager.get(cat: .systemd)!
}
else {
console.print_debug('startupmanager: auto')
return startupmanager.get()!
}
}
}
@[params]
pub struct InstallArgs {
pub mut:
@@ -86,12 +70,4 @@ pub fn (mut self PythonInstaller) destroy() ! {
// switch instance to be used for python
pub fn switch(name string) {
python_default = name
}
// helpers
@[params]
pub struct DefaultConfigArgs {
instance string = 'default'
}

View File

@@ -2,27 +2,33 @@ module rust
import freeflowuniverse.herolib.core.playbook { PlayBook }
import freeflowuniverse.herolib.ui.console
import json
import freeflowuniverse.herolib.osal.startupmanager
import freeflowuniverse.herolib.osal.zinit
__global (
rust_global map[string]&RustInstaller
rust_default string
)
/////////FACTORY
@[params]
pub struct ArgsGet {
pub mut:
name string
name string = 'default'
}
pub fn get(args_ ArgsGet) !&RustInstaller {
pub fn new(args ArgsGet) !&RustInstaller {
return &RustInstaller{}
}
pub fn get(args ArgsGet) !&RustInstaller {
return new(args)!
}
pub fn play(mut plbook PlayBook) ! {
if !plbook.exists(filter: 'rust.') {
return
}
mut install_actions := plbook.find(filter: 'rust.configure')!
if install_actions.len > 0 {
return error("can't configure rust, because no configuration allowed for this installer.")
}
mut other_actions := plbook.find(filter: 'rust.')!
for other_action in other_actions {
if other_action.name in ['destroy', 'install', 'build'] {
@@ -44,28 +50,6 @@ pub fn play(mut plbook PlayBook) ! {
//////////////////////////# LIVE CYCLE MANAGEMENT FOR INSTALLERS ///////////////////////////////////
////////////////////////////////////////////////////////////////////////////////////////////////////
fn startupmanager_get(cat zinit.StartupManagerType) !startupmanager.StartupManager {
// unknown
// screen
// zinit
// tmux
// systemd
match cat {
.zinit {
console.print_debug('startupmanager: zinit')
return startupmanager.get(cat: .zinit)!
}
.systemd {
console.print_debug('startupmanager: systemd')
return startupmanager.get(cat: .systemd)!
}
else {
console.print_debug('startupmanager: auto')
return startupmanager.get()!
}
}
}
@[params]
pub struct InstallArgs {
pub mut:
@@ -86,12 +70,4 @@ pub fn (mut self RustInstaller) destroy() ! {
// switch instance to be used for rust
pub fn switch(name string) {
rust_default = name
}
// helpers
@[params]
pub struct DefaultConfigArgs {
instance string = 'default'
}