summaryrefslogtreecommitdiff
path: root/src/transport.go
diff options
context:
space:
mode:
authorxengineering <mail2xengineering@protonmail.com>2021-06-18 14:30:04 +0200
committerxengineering <mail2xengineering@protonmail.com>2021-06-18 14:30:04 +0200
commit7e08ae6ff7701632c8e3919b9dd3a7a13970835b (patch)
tree4b12cfc492d818a17793e2145425f95be08ced19 /src/transport.go
parent7634ee33120e7ef601ba1e806c63fe61c53e46bb (diff)
downloadbirdscan-7e08ae6ff7701632c8e3919b9dd3a7a13970835b.tar
birdscan-7e08ae6ff7701632c8e3919b9dd3a7a13970835b.tar.zst
birdscan-7e08ae6ff7701632c8e3919b9dd3a7a13970835b.zip
Remove defective Transporter
Diffstat (limited to 'src/transport.go')
-rw-r--r--src/transport.go125
1 files changed, 0 insertions, 125 deletions
diff --git a/src/transport.go b/src/transport.go
deleted file mode 100644
index 3e91355..0000000
--- a/src/transport.go
+++ /dev/null
@@ -1,125 +0,0 @@
-// vim: shiftwidth=4 tabstop=4 noexpandtab
-
-package main
-
-import (
- "time"
- "log"
- "os/exec"
- "fmt"
- "io"
-)
-
-type Transporter struct {
- statemachine Machine
-}
-
-type TransportConfig struct {
- Enabled bool `json:"enabled"`
- LocalPathToSshPrivateKey string `json:"local_path_to_ssh_private_key"`
- FileserverHostOrIp string `json:"fileserver_host_or_ip"`
- FileserverSshPort string `json:"fileserver_ssh_port"`
- RemoteUser string `json:"remote_user"`
- RemotePathToTargetDirectory string `json:"remote_path_to_target_directory"`
-}
-
-func NewTransporter() Transporter {
- return Transporter{
- statemachine: Machine{
- name: "transporter",
- initial: "idle",
- states: StateMap{
- "idle": MachineState{ // nothing to transport
- on: TransitionMap{
- "transport_request": MachineTransition{
- to: "transport",
- },
- },
- },
- "transport": MachineState{ // rsync process for transport is running
- on: TransitionMap{
- "transport_request": MachineTransition{
- to: "transport_queue",
- },
- "transport_finished": MachineTransition{
- to: "idle",
- },
- },
- },
- "transport_queue": MachineState{ // like transport but also a pending transport request
- on: TransitionMap{
- "transport_finished": MachineTransition{
- to: "transport",
- },
- },
- },
- },
- api: make(chan string),
- state_listeners: make([]*(chan string), 0),
- hook: runTransporterHooks,
- },
- }
-}
-
-func (transp *Transporter) Run() {
- transp.statemachine.Run()
-}
-
-func runTransporterHooks(last string, next string, m *Machine) {
- if last == "idle" && next == "transport" {
- go transportData(m)
- }
- if last == "transport_queue" && next == "transport" {
- go transportData(m)
- }
-}
-
-func transportData(m *Machine) {
- if config.Transport.Enabled {
- if !config.Flag.Debug {
-
- // generate command string from config
- cmdString := fmt.Sprintf(
- "\"rsync --remove-source-files -rltgoDv -e 'ssh -p %s -i %s' /var/lib/birdscan/ %s@%s:%s\"",
- config.Transport.FileserverSshPort,
- config.Transport.LocalPathToSshPrivateKey,
- config.Transport.RemoteUser,
- config.Transport.FileserverHostOrIp,
- config.Transport.RemotePathToTargetDirectory,
- )
-
- // create command
- cmd := exec.Command(
- "/bin/bash",
- "-c",
- cmdString,
- )
- log.Printf("Executing: '%s'", cmd.String())
-
- // get stderr
- stderr,err := cmd.StderrPipe()
- if err != nil {
- log.Print(err)
- }
- defer stderr.Close()
-
- // execute command and fetch stderr
- err = cmd.Start()
- if err != nil {
- log.Print(err)
- }
- stderrData,err := io.ReadAll(stderr)
- if err != nil {
- log.Print(err)
- }
- err = cmd.Wait()
- if err != nil {
- log.Print(err)
- log.Println(string(stderrData))
- }
- } else {
- time.Sleep(8 * time.Second)
- }
- }
- m.SendEvent("transport_finished")
-}