1
0
Fork 0
mirror of https://github.com/HACKERALERT/Picocrypt.git synced 2025-01-02 12:52:17 +00:00

Update code with latest changes

This commit is contained in:
Evan Su 2022-04-18 17:46:13 -04:00 committed by GitHub
parent 3d4836b449
commit e3a7cdf63c
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 94 additions and 65 deletions

View file

@ -2,7 +2,7 @@ package main
/* /*
Picocrypt v1.25 Picocrypt v1.26
Copyright (c) Evan Su (https://evansu.cc) Copyright (c) Evan Su (https://evansu.cc)
Released under a GNU GPL v3 License Released under a GNU GPL v3 License
https://github.com/HACKERALERT/Picocrypt https://github.com/HACKERALERT/Picocrypt
@ -48,7 +48,7 @@ import (
) )
// Generic variables // Generic variables
var version = "v1.25" var version = "v1.26"
var window *giu.MasterWindow var window *giu.MasterWindow
var dpi float32 var dpi float32
var mode string var mode string
@ -100,7 +100,7 @@ var reedsolo bool
var deleteWhenDone bool var deleteWhenDone bool
var split bool var split bool
var splitSize string var splitSize string
var splitUnits = []string{"KiB", "MiB", "GiB"} var splitUnits = []string{"KiB", "MiB", "GiB", "TiB"}
var splitSelected int32 = 1 var splitSelected int32 = 1
var compress bool var compress bool
var keep bool var keep bool
@ -393,7 +393,7 @@ func draw() {
} }
fout, _ := os.Create(file) fout, _ := os.Create(file)
data := make([]byte, 1048576) data := make([]byte, 1<<20)
rand.Read(data) rand.Read(data)
fout.Write(data) fout.Write(data)
fout.Close() fout.Close()
@ -401,14 +401,16 @@ func draw() {
giu.Tooltip("Generate a cryptographically secure keyfile."), giu.Tooltip("Generate a cryptographically secure keyfile."),
), ),
giu.Style().SetDisabled(true).To( giu.Style().SetDisabled(true).To(
giu.Button(keyfilePrompt).Size(giu.Auto, 0), giu.InputText(&keyfilePrompt).Size(giu.Auto),
), ),
), ),
), ),
), ),
giu.Separator(), giu.Separator(),
giu.Style().SetDisabled(password == "" || (password != cpassword && mode == "encrypt")).To( giu.Style().SetDisabled((len(keyfiles) == 0 && password == "") ||
(mode == "encrypt" && password != cpassword)).To(
giu.Label(commentsPrompt), giu.Label(commentsPrompt),
giu.Style().SetDisabled(commentsDisabled).To( giu.Style().SetDisabled(commentsDisabled).To(
giu.InputText(&comments).Size(giu.Auto), giu.InputText(&comments).Size(giu.Auto),
@ -465,7 +467,14 @@ func draw() {
bw += p * 2 bw += p * 2
dw := w - bw - p dw := w - bw - p
giu.Style().SetDisabled(true).To( giu.Style().SetDisabled(true).To(
giu.InputText(&outputFile).Size(dw / dpi / dpi).Flags(16384), giu.InputText(func() *string {
tmp := ""
if outputFile == "" {
return &tmp
}
tmp = filepath.Base(outputFile)
return &tmp
}()).Size(dw / dpi / dpi).Flags(16384),
).Build() ).Build()
giu.SameLine() giu.SameLine()
@ -585,6 +594,7 @@ func onDrop(names []string) {
onlyFolders = nil onlyFolders = nil
allFiles = nil allFiles = nil
files, folders := 0, 0 files, folders := 0, 0
size := 0
resetUI() resetUI()
// One item dropped // One item dropped
@ -732,6 +742,7 @@ func onDrop(names []string) {
// Add the file // Add the file
onlyFiles = append(onlyFiles, names[0]) onlyFiles = append(onlyFiles, names[0])
inputFile = names[0] inputFile = names[0]
size += int(stat.Size())
} }
} else { // There are multiple dropped items } else { // There are multiple dropped items
mode = "encrypt" mode = "encrypt"
@ -746,6 +757,7 @@ func onDrop(names []string) {
files++ files++
onlyFiles = append(onlyFiles, name) onlyFiles = append(onlyFiles, name)
allFiles = append(allFiles, name) allFiles = append(allFiles, name)
size += int(stat.Size())
} }
} }
@ -778,10 +790,13 @@ func onDrop(names []string) {
stat, _ := os.Stat(path) stat, _ := os.Stat(path)
if !stat.IsDir() { if !stat.IsDir() {
allFiles = append(allFiles, path) allFiles = append(allFiles, path)
size += int(stat.Size())
} }
return nil return nil
}) })
} }
inputLabel = fmt.Sprintf("%s (%s)", inputLabel, sizeify(int64(size)))
} }
func work() { func work() {
@ -907,7 +922,7 @@ func work() {
for i := 0; i < total; i++ { for i := 0; i < total; i++ {
fin, _ := os.Open(fmt.Sprintf("%s.%d", inputFile, i)) fin, _ := os.Open(fmt.Sprintf("%s.%d", inputFile, i))
for { for {
data := make([]byte, 1048576) data := make([]byte, 1<<20)
read, err := fin.Read(data) read, err := fin.Read(data)
if err != nil { if err != nil {
break break
@ -932,16 +947,6 @@ func work() {
total -= 789 total -= 789
} }
// XChaCha20's max input is 256 GiB, panic at one block less
if total >= int64((math.Pow(2, 32)-1)*64) {
mainStatus = "The input data is too big to encrypt."
mainStatusColor = color.RGBA{0xff, 0x00, 0x00, 0xff}
if len(allFiles) > 1 || len(onlyFolders) > 0 {
os.Remove(inputFile)
}
return
}
// Open input file in read-only mode // Open input file in read-only mode
fin, err := os.Open(inputFile) fin, err := os.Open(inputFile)
if err != nil { if err != nil {
@ -1008,7 +1013,7 @@ func work() {
if reedsolo { // Full Reed-Solomon encoding is selected if reedsolo { // Full Reed-Solomon encoding is selected
flags[3] = 1 flags[3] = 1
} }
if total%1048576 >= 1048448 { // Reed-Solomon internals if total%(1<<20) >= 1<<20-128 { // Reed-Solomon internals
flags[4] = 1 flags[4] = 1
} }
flags = rsEncode(rs5, flags) flags = rsEncode(rs5, flags)
@ -1111,7 +1116,7 @@ func work() {
[]byte(password), []byte(password),
salt, salt,
8, // 8 passes 8, // 8 passes
1048576, // 1 GiB memory 1<<20, // 1 GiB memory
8, // 8 threads 8, // 8 threads
32, // 32-byte output key 32, // 32-byte output key
) )
@ -1120,7 +1125,7 @@ func work() {
[]byte(password), []byte(password),
salt, salt,
4, 4,
1048576, 1<<20,
4, 4,
32, 32,
) )
@ -1251,9 +1256,10 @@ func work() {
} }
done := 0 done := 0
counterDone := 0
counter := 0 counter := 0
startTime := time.Now() startTime := time.Now()
chacha20, _ := chacha20.NewUnauthenticatedCipher(key, nonce) chacha, _ := chacha20.NewUnauthenticatedCipher(key, nonce)
// Use HKDF-SHA3 to generate a subkey // Use HKDF-SHA3 to generate a subkey
var mac hash.Hash var mac hash.Hash
@ -1269,8 +1275,8 @@ func work() {
// Generate another subkey and cipher (not used unless paranoid mode is checked) // Generate another subkey and cipher (not used unless paranoid mode is checked)
serpentKey := make([]byte, 32) serpentKey := make([]byte, 32)
hkdf.Read(serpentKey) hkdf.Read(serpentKey)
srpnt, _ := serpent.NewCipher(serpentKey) s, _ := serpent.NewCipher(serpentKey)
serpent := cipher.NewCTR(srpnt, serpentSalt) serpent := cipher.NewCTR(s, serpentSalt)
for { for {
// If the user cancels the process, stop and clean up // If the user cancels the process, stop and clean up
@ -1292,9 +1298,9 @@ func work() {
// Read in data from the file // Read in data from the file
var src []byte var src []byte
if mode == "decrypt" && reedsolo { if mode == "decrypt" && reedsolo {
src = make([]byte, 1114112) src = make([]byte, 1<<20/128*136)
} else { } else {
src = make([]byte, 1048576) src = make([]byte, 1<<20)
} }
size, err := fin.Read(src) size, err := fin.Read(src)
if err != nil { if err != nil {
@ -1310,16 +1316,16 @@ func work() {
copy(src, dst) copy(src, dst)
} }
chacha20.XORKeyStream(dst, src) chacha.XORKeyStream(dst, src)
mac.Write(dst) mac.Write(dst)
if reedsolo { if reedsolo {
copy(src, dst) copy(src, dst)
dst = nil dst = nil
// If a full MiB is available // If a full MiB is available
if len(src) == 1048576 { if len(src) == 1<<20 {
// Encode every chunk // Encode every chunk
for i := 0; i < 1048576; i += 128 { for i := 0; i < 1<<20; i += 128 {
dst = append(dst, rsEncode(rs128, src[i:i+128])...) dst = append(dst, rsEncode(rs128, src[i:i+128])...)
} }
} else { } else {
@ -1338,9 +1344,9 @@ func work() {
copy(dst, src) copy(dst, src)
src = nil src = nil
// If a complete 1 MiB block is available // If a complete 1 MiB block is available
if len(dst) == 1114112 { if len(dst) == 1<<20/128*136 {
// Decode every chunk // Decode every chunk
for i := 0; i < 1114112; i += 136 { for i := 0; i < 1<<20/128*136; i += 136 {
tmp, err := rsDecode(rs128, dst[i:i+136]) tmp, err := rsDecode(rs128, dst[i:i+136])
if err != nil { if err != nil {
if keep { if keep {
@ -1353,7 +1359,7 @@ func work() {
return return
} }
} }
if i == 1113976 && done+1114112 >= int(total) && padded { if i == 1113976 && done+1<<20/128*136 >= int(total) && padded {
tmp = unpad(tmp) tmp = unpad(tmp)
} }
src = append(src, tmp...) src = append(src, tmp...)
@ -1396,7 +1402,7 @@ func work() {
} }
mac.Write(src) mac.Write(src)
chacha20.XORKeyStream(dst, src) chacha.XORKeyStream(dst, src)
if paranoid { if paranoid {
copy(src, dst) copy(src, dst)
@ -1407,21 +1413,29 @@ func work() {
// Update stats // Update stats
if mode == "decrypt" && reedsolo { if mode == "decrypt" && reedsolo {
done += 1114112 done += 1 << 20 / 128 * 136
} else { } else {
done += 1048576 done += 1 << 20
} }
counterDone += 1 << 20
counter++ counter++
progress = float32(done) / float32(total) progress = float32(done) / float32(total)
elapsed := float64(time.Since(startTime)) / math.Pow(10, 9) elapsed := float64(time.Since(startTime)) / (1 << 20) / 1000
speed := float64(done) / elapsed / math.Pow(10, 6) speed := float64(done) / elapsed / (1 << 20)
eta := int(math.Floor(float64(total-int64(done)) / (speed * math.Pow(10, 6)))) eta := int(math.Floor(float64(total-int64(done)) / (speed * (1 << 20))))
if progress > 1 { // If the progress bar ever goes out of bounds, cap it at 100% progress = float32(math.Min(float64(progress), 1)) // Cap progress to 100%
progress = 1
}
progressInfo = fmt.Sprintf("%.2f%%", progress*100) progressInfo = fmt.Sprintf("%.2f%%", progress*100)
popupStatus = fmt.Sprintf("Working at %.2f MB/s (ETA: %s)", speed, humanize(eta)) popupStatus = fmt.Sprintf("Working at %.2f MiB/s (ETA: %s)", speed, humanize(eta))
giu.Update() giu.Update()
// If more than 256 GiB passed, change the nonce to prevent counter overflow
blocks := counterDone/64 + 1
if blocks+(1<<20/64) > 1<<32 {
nonce = make([]byte, 24)
hkdf.Read(nonce)
chacha, _ = chacha20.NewUnauthenticatedCipher(key, nonce)
counterDone = 0
}
} }
if mode == "encrypt" { if mode == "encrypt" {
@ -1457,13 +1471,15 @@ func work() {
finishedRaw := 0 finishedRaw := 0
chunkSize, _ := strconv.Atoi(splitSize) chunkSize, _ := strconv.Atoi(splitSize)
// User can choose KiB, MiB, and GiB // User can choose KiB, MiB, GiB, or TiB
if splitSelected == 0 { if splitSelected == 0 {
chunkSize *= 1024 chunkSize *= 1 << 10
} else if splitSelected == 1 { } else if splitSelected == 1 {
chunkSize *= 1048576 chunkSize *= 1 << 20
} else if splitSelected == 2 {
chunkSize *= 1 << 30
} else { } else {
chunkSize *= 1073741824 chunkSize *= 1 << 40
} }
// Get the number of required chunks // Get the number of required chunks
@ -1478,7 +1494,7 @@ func work() {
// Copy data into the chunk // Copy data into the chunk
for { for {
data := make([]byte, 1048576) data := make([]byte, 1<<20)
read, err := fin.Read(data) read, err := fin.Read(data)
if err != nil { if err != nil {
break break
@ -1714,6 +1730,19 @@ func humanize(seconds int) string {
return fmt.Sprintf("%02d:%02d:%02d", hours, minutes, seconds) return fmt.Sprintf("%02d:%02d:%02d", hours, minutes, seconds)
} }
// Convert bytes to KiB, MiB, etc.
func sizeify(size int64) string {
if size >= int64(1<<40) {
return fmt.Sprintf("%.2fT", float64(size)/(1<<40))
} else if size >= int64(1<<30) {
return fmt.Sprintf("%.2fG", float64(size)/(1<<30))
} else if size >= int64(1<<20) {
return fmt.Sprintf("%.0fM", float64(size)/(1<<20))
} else {
return fmt.Sprintf("%.0fK", float64(size)/(1<<10))
}
}
func main() { func main() {
// Create the main window // Create the main window
window = giu.NewMasterWindow("Picocrypt", 318, 479, giu.MasterWindowFlagsNotResizable) window = giu.NewMasterWindow("Picocrypt", 318, 479, giu.MasterWindowFlagsNotResizable)

View file

@ -5,17 +5,17 @@ go 1.17
require ( require (
github.com/HACKERALERT/clipboard v0.1.5-0.20211215214929-7345ba96aeca github.com/HACKERALERT/clipboard v0.1.5-0.20211215214929-7345ba96aeca
github.com/HACKERALERT/crypto v0.0.0-20220412024110-ba8732acd7e7 github.com/HACKERALERT/crypto v0.0.0-20220412024110-ba8732acd7e7
github.com/HACKERALERT/dialog v0.0.0-20220410221520-a9e6303eda42 github.com/HACKERALERT/dialog v0.0.0-20220415015354-cd2cf9c423ec
github.com/HACKERALERT/giu v0.5.7-0.20220411212054-a37934efe9a9 github.com/HACKERALERT/giu v0.5.7-0.20220418211504-32988b007704
github.com/HACKERALERT/infectious v0.0.0-20220412021528-bb1303403749 github.com/HACKERALERT/infectious v0.0.0-20220412021528-bb1303403749
github.com/HACKERALERT/serpent v0.0.0-20210716182301-293b29869c66 github.com/HACKERALERT/serpent v0.0.0-20210716182301-293b29869c66
github.com/HACKERALERT/zxcvbn-go v0.0.0-20210927200100-f131a4666ad5 github.com/HACKERALERT/zxcvbn-go v0.0.0-20210927200100-f131a4666ad5
) )
require ( require (
github.com/HACKERALERT/gl v0.0.0-20220411210853-402fdd216609 // indirect github.com/HACKERALERT/gl v0.0.0-20220417032545-0e093e3300ba // indirect
github.com/HACKERALERT/glfw/v3.3/glfw v0.0.0-20211216001154-d0da149b3bef // indirect github.com/HACKERALERT/glfw/v3.3/glfw v0.0.0-20220418211004-bfe86c8a6804 // indirect
github.com/HACKERALERT/imgui-go v1.12.1-0.20220411211703-da7cd33ca753 // indirect github.com/HACKERALERT/imgui-go v1.12.1-0.20220418211401-490889e6f8b6 // indirect
github.com/HACKERALERT/mainthread v0.0.0-20211027212305-2ec9e701cc14 // indirect github.com/HACKERALERT/mainthread v0.0.0-20211027212305-2ec9e701cc14 // indirect
github.com/HACKERALERT/sys v0.0.0-20220412020404-2e09c491f471 // indirect github.com/HACKERALERT/sys v0.0.0-20220412020404-2e09c491f471 // indirect
github.com/HACKERALERT/w32 v0.0.0-20211215215707-4b84c2675d8d // indirect github.com/HACKERALERT/w32 v0.0.0-20211215215707-4b84c2675d8d // indirect

View file

@ -2,16 +2,16 @@ github.com/HACKERALERT/clipboard v0.1.5-0.20211215214929-7345ba96aeca h1:yZj12M2
github.com/HACKERALERT/clipboard v0.1.5-0.20211215214929-7345ba96aeca/go.mod h1:kkjR9AGvIlIUJdjd/CBL1VfQvyPDE5kL31rAzY/r0s4= github.com/HACKERALERT/clipboard v0.1.5-0.20211215214929-7345ba96aeca/go.mod h1:kkjR9AGvIlIUJdjd/CBL1VfQvyPDE5kL31rAzY/r0s4=
github.com/HACKERALERT/crypto v0.0.0-20220412024110-ba8732acd7e7 h1:vOy0zRm74+1hPiUJ6R2EQl+agZBo+KcGQR85OWCzEZQ= github.com/HACKERALERT/crypto v0.0.0-20220412024110-ba8732acd7e7 h1:vOy0zRm74+1hPiUJ6R2EQl+agZBo+KcGQR85OWCzEZQ=
github.com/HACKERALERT/crypto v0.0.0-20220412024110-ba8732acd7e7/go.mod h1:XjuRsuBwllqVRs7DqJrbpPeUsT3qebqANdKSBJnNn0s= github.com/HACKERALERT/crypto v0.0.0-20220412024110-ba8732acd7e7/go.mod h1:XjuRsuBwllqVRs7DqJrbpPeUsT3qebqANdKSBJnNn0s=
github.com/HACKERALERT/dialog v0.0.0-20220410221520-a9e6303eda42 h1:YdKzDcpjykZRSVQSah9gLMxY7H7DAbk+L/AHKypYwSI= github.com/HACKERALERT/dialog v0.0.0-20220415015354-cd2cf9c423ec h1:BT5dOJ3xggkQOHAJTko58Fjs7/QuyBP6o3PKYWZ8N+M=
github.com/HACKERALERT/dialog v0.0.0-20220410221520-a9e6303eda42/go.mod h1:GxPIEf2nKp6Gx+sdpjwTdFIGmW5kj6Jta7rRO50TgpU= github.com/HACKERALERT/dialog v0.0.0-20220415015354-cd2cf9c423ec/go.mod h1:GxPIEf2nKp6Gx+sdpjwTdFIGmW5kj6Jta7rRO50TgpU=
github.com/HACKERALERT/giu v0.5.7-0.20220411212054-a37934efe9a9 h1:OkhEGzCEjVZ683etseTpDvewMXOjqkcnG6puAbX88hM= github.com/HACKERALERT/giu v0.5.7-0.20220418211504-32988b007704 h1:k7R+pk5W2aNtK51zBlf1nTrLeSNT4cHh07uF9zugzS8=
github.com/HACKERALERT/giu v0.5.7-0.20220411212054-a37934efe9a9/go.mod h1:Mp6wVuSFEx2nI/XrHw7nce2aAh5nIbqIgozUbMVLlUs= github.com/HACKERALERT/giu v0.5.7-0.20220418211504-32988b007704/go.mod h1:8b1hTZsUiy0j1LqbRSPksiUnP0AISeMGouhqXcOXLP0=
github.com/HACKERALERT/gl v0.0.0-20220411210853-402fdd216609 h1:AOJrzpVT3VYIpPH9BD0tXHBDMljK5FhORrz47Odc5/U= github.com/HACKERALERT/gl v0.0.0-20220417032545-0e093e3300ba h1:AGAO9HNDmj3Rx/zsnmeqmZSs/d6Sm3bW9FYqgHTXmAw=
github.com/HACKERALERT/gl v0.0.0-20220411210853-402fdd216609/go.mod h1:ZUosVzfEKNGLMLk6aj9yo0FSAhWWsbTMjuzeIUXniB0= github.com/HACKERALERT/gl v0.0.0-20220417032545-0e093e3300ba/go.mod h1:ZUosVzfEKNGLMLk6aj9yo0FSAhWWsbTMjuzeIUXniB0=
github.com/HACKERALERT/glfw/v3.3/glfw v0.0.0-20211216001154-d0da149b3bef h1:MWA48bM0uKSblAiB51YtMDWEBhJtX+s3HcjlUN7o8cE= github.com/HACKERALERT/glfw/v3.3/glfw v0.0.0-20220418211004-bfe86c8a6804 h1:KnV8GLNQDt2oLnvYU0e3sPOJ2vhsJDzF3JazJ5Dnj6A=
github.com/HACKERALERT/glfw/v3.3/glfw v0.0.0-20211216001154-d0da149b3bef/go.mod h1:aP+FSN9tk1W3UsQisFWxRLQ4WOF7T3niq68UYw0B150= github.com/HACKERALERT/glfw/v3.3/glfw v0.0.0-20220418211004-bfe86c8a6804/go.mod h1:aP+FSN9tk1W3UsQisFWxRLQ4WOF7T3niq68UYw0B150=
github.com/HACKERALERT/imgui-go v1.12.1-0.20220411211703-da7cd33ca753 h1:RfwDOJtKS2aQf4n5eGA3V8TGtmgmIwPuJThgkNa+p/o= github.com/HACKERALERT/imgui-go v1.12.1-0.20220418211401-490889e6f8b6 h1:qLaFTxyT3r+oiZNuNxlY5ep/MAGX7JpSOaoYufk+5J8=
github.com/HACKERALERT/imgui-go v1.12.1-0.20220411211703-da7cd33ca753/go.mod h1:COMjMzefnK51DW+MwUfybQ/oCGv0zpGlP8fy6zr6oOs= github.com/HACKERALERT/imgui-go v1.12.1-0.20220418211401-490889e6f8b6/go.mod h1:h8m2AFVQUhwB6Ygp98H7av+3n3X5vWsiWriGCL9SanQ=
github.com/HACKERALERT/infectious v0.0.0-20220412021528-bb1303403749 h1:uZMOuYhLopMYH1E5JC4gMqWsp3aVhxUnOgvCH6cGMqo= github.com/HACKERALERT/infectious v0.0.0-20220412021528-bb1303403749 h1:uZMOuYhLopMYH1E5JC4gMqWsp3aVhxUnOgvCH6cGMqo=
github.com/HACKERALERT/infectious v0.0.0-20220412021528-bb1303403749/go.mod h1:LInDG9bntPYtji6J+OLDZvv1OTWA5XpqXv19MBsWJrA= github.com/HACKERALERT/infectious v0.0.0-20220412021528-bb1303403749/go.mod h1:LInDG9bntPYtji6J+OLDZvv1OTWA5XpqXv19MBsWJrA=
github.com/HACKERALERT/mainthread v0.0.0-20211027212305-2ec9e701cc14 h1:DwWXverhu/dEsPM/GPykuHGh4SxW69DaGZL5t3fANG4= github.com/HACKERALERT/mainthread v0.0.0-20211027212305-2ec9e701cc14 h1:DwWXverhu/dEsPM/GPykuHGh4SxW69DaGZL5t3fANG4=