1
0
Fork 0
mirror of https://github.com/HACKERALERT/Picocrypt.git synced 2025-01-04 21:58:23 +00:00

Update Picocrypt.go

This commit is contained in:
Evan Su 2021-08-29 20:39:26 -04:00 committed by GitHub
parent 6e58086869
commit 9869868d94
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -62,13 +62,13 @@ import (
"github.com/AllenDang/imgui-go" "github.com/AllenDang/imgui-go"
// Reed-Solomon // Reed-Solomon
"github.com/HACKERALERT/infectious" // v0.0.0-20210818221523-92bdec168696 "github.com/HACKERALERT/infectious" // v0.0.0-20210829223857-06884e85204c
// Helpers // Helpers
"github.com/HACKERALERT/jibber_jabber" // v0.0.0-20210819210536-54a4d27b5376 "github.com/HACKERALERT/jibber_jabber" // v0.0.0-20210819210536-54a4d27b5376
"github.com/HACKERALERT/clipboard" // v0.1.5-0.20210716140604-61d96bf4fc94 "github.com/HACKERALERT/clipboard" // v0.1.5-0.20210716140604-61d96bf4fc94
"github.com/HACKERALERT/dialog" // v0.0.0-20210716143851-223edea1d840 "github.com/HACKERALERT/dialog" // v0.0.0-20210716143851-223edea1d840
"github.com/HACKERALERT/browser" // v0.0.0-20210818221535-991cc324ab76 "github.com/HACKERALERT/browser" // v0.0.0-20210829223838-6f2b13590b20
"github.com/HACKERALERT/zxcvbn-go" // v0.0.0-20210730224720-b29e9dba62c2 "github.com/HACKERALERT/zxcvbn-go" // v0.0.0-20210730224720-b29e9dba62c2
) )
@ -133,6 +133,7 @@ var outputWidth float32 = 370
var orLabel = "or" var orLabel = "or"
var passwordStrength int var passwordStrength int
var keyfile = false // True if user chooses/chose to use a keyfile var keyfile = false // True if user chooses/chose to use a keyfile
var keyfileOrderMatters bool
var showConfirmation = false // True if a confirmation to overwrite is needed var showConfirmation = false // True if a confirmation to overwrite is needed
var showProgress = false var showProgress = false
var progress float32 = 0 // 0 is 0%, 1 is 100% var progress float32 = 0 // 0 is 0%, 1 is 100%
@ -184,6 +185,7 @@ var genpassSymbols = true
// Reed-Solomon encoders // Reed-Solomon encoders
var rs1,_ = infectious.NewFEC(1,3) // 1 data shards, 3 total -> 2 parity shards var rs1,_ = infectious.NewFEC(1,3) // 1 data shards, 3 total -> 2 parity shards
var rs5,_ = infectious.NewFEC(5,15) var rs5,_ = infectious.NewFEC(5,15)
var rs6,_ = infectious.NewFEC(6,18)
var rs10,_ = infectious.NewFEC(10,30) var rs10,_ = infectious.NewFEC(10,30)
var rs16,_ = infectious.NewFEC(16,48) var rs16,_ = infectious.NewFEC(16,48)
var rs24,_ = infectious.NewFEC(24,72) var rs24,_ = infectious.NewFEC(24,72)
@ -228,11 +230,11 @@ func startUI(){
pos := giu.GetCursorPos() pos := giu.GetCursorPos()
w,_ := giu.CalcTextSize(languages[languageSelected]) w,_ := giu.CalcTextSize(languages[languageSelected])
giu.Row( giu.Row(
giu.Dummy(-w-32,0), giu.Dummy(-w/dpi-32,0),
giu.Combo("##language",languages[languageSelected],languages,&languageSelected).OnChange(func(){ giu.Combo("##language",languages[languageSelected],languages,&languageSelected).OnChange(func(){
selectedLocale = allLocales[languageSelected] selectedLocale = allLocales[languageSelected]
shredding = s(shredding) shredding = s(shredding)
}).Size(w+24), }).Size(w/dpi+24),
).Build() ).Build()
giu.SetCursorPos(pos) giu.SetCursorPos(pos)
// The tab bar, which contains different tabs for different functions // The tab bar, which contains different tabs for different functions
@ -285,25 +287,33 @@ func startUI(){
if showKeyfile{ if showKeyfile{
giu.PopupModal(s("Manage keyfile(s):")).Layout( giu.PopupModal(s("Manage keyfile(s):")).Layout(
giu.Label(s("Drop and drop your keyfile(s) here.")), giu.Label(s("Drop and drop your keyfile(s) here.")),
giu.Row( giu.Custom(func(){
giu.Label(s("You can also generate a keyfile:")), if mode!="decrypt"{
giu.Button(s("Generate")).OnClick(func(){ giu.Row(
file,_ := dialog.File().Title(s("Save keyfile as")).Save() giu.Label(s("You can also generate a keyfile:")),
giu.Button(s("Generate")).OnClick(func(){
file,_ := dialog.File().Title(s("Save keyfile as")).Save()
// Return if user canceled the file dialog // Return if user canceled the file dialog
if file==""{ if file==""{
return return
} }
fout,_ := os.Create(file) fout,_ := os.Create(file)
data := make([]byte,1048576) data := make([]byte,1048576)
rand.Read(data) rand.Read(data)
fout.Write(data) fout.Write(data)
fout.Close() fout.Close()
keyfiles = append(keyfiles,file) keyfiles = append(keyfiles,file)
}), }),
), ).Build()
giu.Checkbox(s("Require correct keyfile order"),&keyfileOrderMatters).Build()
}else if keyfileOrderMatters{
giu.Label(s("The correct order of keyfiles is required.")).Build()
}
}),
giu.Tooltip(s("If checked, you will need to drop keyfiles in the correct order.")),
giu.Custom(func(){ giu.Custom(func(){
for _,i := range keyfiles{ for _,i := range keyfiles{
giu.Row( giu.Row(
@ -926,8 +936,6 @@ func startUI(){
// Handle files dropped into Picocrypt by user // Handle files dropped into Picocrypt by user
func onDrop(names []string){ func onDrop(names []string){
_status = "Ready."
recombine = false
if tab==0{ if tab==0{
if showKeyfile{ if showKeyfile{
keyfiles = append(keyfiles,names...) keyfiles = append(keyfiles,names...)
@ -935,6 +943,9 @@ func onDrop(names []string){
return return
} }
_status = "Ready."
recombine = false
// Clear variables // Clear variables
onlyFiles = nil onlyFiles = nil
onlyFolders = nil onlyFolders = nil
@ -1059,9 +1070,9 @@ func onDrop(names []string){
metadata = s("Metadata is corrupted.") metadata = s("Metadata is corrupted.")
} }
flags := make([]byte,15) flags := make([]byte,18)
fin.Read(flags) fin.Read(flags)
flags,err = rsDecode(rs5,flags) flags,err = rsDecode(rs6,flags)
if err!=nil{ if err!=nil{
_status = "Input file is corrupt and cannot be decrypted." _status = "Input file is corrupt and cannot be decrypted."
_status_color = color.RGBA{0xff,0x00,0x00,255} _status_color = color.RGBA{0xff,0x00,0x00,255}
@ -1071,6 +1082,9 @@ func onDrop(names []string){
if flags[2]==1{ if flags[2]==1{
keyfile = true keyfile = true
} }
if flags[5]==1{
keyfileOrderMatters = true
}
fin.Close() fin.Close()
}else{ }else{
@ -1314,7 +1328,7 @@ func work(){
fout.Write(rsEncode(rs1,[]byte{i})) fout.Write(rsEncode(rs1,[]byte{i}))
} }
flags := make([]byte,5) flags := make([]byte,6)
if fast{ if fast{
flags[0] = 1 flags[0] = 1
} }
@ -1330,7 +1344,10 @@ func work(){
if total%1048576>=1048448{ if total%1048576>=1048448{
flags[4] = 1 flags[4] = 1
} }
flags = rsEncode(rs5,flags) if keyfileOrderMatters{
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
@ -1388,12 +1405,12 @@ func work(){
fin.Read(make([]byte,metadataLength*3)) fin.Read(make([]byte,metadataLength*3))
flags := make([]byte,15) flags := make([]byte,18)
fin.Read(flags) fin.Read(flags)
flags,err3 = rsDecode(rs5,flags) flags,err3 = rsDecode(rs6,flags)
fast = flags[0]==1 fast = flags[0]==1
paranoid = flags[1]==1 paranoid = flags[1]==1
keyfile = flags[2]==1 //keyfile = flags[2]==1
reedsolo = flags[3]==1 reedsolo = flags[3]==1
padded = flags[4]==1 padded = flags[4]==1
@ -1504,28 +1521,44 @@ func work(){
khash_hash = khash_sha3.Sum(nil) khash_hash = khash_sha3.Sum(nil)
}*/ }*/
if len(keyfiles)>0||keyfile{ if len(keyfiles)>0||keyfile{
var keysum []byte if keyfileOrderMatters{
for _,path := range keyfiles{ var keysum = sha3.New256()
kin,_ := os.Open(path) for _,path := range keyfiles{
kstat,_ := os.Stat(path) kin,_ := os.Open(path)
kbytes := make([]byte,kstat.Size()) kstat,_ := os.Stat(path)
kin.Read(kbytes) kbytes := make([]byte,kstat.Size())
kin.Close() kin.Read(kbytes)
ksha3 := sha3.New256() kin.Close()
ksha3.Write(kbytes) keysum.Write(kbytes)
khash := ksha3.Sum(nil) }
if keysum==nil{ khash = keysum.Sum(nil)
keysum = khash khash_sha3 := sha3.New256()
}else{ khash_sha3.Write(khash)
for i,j := range khash{ khash_hash = khash_sha3.Sum(nil)
keysum[i] ^= j }else{
var keysum []byte
for _,path := range keyfiles{
kin,_ := os.Open(path)
kstat,_ := os.Stat(path)
kbytes := make([]byte,kstat.Size())
kin.Read(kbytes)
kin.Close()
ksha3 := sha3.New256()
ksha3.Write(kbytes)
khash := ksha3.Sum(nil)
if keysum==nil{
keysum = khash
}else{
for i,j := range khash{
keysum[i] ^= j
}
} }
} }
khash = keysum
khash_sha3 := sha3.New256()
khash_sha3.Write(keysum)
khash_hash = khash_sha3.Sum(nil)
} }
khash = keysum
khash_sha3 := sha3.New256()
khash_sha3.Write(keysum)
khash_hash = khash_sha3.Sum(nil)
} }
sha3_512 := sha3.New512() sha3_512 := sha3.New512()
@ -1556,7 +1589,11 @@ func work(){
if !keyCorrect{ if !keyCorrect{
_status = "The provided password is incorrect." _status = "The provided password is incorrect."
}else{ }else{
_status = "Incorrect keyfile(s)." if keyfileOrderMatters{
_status = "Incorrect keyfile(s) and/or order."
}else{
_status = "Incorrect keyfile(s)."
}
} }
_status_color = color.RGBA{0xff,0x00,0x00,255} _status_color = color.RGBA{0xff,0x00,0x00,255}
key = nil key = nil
@ -1760,7 +1797,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(309+len(metadata)*3),0) fout.Seek(int64(312+len(metadata)*3),0)
fout.Write(rsEncode(rs64,keyHash)) fout.Write(rsEncode(rs64,keyHash))
fout.Write(rsEncode(rs32,khash_hash)) fout.Write(rsEncode(rs32,khash_hash))
fout.Write(rsEncode(rs64,mac.Sum(nil))) fout.Write(rsEncode(rs64,mac.Sum(nil)))
@ -2207,6 +2244,7 @@ func resetUI(){
cPassword = "" cPassword = ""
keyfiles = nil keyfiles = nil
keyfile = false keyfile = false
keyfileOrderMatters = false
metadata = "" metadata = ""
metadataPrompt = s("Metadata (optional):") metadataPrompt = s("Metadata (optional):")
metadataState = giu.InputTextFlagsNone metadataState = giu.InputTextFlagsNone