Попытка передать инструкции командной строки 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, извините, если я сделал очевидную ошибку.