Browse Source

hashcat Crack Progress

Former-commit-id: d4ffb11a01
pull/39/head
zhangwei 1 year ago
parent
commit
94a9154011
4 changed files with 24 additions and 18 deletions
  1. +5
    -0
      api/desc/core/pcm-core.api
  2. +2
    -6
      api/internal/handler/core/crackprogresshandler.go
  3. +12
    -12
      api/internal/logic/core/crackprogresslogic.go
  4. +5
    -0
      api/internal/types/types.go

+ 5
- 0
api/desc/core/pcm-core.api View File

@@ -555,6 +555,11 @@ type NodeAsset {
} }


type crackProgressResp { type crackProgressResp {
crackProgressList []CrackProgress `json:"crackProgressList"`
}

type CrackProgress {
Name string `json:"name"`
Progress string `json:"progress"` Progress string `json:"progress"`
Current string `json:"current"` Current string `json:"current"`
Total string `json:"total"` Total string `json:"total"`


+ 2
- 6
api/internal/handler/core/crackprogresshandler.go View File

@@ -1,9 +1,9 @@
package core package core


import ( import (
"gitlink.org.cn/jcce-pcm/pcm-coordinator/pkg/repository/result"
"net/http" "net/http"


"github.com/zeromicro/go-zero/rest/httpx"
"gitlink.org.cn/jcce-pcm/pcm-coordinator/api/internal/logic/core" "gitlink.org.cn/jcce-pcm/pcm-coordinator/api/internal/logic/core"
"gitlink.org.cn/jcce-pcm/pcm-coordinator/api/internal/svc" "gitlink.org.cn/jcce-pcm/pcm-coordinator/api/internal/svc"
) )
@@ -12,10 +12,6 @@ func CrackProgressHandler(svcCtx *svc.ServiceContext) http.HandlerFunc {
return func(w http.ResponseWriter, r *http.Request) { return func(w http.ResponseWriter, r *http.Request) {
l := core.NewCrackProgressLogic(r.Context(), svcCtx) l := core.NewCrackProgressLogic(r.Context(), svcCtx)
resp, err := l.CrackProgress() resp, err := l.CrackProgress()
if err != nil {
httpx.ErrorCtx(r.Context(), w, err)
} else {
httpx.OkJsonCtx(r.Context(), w, resp)
}
result.HttpResult(r, w, resp, err)
} }
} }

+ 12
- 12
api/internal/logic/core/crackprogresslogic.go View File

@@ -2,7 +2,6 @@ package core


import ( import (
"context" "context"
"gitlink.org.cn/jcce-pcm/pcm-coordinator/pkg/models"
"strings" "strings"


"gitlink.org.cn/jcce-pcm/pcm-coordinator/api/internal/svc" "gitlink.org.cn/jcce-pcm/pcm-coordinator/api/internal/svc"
@@ -28,24 +27,25 @@ func NewCrackProgressLogic(ctx context.Context, svcCtx *svc.ServiceContext) *Cra
func (l *CrackProgressLogic) CrackProgress() (resp *types.CrackProgressResp, err error) { func (l *CrackProgressLogic) CrackProgress() (resp *types.CrackProgressResp, err error) {
// todo: add your logic here and delete this line // todo: add your logic here and delete this line
result := types.CrackProgressResp{} result := types.CrackProgressResp{}
var hashcatList []*models.THashcat
tx := l.svcCtx.DbEngin.Raw("SELECT h.id, h.speed, h.crack_progress \nFROM t_hashcat h \nJOIN ( \n SELECT crack_task_id, MAX(id) as max_id \n FROM t_hashcat \n GROUP BY crack_task_id \n) AS sub_query ON h.crack_task_id = sub_query.crack_task_id AND h.id = sub_query.max_id \nJOIN cloud c ON h.crack_task_id = c.`name`").Scan(&hashcatList)
var crackProgressList []*types.CrackProgress
tx := l.svcCtx.DbEngin.Raw("SELECT h.id, h.speed, h.crack_progress as progress,c.`name` \nFROM t_hashcat h \nJOIN ( \n SELECT crack_task_id, MAX(id) as max_id \n FROM t_hashcat \n GROUP BY crack_task_id \n) AS sub_query ON h.crack_task_id = sub_query.crack_task_id AND h.id = sub_query.max_id \nJOIN cloud c ON h.crack_task_id = c.`name`").Scan(&crackProgressList)
if tx.Error != nil { if tx.Error != nil {
return nil, tx.Error return nil, tx.Error
} }
for _, hashcat := range hashcatList {
if len(hashcat.Speed) != 0 {
str1 := strings.Split(hashcat.Speed, "@")
result.Speed = str1[0]
for _, crackProgress := range crackProgressList {
if len(crackProgress.Speed) != 0 {
str1 := strings.Split(crackProgress.Speed, "@")
crackProgress.Speed = str1[0]
} }
if len(hashcat.CrackProgress) != 0 {
str1 := strings.Split(hashcat.CrackProgress, "/")
result.Current = str1[0]
if len(crackProgress.Progress) != 0 {
str1 := strings.Split(crackProgress.Progress, "/")
crackProgress.Current = str1[0]
str2 := strings.Split(str1[1], " (") str2 := strings.Split(str1[1], " (")
result.Total = str2[0]
crackProgress.Total = str2[0]
str3 := strings.Split(str2[1], "%") str3 := strings.Split(str2[1], "%")
result.Progress = str3[0]
crackProgress.Progress = str3[0]
} }
result.CrackProgressList = append(result.CrackProgressList, *crackProgress)
} }


return &result, nil return &result, nil


+ 5
- 0
api/internal/types/types.go View File

@@ -518,6 +518,11 @@ type NodeAsset struct {
} }


type CrackProgressResp struct { type CrackProgressResp struct {
CrackProgressList []CrackProgress `json:"crackProgressList"`
}

type CrackProgress struct {
Name string `json:"name"`
Progress string `json:"progress"` Progress string `json:"progress"`
Current string `json:"current"` Current string `json:"current"`
Total string `json:"total"` Total string `json:"total"`


Loading…
Cancel
Save