Создавайте объемы веракрипта, используя Голанг - PullRequest
0 голосов
/ 03 января 2019

Попытка передать инструкции командной строки go для запуска veracrypt, но она получает статус выхода 1 или не показывает ошибку и не создает запрошенный том.

func main() {
    cmd := exec.Command("veracrypt",
        "-c", "/home/user/test/samplevolume.vcrypt",
        "--volume-type", "normal",
        "--filesystem", "FAT",
        "--hash", "SHA256",
        "--encryption", "AES",
        "--size", "10M",
        "--pim", "1234",
        "-k", "",
        "--random-source", "/home/user/test/README.md")

    var out bytes.Buffer
    var stderr bytes.Buffer
    cmd.Stderr = &stderr

    stdin, err := cmd.StdinPipe()
    if err != nil {
        fmt.Println(fmt.Sprint(err))
    }

    go func() {
        defer stdin.Close()
        err = cmd.Run()
        // io.WriteString(stdin, "1234")
        // io.WriteString(stdin, "y")
        // io.WriteString(stdin, "1234")
    }()

    if err != nil {
        fmt.Println(fmt.Sprint(err) + ": " + stderr.String())
        return
    }
    fmt.Println("Result: " + out.String())
    // outin, err := cmd.CombinedOutput()
    // if err != nil {
    //  log.Fatal(err)
    // }

    // fmt.Printf("%s\n", outin)
}

Закомментированная часть - это другой подход, который я использовал, который приводит к состоянию выхода 1.

Причина передачи трех строк в конце «1234», y, «1234» заключается в том, что мы хотим ввести пароль в интерактивном режиме.

Код не заканчивается созданием файлов veracrypt.

Вот инструкции командной строки для veracrypt, которые мы пытаемся вызвать с помощью golang.

veracrypt -c ~/test/samplevolume.vcrypt --volume-type normal --filesystem FAT --hash SHA256 --encryption AES --size 10M --pim 1234 -k= --random-source ~/test/README.md

Примечание: все на linux, если это имеет значение.

Редактировать: Кроме того, я новичок в golang, извините, если я сделал очевидную ошибку.

Ответы [ 2 ]

0 голосов
/ 04 января 2019

Итак, я понял, что я делаю не так.Я должен был использовать cmd.Start и cmd.Wait.так вот исправленная версия.Эта версия также может правильно принимать пользовательский ввод.

func main() {
    cmd := exec.Command("veracrypt",
        "-c", "/home/user/test/samplevolume.vcrypt",
        "--volume-type", "normal",
        "--filesystem", "FAT",
        "--hash", "SHA256",
        "--encryption", "AES",
        "--size", "10M",
        "--pim", "1234",
        "-k", "",
        "--random-source", "/home/user/test/README.md")

    var out bytes.Buffer
    var stderr bytes.Buffer
    cmd.Stderr = &stderr

    stdin, err := cmd.StdinPipe()
    if err != nil {
        fmt.Println(fmt.Sprint(err))
    }

    go func() {
        defer stdin.Close()
        err = cmd.Start()
        io.WriteString(stdin, "1234\n")
        io.WriteString(stdin, "y\n")
        io.WriteString(stdin, "1234\n")
    }()

    if err != nil {
        fmt.Println(fmt.Sprint(err) + ": " + stderr.String())
        return
    }

    err = cmd.Wait()
    if err != nil {
        fmt.Printf("Command finished with error: %v", err)
    }

    fmt.Println("Result: " + out.String())
}
0 голосов
/ 03 января 2019

Вы использовали символ тильды ~ в именах путей, но это недопустимый символ в начале пути Unix.

Скорее, некоторые оболочки заменяют тильду путем путиДомашний каталог пользователя, прежде чем передавать его в операционную систему.

Поскольку вы не используете оболочку, вы должны предоставить действительный каталог самостоятельно.Вы не можете использовать тильду в начале пути.

...