func (pkg *smPackage) writeTargetState(client connection.Client) error { sess, err := client.NewSession() if err != nil { return err } defer sess.Close() stdin, err := sess.StdinPipe() if err != nil { return errors.Wrap(err, "failed to receive stdin pipe") } tstamp := time.Now().UTC().Format("20060102T150405") filename := fmt.Sprintf("/var/lib/smutje/%s.%s.log", pkg.ID, tstamp) cmd := fmt.Sprintf(`bash -c "cat - > %[1]s && ln -sf %[1]s /var/lib/smutje/%[2]s.log"`, filename, pkg.ID) if err := sess.Start(cmd); err != nil { return err } if _, err := io.WriteString(stdin, strings.Join(pkg.state, "\n")+"\n"); err != nil { return errors.Wrap(err, "failed to send script to target") } stdin.Close() return sess.Wait() }
func runCommand(client connection.Client, cmd string) error { sess, err := client.NewSession() if err != nil { return err } defer sess.Close() if err := sess.Start(cmd); err != nil { return err } return sess.Wait() }
func (pkg *smPackage) readPackageState(client connection.Client) ([]string, error) { sess, err := client.NewSession() if err != nil { return nil, err } defer sess.Close() stdout, err := sess.StdoutPipe() if err != nil { return nil, err } fname := fmt.Sprintf("/var/lib/smutje/%s.log", pkg.ID) cmd := fmt.Sprintf(`bash -c "if [[ -f %[1]q ]]; then cat %[1]s; else mkdir -p /var/lib/smutje; fi"`, fname) if err := sess.Start(cmd); err != nil { return nil, err } buf := bytes.NewBuffer(nil) if _, err := io.Copy(buf, stdout); err != nil { return nil, errors.Wrap(err, "failed to copy output of command") } if err := sess.Wait(); err != nil { return nil, err } state := []string{} sc := bufio.NewScanner(buf) for sc.Scan() { l := sc.Text() switch l[0] { case '+', '.': state = append(state, l) case '-': //ignore default: return nil, errors.Errorf("invalid token read: %s", l) } } return state, errors.Wrap(sc.Err(), "failed to scan output") }