mirror of
https://github.com/HACKERALERT/Picocrypt.git
synced 2025-01-04 05:38:31 +00:00
Finalize v1.22
This commit is contained in:
parent
8f183b6f95
commit
82c21b2986
1 changed files with 41 additions and 60 deletions
|
@ -2,7 +2,7 @@ package main
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
||||||
Picocrypt v1.21
|
Picocrypt v1.22
|
||||||
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
|
||||||
|
@ -45,7 +45,7 @@ import (
|
||||||
"crypto/sha256"
|
"crypto/sha256"
|
||||||
"crypto/subtle"
|
"crypto/subtle"
|
||||||
|
|
||||||
"github.com/HACKERALERT/serpent"
|
"github.com/HACKERALERT/serpent" //v0.0.0-20210716182301-293b29869c66
|
||||||
"golang.org/x/crypto/argon2"
|
"golang.org/x/crypto/argon2"
|
||||||
"golang.org/x/crypto/blake2b"
|
"golang.org/x/crypto/blake2b"
|
||||||
"golang.org/x/crypto/blake2s"
|
"golang.org/x/crypto/blake2s"
|
||||||
|
@ -54,16 +54,16 @@ import (
|
||||||
"golang.org/x/crypto/sha3"
|
"golang.org/x/crypto/sha3"
|
||||||
|
|
||||||
// UI
|
// UI
|
||||||
"github.com/HACKERALERT/giu"
|
"github.com/HACKERALERT/giu" //v0.5.7-0.20211216020632-65de69857557
|
||||||
|
|
||||||
// Reed-Solomon
|
// Reed-Solomon
|
||||||
"github.com/HACKERALERT/infectious"
|
"github.com/HACKERALERT/infectious" //v0.0.0-20211215232025-9d20874ad4b1
|
||||||
|
|
||||||
// Helpers
|
// Helpers
|
||||||
"github.com/HACKERALERT/clipboard"
|
"github.com/HACKERALERT/clipboard" //v0.1.5-0.20211215214929-7345ba96aeca
|
||||||
"github.com/HACKERALERT/dialog"
|
"github.com/HACKERALERT/dialog" //v0.0.0-20211215220206-17f428aa513e
|
||||||
"github.com/HACKERALERT/jibber_jabber"
|
"github.com/HACKERALERT/jibber_jabber" //v0.0.0-20211215234401-c23e432f628b
|
||||||
"github.com/HACKERALERT/zxcvbn-go"
|
"github.com/HACKERALERT/zxcvbn-go" //v0.0.0-20210927200100-f131a4666ad5
|
||||||
)
|
)
|
||||||
|
|
||||||
//go:embed icon.png
|
//go:embed icon.png
|
||||||
|
@ -92,7 +92,7 @@ var languages = []string{
|
||||||
var languageSelected int32
|
var languageSelected int32
|
||||||
|
|
||||||
// Generic variables
|
// Generic variables
|
||||||
var version = "v1.21"
|
var version = "v1.22"
|
||||||
var window *giu.MasterWindow
|
var window *giu.MasterWindow
|
||||||
var windowOptimized bool
|
var windowOptimized bool
|
||||||
var dpi float32
|
var dpi float32
|
||||||
|
@ -139,7 +139,6 @@ var metadataPrompt = "Metadata:"
|
||||||
var metadataDisabled bool
|
var metadataDisabled bool
|
||||||
|
|
||||||
// Advanced options
|
// Advanced options
|
||||||
var fast bool
|
|
||||||
var paranoid bool
|
var paranoid bool
|
||||||
var reedsolo bool
|
var reedsolo bool
|
||||||
var deleteWhenDone bool
|
var deleteWhenDone bool
|
||||||
|
@ -174,7 +173,6 @@ var showConfirmation bool
|
||||||
// Reed-Solomon encoders
|
// Reed-Solomon encoders
|
||||||
var rs1, _ = infectious.NewFEC(1, 3) // 1 data shard, 3 total -> 2 parity shards
|
var rs1, _ = infectious.NewFEC(1, 3) // 1 data shard, 3 total -> 2 parity shards
|
||||||
var rs5, _ = infectious.NewFEC(5, 15)
|
var rs5, _ = infectious.NewFEC(5, 15)
|
||||||
var rs6, _ = infectious.NewFEC(6, 18)
|
|
||||||
var rs16, _ = infectious.NewFEC(16, 48)
|
var rs16, _ = infectious.NewFEC(16, 48)
|
||||||
var rs24, _ = infectious.NewFEC(24, 72)
|
var rs24, _ = infectious.NewFEC(24, 72)
|
||||||
var rs32, _ = infectious.NewFEC(32, 96)
|
var rs32, _ = infectious.NewFEC(32, 96)
|
||||||
|
@ -182,6 +180,7 @@ var rs64, _ = infectious.NewFEC(64, 192)
|
||||||
var rs128, _ = infectious.NewFEC(128, 136)
|
var rs128, _ = infectious.NewFEC(128, 136)
|
||||||
|
|
||||||
// File checksum generator variables
|
// File checksum generator variables
|
||||||
|
var csProgress float32
|
||||||
var csMd5 string
|
var csMd5 string
|
||||||
var csSha1 string
|
var csSha1 string
|
||||||
var csSha256 string
|
var csSha256 string
|
||||||
|
@ -195,7 +194,6 @@ var sha256Color = color.RGBA{0x00, 0x00, 0x00, 0x00}
|
||||||
var sha3Color = color.RGBA{0x00, 0x00, 0x00, 0x00}
|
var sha3Color = color.RGBA{0x00, 0x00, 0x00, 0x00}
|
||||||
var blake2bColor = color.RGBA{0x00, 0x00, 0x00, 0x00}
|
var blake2bColor = color.RGBA{0x00, 0x00, 0x00, 0x00}
|
||||||
var blake2sColor = color.RGBA{0x00, 0x00, 0x00, 0x00}
|
var blake2sColor = color.RGBA{0x00, 0x00, 0x00, 0x00}
|
||||||
var csProgress float32 = 0
|
|
||||||
var md5Selected = true
|
var md5Selected = true
|
||||||
var sha1Selected = true
|
var sha1Selected = true
|
||||||
var sha256Selected = true
|
var sha256Selected = true
|
||||||
|
@ -542,21 +540,19 @@ func draw() {
|
||||||
giu.Label(s("Advanced:")),
|
giu.Label(s("Advanced:")),
|
||||||
giu.Custom(func() {
|
giu.Custom(func() {
|
||||||
if mode != "decrypt" {
|
if mode != "decrypt" {
|
||||||
giu.Row(
|
|
||||||
giu.Checkbox(s("Use fast mode"), &fast),
|
|
||||||
giu.Dummy(-221, 0),
|
|
||||||
giu.Checkbox(s("Encode with Reed-Solomon"), &reedsolo),
|
|
||||||
).Build()
|
|
||||||
giu.Row(
|
giu.Row(
|
||||||
giu.Checkbox(s("Use paranoid mode"), ¶noid),
|
giu.Checkbox(s("Use paranoid mode"), ¶noid),
|
||||||
giu.Dummy(-221, 0),
|
giu.Dummy(-221, 0),
|
||||||
giu.Checkbox(s("Delete files when complete"), &deleteWhenDone),
|
giu.Checkbox(s("Encode with Reed-Solomon"), &reedsolo),
|
||||||
).Build()
|
).Build()
|
||||||
giu.Row(
|
giu.Row(
|
||||||
giu.Style().SetDisabled(!(len(allFiles) > 1 || len(onlyFolders) > 0)).To(
|
giu.Style().SetDisabled(!(len(allFiles) > 1 || len(onlyFolders) > 0)).To(
|
||||||
giu.Checkbox(s("Compress files"), &compress),
|
giu.Checkbox(s("Compress files"), &compress),
|
||||||
),
|
),
|
||||||
giu.Dummy(-221, 0),
|
giu.Dummy(-221, 0),
|
||||||
|
giu.Checkbox(s("Delete files when complete"), &deleteWhenDone),
|
||||||
|
).Build()
|
||||||
|
giu.Row(
|
||||||
giu.Checkbox(s("Split every"), &split),
|
giu.Checkbox(s("Split every"), &split),
|
||||||
giu.InputText(&splitSize).Size(55/dpi).Flags(giu.InputTextFlagsCharsHexadecimal).OnChange(func() {
|
giu.InputText(&splitSize).Size(55/dpi).Flags(giu.InputTextFlagsCharsHexadecimal).OnChange(func() {
|
||||||
split = splitSize != ""
|
split = splitSize != ""
|
||||||
|
@ -865,19 +861,18 @@ func draw() {
|
||||||
giu.Label(fmt.Sprintf(s("Picocrypt %s, created by Evan Su (https://evansu.cc/)."), version)),
|
giu.Label(fmt.Sprintf(s("Picocrypt %s, created by Evan Su (https://evansu.cc/)."), version)),
|
||||||
giu.Label(s("Released under a GNU GPL v3 License.")),
|
giu.Label(s("Released under a GNU GPL v3 License.")),
|
||||||
giu.Label(s("A warm thank you to all the people listed below.")),
|
giu.Label(s("A warm thank you to all the people listed below.")),
|
||||||
giu.Label(s("Patrons:")),
|
giu.Label(s("Donors:")),
|
||||||
giu.Label(" - Frederick Doe"),
|
|
||||||
giu.Label(s("Donators:")),
|
|
||||||
giu.Label(" - jp26"),
|
giu.Label(" - jp26"),
|
||||||
|
giu.Label(" - Tybbs"),
|
||||||
giu.Label(" - W.Graham"),
|
giu.Label(" - W.Graham"),
|
||||||
giu.Label(" - N. Chin"),
|
giu.Label(" - N. Chin"),
|
||||||
giu.Label(" - Manjot"),
|
giu.Label(" - Manjot"),
|
||||||
giu.Label(" - Phil P."),
|
giu.Label(" - Phil P."),
|
||||||
giu.Label(" - E. Zahard"),
|
giu.Label(" - E. Zahard"),
|
||||||
giu.Label(s("Translators:")),
|
giu.Label(s("Translators:")),
|
||||||
giu.Label("umitseyhan75, digitalblossom, zeeaall, francirc, kurpau"),
|
giu.Label("umitseyhan75, digitalblossom, zeeaall, kurpau, francirc, yn, Etim-Orb").Wrapped(true),
|
||||||
giu.Label(s("Other:")),
|
giu.Label(s("Others:")),
|
||||||
giu.Label("Fuderal, u/greenreddits, u/Tall_Escape, u/NSABackdoors"),
|
giu.Label("Fuderal, u/greenreddits, u/Tall_Escape, u/NSABackdoors, @samuel-lucas6").Wrapped(true),
|
||||||
),
|
),
|
||||||
).Build()
|
).Build()
|
||||||
}),
|
}),
|
||||||
|
@ -1047,23 +1042,23 @@ func onDrop(names []string) {
|
||||||
metadata = s("Metadata is corrupted.")
|
metadata = s("Metadata is corrupted.")
|
||||||
}
|
}
|
||||||
|
|
||||||
flags := make([]byte, 18)
|
flags := make([]byte, 15)
|
||||||
fin.Read(flags)
|
fin.Read(flags)
|
||||||
fin.Close()
|
fin.Close()
|
||||||
flags, err = rsDecode(rs6, flags)
|
flags, err = rsDecode(rs5, flags)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
mainStatus = "Input file is corrupt and cannot be decrypted."
|
mainStatus = "Input file is corrupt and cannot be decrypted."
|
||||||
mainStatusColor = color.RGBA{0xff, 0x00, 0x00, 0xff}
|
mainStatusColor = color.RGBA{0xff, 0x00, 0x00, 0xff}
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
if flags[2] == 1 {
|
if flags[1] == 1 {
|
||||||
keyfile = true
|
keyfile = true
|
||||||
keyfilePrompt = s("Keyfiles required.")
|
keyfilePrompt = s("Keyfiles required.")
|
||||||
} else {
|
} else {
|
||||||
keyfilePrompt = s("Not applicable.")
|
keyfilePrompt = s("Not applicable.")
|
||||||
}
|
}
|
||||||
if flags[5] == 1 {
|
if flags[2] == 1 {
|
||||||
keyfileOrderMatters = true
|
keyfileOrderMatters = true
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -1245,7 +1240,7 @@ func work() {
|
||||||
stat, _ := os.Stat(inputFile)
|
stat, _ := os.Stat(inputFile)
|
||||||
total := stat.Size()
|
total := stat.Size()
|
||||||
if mode == "decrypt" {
|
if mode == "decrypt" {
|
||||||
total -= 789
|
total -= 786
|
||||||
}
|
}
|
||||||
|
|
||||||
// XChaCha20's max message size is 256 GiB
|
// XChaCha20's max message size is 256 GiB
|
||||||
|
@ -1299,14 +1294,14 @@ func work() {
|
||||||
fout.Write(rsEncode(rs1, []byte{i}))
|
fout.Write(rsEncode(rs1, []byte{i}))
|
||||||
}
|
}
|
||||||
|
|
||||||
flags := make([]byte, 6)
|
flags := make([]byte, 5)
|
||||||
if fast {
|
if paranoid {
|
||||||
flags[0] = 1
|
flags[0] = 1
|
||||||
}
|
}
|
||||||
if paranoid {
|
if len(keyfiles) > 0 {
|
||||||
flags[1] = 1
|
flags[1] = 1
|
||||||
}
|
}
|
||||||
if len(keyfiles) > 0 {
|
if keyfileOrderMatters {
|
||||||
flags[2] = 1
|
flags[2] = 1
|
||||||
}
|
}
|
||||||
if reedsolo {
|
if reedsolo {
|
||||||
|
@ -1315,10 +1310,7 @@ func work() {
|
||||||
if total%1048576 >= 1048448 {
|
if total%1048576 >= 1048448 {
|
||||||
flags[4] = 1
|
flags[4] = 1
|
||||||
}
|
}
|
||||||
if keyfileOrderMatters {
|
flags = rsEncode(rs5, flags)
|
||||||
flags[5] = 1
|
|
||||||
}
|
|
||||||
flags = rsEncode(rs6, flags)
|
|
||||||
fout.Write(flags)
|
fout.Write(flags)
|
||||||
|
|
||||||
// Fill salts and nonce with Go's CSPRNG
|
// Fill salts and nonce with Go's CSPRNG
|
||||||
|
@ -1377,11 +1369,10 @@ func work() {
|
||||||
|
|
||||||
fin.Read(make([]byte, metadataLength*3))
|
fin.Read(make([]byte, metadataLength*3))
|
||||||
|
|
||||||
flags := make([]byte, 18)
|
flags := make([]byte, 15)
|
||||||
fin.Read(flags)
|
fin.Read(flags)
|
||||||
flags, err3 = rsDecode(rs6, flags)
|
flags, err3 = rsDecode(rs5, flags)
|
||||||
fast = flags[0] == 1
|
paranoid = flags[0] == 1
|
||||||
paranoid = flags[1] == 1
|
|
||||||
reedsolo = flags[3] == 1
|
reedsolo = flags[3] == 1
|
||||||
padded = flags[4] == 1
|
padded = flags[4] == 1
|
||||||
|
|
||||||
|
@ -1434,16 +1425,7 @@ func work() {
|
||||||
|
|
||||||
// Derive encryption/decryption keys and subkeys
|
// Derive encryption/decryption keys and subkeys
|
||||||
var key []byte
|
var key []byte
|
||||||
if fast {
|
if paranoid {
|
||||||
key = argon2.IDKey(
|
|
||||||
[]byte(password),
|
|
||||||
salt,
|
|
||||||
4,
|
|
||||||
131072,
|
|
||||||
4,
|
|
||||||
32,
|
|
||||||
)
|
|
||||||
} else if paranoid {
|
|
||||||
key = argon2.IDKey(
|
key = argon2.IDKey(
|
||||||
[]byte(password),
|
[]byte(password),
|
||||||
salt,
|
salt,
|
||||||
|
@ -1527,9 +1509,9 @@ func work() {
|
||||||
keyfileCorrect := true
|
keyfileCorrect := true
|
||||||
var tmp bool
|
var tmp bool
|
||||||
|
|
||||||
keyCorrect = !(subtle.ConstantTimeCompare(keyHash, _keyHash) == 0)
|
keyCorrect = subtle.ConstantTimeCompare(keyHash, _keyHash) != 0
|
||||||
if keyfile {
|
if keyfile {
|
||||||
keyfileCorrect = !(subtle.ConstantTimeCompare(keyfileHash, _keyfileHash) == 0)
|
keyfileCorrect = subtle.ConstantTimeCompare(keyfileHash, _keyfileHash) != 0
|
||||||
tmp = !keyCorrect || !keyfileCorrect
|
tmp = !keyCorrect || !keyfileCorrect
|
||||||
} else {
|
} else {
|
||||||
tmp = !keyCorrect
|
tmp = !keyCorrect
|
||||||
|
@ -1586,12 +1568,12 @@ func work() {
|
||||||
subkey := make([]byte, 32)
|
subkey := make([]byte, 32)
|
||||||
hkdf := hkdf.New(sha3.New256, key, hkdfSalt, nil)
|
hkdf := hkdf.New(sha3.New256, key, hkdfSalt, nil)
|
||||||
hkdf.Read(subkey)
|
hkdf.Read(subkey)
|
||||||
if fast {
|
if paranoid {
|
||||||
// Keyed BLAKE2b
|
|
||||||
mac, _ = blake2b.New512(subkey)
|
|
||||||
} else {
|
|
||||||
// HMAC-SHA3
|
// HMAC-SHA3
|
||||||
mac = hmac.New(sha3.New512, subkey)
|
mac = hmac.New(sha3.New512, subkey)
|
||||||
|
} else {
|
||||||
|
// Keyed BLAKE2b
|
||||||
|
mac, _ = blake2b.New512(subkey)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Generate another subkey and cipher (not used unless paranoid mode is checked)
|
// Generate another subkey and cipher (not used unless paranoid mode is checked)
|
||||||
|
@ -1757,7 +1739,7 @@ func work() {
|
||||||
|
|
||||||
if mode == "encrypt" {
|
if mode == "encrypt" {
|
||||||
// Seek back to header and write important data
|
// Seek back to header and write important data
|
||||||
fout.Seek(int64(312+len(metadata)*3), 0)
|
fout.Seek(int64(309+len(metadata)*3), 0)
|
||||||
fout.Write(rsEncode(rs64, keyHash))
|
fout.Write(rsEncode(rs64, keyHash))
|
||||||
fout.Write(rsEncode(rs32, keyfileHash))
|
fout.Write(rsEncode(rs32, keyfileHash))
|
||||||
fout.Write(rsEncode(rs64, mac.Sum(nil)))
|
fout.Write(rsEncode(rs64, mac.Sum(nil)))
|
||||||
|
@ -2032,7 +2014,6 @@ func resetUI() {
|
||||||
split = false
|
split = false
|
||||||
splitSize = ""
|
splitSize = ""
|
||||||
splitSelected = 1
|
splitSelected = 1
|
||||||
fast = false
|
|
||||||
deleteWhenDone = false
|
deleteWhenDone = false
|
||||||
paranoid = false
|
paranoid = false
|
||||||
compress = false
|
compress = false
|
||||||
|
|
Loading…
Reference in a new issue