...
1
2
3
4 package crypt
5
6 import (
7 "bytes"
8 "crypto/rand"
9 "fmt"
10 "io"
11 "os"
12 )
13
14 func zeroFirstBlock(path string, blockSize int) error {
15 fout, err := os.OpenFile(path, os.O_WRONLY, 0)
16 if err != nil {
17 return fmt.Errorf("failed to open file for zero'ing: %w", err)
18 }
19 defer fout.Close()
20
21 size, err := fout.Seek(0, io.SeekEnd)
22 if err != nil {
23 return fmt.Errorf("error seeking end of %s: %w", path, err)
24 }
25 if size < int64(blockSize) {
26 return fmt.Errorf("file size is smaller than minimum expected: %d < %d", size, blockSize)
27 }
28
29 _, err = fout.Seek(0, io.SeekStart)
30 if err != nil {
31 return fmt.Errorf("error seeking start of %s: %w", path, err)
32 }
33
34 zeros := bytes.Repeat([]byte{0}, blockSize)
35 if _, err := fout.Write(zeros); err != nil {
36 return fmt.Errorf("failed to zero-out bytes: %w", err)
37 }
38 return nil
39 }
40
41
42 func generateKeyFile(path string, size int64) error {
43
44 keyArray := make([]byte, size)
45 _, err := rand.Read(keyArray[:])
46 if err != nil {
47 return fmt.Errorf("failed to generate key slice: %w", err)
48 }
49
50 if err := os.WriteFile(path, keyArray[:], 0644); err != nil {
51 return fmt.Errorf("failed to save key to file: %w", err)
52 }
53 return nil
54 }
55
View as plain text