mirror of
https://github.com/HACKERALERT/Picocrypt.git
synced 2025-01-04 05:38:31 +00:00
Fixed keyfile bug
This commit is contained in:
parent
ea6739fb43
commit
b73de4ca3e
1 changed files with 150 additions and 46 deletions
|
@ -2,7 +2,7 @@ package main
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
||||||
Picocrypt v1.15
|
Picocrypt v1.16
|
||||||
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
|
||||||
|
@ -105,7 +105,6 @@ 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 keyfilePrompt = "Keyfile (optional):" // Changes if decrypting and keyfile was enabled
|
|
||||||
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%
|
||||||
|
@ -128,11 +127,13 @@ var shredOverlay string // Text in shredding progress bar
|
||||||
var shredding = "Ready."
|
var shredding = "Ready."
|
||||||
|
|
||||||
// User input variables
|
// User input variables
|
||||||
|
var passwordState = giu.InputTextFlagsPassword
|
||||||
var password string
|
var password string
|
||||||
var cPassword string // Confirm password text entry string variable
|
var cPassword string // Confirm password text entry string variable
|
||||||
var keyfilePath string
|
var keyfilePath string
|
||||||
var keyfileLabel = "Use a keyfile (Beta)"
|
var keyfileLabel = "Use a keyfile"
|
||||||
var metadata string
|
var metadata string
|
||||||
|
var metadataPrompt = "Metadata (optional):"
|
||||||
var shredTemp bool
|
var shredTemp bool
|
||||||
var paranoid bool
|
var paranoid bool
|
||||||
var keep bool
|
var keep bool
|
||||||
|
@ -142,6 +143,12 @@ var splitSize string
|
||||||
var fast bool
|
var fast bool
|
||||||
var kept = false // If a file was corrupted/modified, but the output was kept
|
var kept = false // If a file was corrupted/modified, but the output was kept
|
||||||
|
|
||||||
|
var showGenpass = false
|
||||||
|
var genpassUpper bool
|
||||||
|
var genpassLower bool
|
||||||
|
var genpassNums bool
|
||||||
|
var genpassSymbols bool
|
||||||
|
|
||||||
// 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)
|
||||||
|
@ -201,6 +208,40 @@ func startUI(){
|
||||||
}
|
}
|
||||||
}),
|
}),
|
||||||
|
|
||||||
|
// Password generator modal
|
||||||
|
giu.Custom(func(){
|
||||||
|
if showGenpass{
|
||||||
|
giu.PopupModal("Generate password:").Layout(
|
||||||
|
giu.Checkbox("Uppercase letters",&genpassUpper),
|
||||||
|
giu.Checkbox("Lowercase letters",&genpassLower),
|
||||||
|
giu.Checkbox("Numbers",&genpassNums),
|
||||||
|
giu.Checkbox("Symbols",&genpassSymbols),
|
||||||
|
giu.Button("Cancel").Size(100,0).OnClick(func(){
|
||||||
|
giu.CloseCurrentPopup()
|
||||||
|
showGenpass = false
|
||||||
|
}),
|
||||||
|
giu.Button("Generate").Size(100,0).OnClick(func(){
|
||||||
|
tmp := genPassword()
|
||||||
|
password = tmp
|
||||||
|
cPassword = tmp
|
||||||
|
passwordStrength = zxcvbn.PasswordStrength(password,nil).Score
|
||||||
|
giu.CloseCurrentPopup()
|
||||||
|
showGenpass = false
|
||||||
|
passwordState = giu.InputTextFlagsNone
|
||||||
|
go func(){
|
||||||
|
time.Sleep(3*time.Second)
|
||||||
|
passwordState = giu.InputTextFlagsPassword
|
||||||
|
giu.Update()
|
||||||
|
}()
|
||||||
|
|
||||||
|
giu.Update()
|
||||||
|
}),
|
||||||
|
).Build()
|
||||||
|
giu.OpenPopup("Generate password:")
|
||||||
|
giu.Update()
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
|
||||||
// Confirm overwrite with a modal
|
// Confirm overwrite with a modal
|
||||||
giu.Custom(func(){
|
giu.Custom(func(){
|
||||||
if showConfirmation{
|
if showConfirmation{
|
||||||
|
@ -214,7 +255,6 @@ func startUI(){
|
||||||
giu.Button("Yes").Size(100,0).OnClick(func(){
|
giu.Button("Yes").Size(100,0).OnClick(func(){
|
||||||
giu.CloseCurrentPopup()
|
giu.CloseCurrentPopup()
|
||||||
showConfirmation = false
|
showConfirmation = false
|
||||||
giu.Update()
|
|
||||||
showProgress = true
|
showProgress = true
|
||||||
giu.Update()
|
giu.Update()
|
||||||
go func (){
|
go func (){
|
||||||
|
@ -297,25 +337,32 @@ func startUI(){
|
||||||
// Prompt for password
|
// Prompt for password
|
||||||
giu.Row(
|
giu.Row(
|
||||||
giu.Label("Password:"),
|
giu.Label("Password:"),
|
||||||
|
giu.Custom(func(){
|
||||||
|
giu.Row(
|
||||||
giu.Custom(func(){
|
giu.Custom(func(){
|
||||||
if mode!="decrypt"{
|
if mode!="decrypt"{
|
||||||
|
giu.Row(
|
||||||
giu.SmallButton("Generate").OnClick(func(){
|
giu.SmallButton("Generate").OnClick(func(){
|
||||||
tmp := genPassword()
|
showGenpass = true
|
||||||
|
}),
|
||||||
|
giu.SmallButton("Copy").OnClick(func(){
|
||||||
|
clipboard.WriteAll(password)
|
||||||
|
}),
|
||||||
|
).Build()
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
giu.SmallButton("Paste").OnClick(func(){
|
||||||
|
tmp,_ := clipboard.ReadAll()
|
||||||
password = tmp
|
password = tmp
|
||||||
cPassword = tmp
|
cPassword = tmp
|
||||||
passwordStrength = zxcvbn.PasswordStrength(password,nil).Score
|
passwordStrength = zxcvbn.PasswordStrength(password,nil).Score
|
||||||
giu.Update()
|
giu.Update()
|
||||||
}).Build()
|
|
||||||
giu.SmallButton("Copy").OnClick(func(){
|
|
||||||
clipboard.WriteAll(password)
|
|
||||||
}).Build()
|
|
||||||
}
|
|
||||||
}),
|
}),
|
||||||
giu.Dummy(-200,0),
|
).Build()
|
||||||
giu.Label(keyfilePrompt),
|
}),
|
||||||
),
|
),
|
||||||
giu.Row(
|
giu.Row(
|
||||||
giu.InputText(&password).Size(241/dpi).Flags(giu.InputTextFlagsPassword).OnChange(func(){
|
giu.InputText(&password).Size(241/dpi).Flags(passwordState).OnChange(func(){
|
||||||
passwordStrength = zxcvbn.PasswordStrength(password,nil).Score
|
passwordStrength = zxcvbn.PasswordStrength(password,nil).Score
|
||||||
}),
|
}),
|
||||||
|
|
||||||
|
@ -351,9 +398,9 @@ func startUI(){
|
||||||
-1)
|
-1)
|
||||||
canvas.PathStroke(col,false,3)
|
canvas.PathStroke(col,false,3)
|
||||||
}),
|
}),
|
||||||
giu.Dummy(-200,0),
|
giu.Dummy(-160,0),
|
||||||
|
|
||||||
giu.Checkbox(keyfileLabel,&keyfile).OnChange(func(){
|
/*giu.Checkbox(keyfileLabel,&keyfile).OnChange(func(){
|
||||||
if !keyfile{
|
if !keyfile{
|
||||||
keyfileLabel = "Use a keyfile"
|
keyfileLabel = "Use a keyfile"
|
||||||
return
|
return
|
||||||
|
@ -365,13 +412,38 @@ func startUI(){
|
||||||
}
|
}
|
||||||
keyfileLabel = filename
|
keyfileLabel = filename
|
||||||
keyfilePath = filename
|
keyfilePath = filename
|
||||||
|
}),*/
|
||||||
|
giu.Custom(func(){
|
||||||
|
if !(mode=="decrypt"&&!keyfile){
|
||||||
|
giu.Button(keyfileLabel).OnClick(func(){
|
||||||
|
filename,err := dialog.File().Load()
|
||||||
|
if err!=nil{
|
||||||
|
return
|
||||||
|
}
|
||||||
|
keyfile = true
|
||||||
|
keyfileLabel = filepath.Base(filename)
|
||||||
|
keyfilePath = filename
|
||||||
|
}).Build()
|
||||||
|
}
|
||||||
}),
|
}),
|
||||||
|
giu.Custom(func(){
|
||||||
|
if keyfile&&mode=="encrypt"{
|
||||||
|
giu.Button("Clear").OnClick(func(){
|
||||||
|
keyfile = false
|
||||||
|
keyfileLabel = "Use a keyfile"
|
||||||
|
keyfilePath = ""
|
||||||
|
}).Build()
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
giu.Dummy(-0.0000001,0),
|
||||||
),
|
),
|
||||||
|
|
||||||
// Prompt to confirm password
|
// Prompt to confirm password
|
||||||
giu.Label("Confirm password:"),
|
giu.Custom(func(){
|
||||||
|
if mode!="decrypt"{
|
||||||
|
giu.Label("Confirm password:").Build()
|
||||||
giu.Row(
|
giu.Row(
|
||||||
giu.InputText(&cPassword).Size(241/dpi).Flags(giu.InputTextFlagsPassword),
|
giu.InputText(&cPassword).Size(241/dpi).Flags(passwordState),
|
||||||
giu.Custom(func(){
|
giu.Custom(func(){
|
||||||
canvas := giu.GetCanvas()
|
canvas := giu.GetCanvas()
|
||||||
pos := giu.GetCursorScreenPos()
|
pos := giu.GetCursorScreenPos()
|
||||||
|
@ -390,10 +462,14 @@ func startUI(){
|
||||||
canvas.PathStroke(col,false,3)
|
canvas.PathStroke(col,false,3)
|
||||||
}),
|
}),
|
||||||
giu.Dummy(-0.0000001,0),
|
giu.Dummy(-0.0000001,0),
|
||||||
),
|
).Build()
|
||||||
|
}else{
|
||||||
|
giu.Dummy(0,42).Build()
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
|
||||||
// Optional metadata
|
// Optional metadata
|
||||||
giu.Label("Metadata (optional):"),
|
giu.Label(metadataPrompt),
|
||||||
giu.InputText(&metadata).Size(-0.0000001),
|
giu.InputText(&metadata).Size(-0.0000001),
|
||||||
|
|
||||||
giu.Custom(func(){
|
giu.Custom(func(){
|
||||||
|
@ -417,7 +493,11 @@ func startUI(){
|
||||||
giu.Row(
|
giu.Row(
|
||||||
giu.Checkbox("Split output into chunks of",&split),
|
giu.Checkbox("Split output into chunks of",&split),
|
||||||
giu.InputText(&splitSize).Size(50).Flags(giu.InputTextFlagsCharsDecimal).OnChange(func(){
|
giu.InputText(&splitSize).Size(50).Flags(giu.InputTextFlagsCharsDecimal).OnChange(func(){
|
||||||
|
if splitSize==""{
|
||||||
|
split = false
|
||||||
|
}else{
|
||||||
split = true
|
split = true
|
||||||
|
}
|
||||||
}),
|
}),
|
||||||
giu.Combo("##splitter",splitUnits[splitSelected],splitUnits,&splitSelected).Size(52),
|
giu.Combo("##splitter",splitUnits[splitSelected],splitUnits,&splitSelected).Size(52),
|
||||||
).Build()
|
).Build()
|
||||||
|
@ -439,6 +519,12 @@ func startUI(){
|
||||||
_status_color = color.RGBA{0xff,0x00,0x00,255}
|
_status_color = color.RGBA{0xff,0x00,0x00,255}
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
fmt.Println(keyfile,keyfilePath)
|
||||||
|
if keyfile&&keyfilePath==""{
|
||||||
|
_status = "Please select a keyfile."
|
||||||
|
_status_color = color.RGBA{0xff,0x00,0x00,255}
|
||||||
|
return
|
||||||
|
}
|
||||||
if mode=="encrypt"{
|
if mode=="encrypt"{
|
||||||
if len(allFiles)>1||len(onlyFolders)>0{
|
if len(allFiles)>1||len(onlyFolders)>0{
|
||||||
outputFile = outputEntry+".zip.pcv"
|
outputFile = outputEntry+".zip.pcv"
|
||||||
|
@ -708,6 +794,7 @@ func onDrop(names []string){
|
||||||
if strings.HasSuffix(names[0],".pcv")||isSplit{
|
if strings.HasSuffix(names[0],".pcv")||isSplit{
|
||||||
mode = "decrypt"
|
mode = "decrypt"
|
||||||
inputLabel = name+" (will decrypt)"
|
inputLabel = name+" (will decrypt)"
|
||||||
|
metadataPrompt = "Metadata (read-only):"
|
||||||
|
|
||||||
if isSplit{
|
if isSplit{
|
||||||
inputLabel = name+" (will recombine and decrypt)"
|
inputLabel = name+" (will recombine and decrypt)"
|
||||||
|
@ -775,9 +862,9 @@ func onDrop(names []string){
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
if flags[1]==1{
|
if flags[2]==1{
|
||||||
keyfilePrompt = "Keyfile (required):"
|
keyfile = true
|
||||||
keyfileLabel = "Click here to select keyfile."
|
keyfileLabel = "Select keyfile"
|
||||||
}
|
}
|
||||||
|
|
||||||
fin.Close()
|
fin.Close()
|
||||||
|
@ -1199,6 +1286,7 @@ func work(){
|
||||||
khash_sha3.Write(khash)
|
khash_sha3.Write(khash)
|
||||||
khash_hash = khash_sha3.Sum(nil)
|
khash_hash = khash_sha3.Sum(nil)
|
||||||
}
|
}
|
||||||
|
fmt.Println(keyfile)
|
||||||
|
|
||||||
sha3_512 := sha3.New512()
|
sha3_512 := sha3.New512()
|
||||||
sha3_512.Write(key)
|
sha3_512.Write(key)
|
||||||
|
@ -1836,7 +1924,7 @@ func shred(names []string,separate bool){
|
||||||
}
|
}
|
||||||
|
|
||||||
// Clear UI state
|
// Clear UI state
|
||||||
shredding = "Ready."
|
shredding = "Completed."
|
||||||
shredProgress = 0
|
shredProgress = 0
|
||||||
shredOverlay = ""
|
shredOverlay = ""
|
||||||
}
|
}
|
||||||
|
@ -1862,10 +1950,11 @@ func resetUI(){
|
||||||
outputWidth = 370
|
outputWidth = 370
|
||||||
password = ""
|
password = ""
|
||||||
cPassword = ""
|
cPassword = ""
|
||||||
keyfilePrompt = "Keyfile (optional):"
|
|
||||||
keyfileLabel = "Use a keyfile"
|
keyfileLabel = "Use a keyfile"
|
||||||
|
keyfilePath = ""
|
||||||
keyfile = false
|
keyfile = false
|
||||||
metadata = ""
|
metadata = ""
|
||||||
|
metadataPrompt = "Metadata (optional):"
|
||||||
shredTemp = false
|
shredTemp = false
|
||||||
keep = false
|
keep = false
|
||||||
reedsolo = false
|
reedsolo = false
|
||||||
|
@ -1933,7 +2022,22 @@ func humanize(seconds int) string{
|
||||||
|
|
||||||
// Generate cryptographically secure high-entropy passwords
|
// Generate cryptographically secure high-entropy passwords
|
||||||
func genPassword() string{
|
func genPassword() string{
|
||||||
chars := "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890-=!@#$^&()_+?"
|
chars := ""
|
||||||
|
if genpassUpper{
|
||||||
|
chars += "ABCDEFGHIJKLMNOPQRSTUVWXYZ"
|
||||||
|
}
|
||||||
|
if genpassLower{
|
||||||
|
chars += "abcdefghijklmnopqrstuvwxyz"
|
||||||
|
}
|
||||||
|
if genpassNums{
|
||||||
|
chars += "1234567890"
|
||||||
|
}
|
||||||
|
if genpassSymbols{
|
||||||
|
chars += "-=!@#$^&()_+?"
|
||||||
|
}
|
||||||
|
if chars==""{
|
||||||
|
return chars
|
||||||
|
}
|
||||||
tmp := make([]byte,32)
|
tmp := make([]byte,32)
|
||||||
for i:=0;i<32;i++{
|
for i:=0;i<32;i++{
|
||||||
j,_ := rand.Int(rand.Reader,new(big.Int).SetUint64(uint64(len(chars))))
|
j,_ := rand.Int(rand.Reader,new(big.Int).SetUint64(uint64(len(chars))))
|
||||||
|
@ -1981,7 +2085,7 @@ func main(){
|
||||||
window.SetDropCallback(onDrop)
|
window.SetDropCallback(onDrop)
|
||||||
window.SetCloseCallback(func() bool{
|
window.SetCloseCallback(func() bool{
|
||||||
// Disable closing window if a Picocrypt is working to prevent temporary files
|
// Disable closing window if a Picocrypt is working to prevent temporary files
|
||||||
if working||shredding!="Ready."{
|
if working||(shredding!="Ready."&&shredding!="Completed."){
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
return true
|
return true
|
||||||
|
|
Loading…
Reference in a new issue