mirror of
https://github.com/ksherlock/host-modemworks.git
synced 2025-01-14 02:32:03 +00:00
kegs hash tool.
This commit is contained in:
parent
8e3253ad61
commit
1d9c2d3c13
587
HashKEGS.aii
Normal file
587
HashKEGS.aii
Normal file
@ -0,0 +1,587 @@
|
||||
|
||||
machine m65816
|
||||
case on
|
||||
string asis
|
||||
|
||||
longa off
|
||||
longi off
|
||||
|
||||
include 'OMM.equ'
|
||||
|
||||
macro
|
||||
&l cstr &x
|
||||
&l dc.b &x, 0
|
||||
endm
|
||||
|
||||
|
||||
macro
|
||||
native
|
||||
clc
|
||||
xce
|
||||
rep #$30
|
||||
longa on
|
||||
longi on
|
||||
endm
|
||||
|
||||
macro
|
||||
emulated
|
||||
sec
|
||||
xce
|
||||
longa off
|
||||
longi off
|
||||
endm
|
||||
|
||||
|
||||
macro
|
||||
&l bsr &x
|
||||
&l per @ok-1
|
||||
brl &x
|
||||
@ok
|
||||
mend
|
||||
|
||||
MACRO
|
||||
long &p1,&p2
|
||||
|
||||
lcla &bits
|
||||
&bits seta %00000000
|
||||
;&p1 setc &lc(&p1)
|
||||
;&p2 setc &lc(&p2)
|
||||
|
||||
if &p1='m' OR &p2='m' THEN
|
||||
&bits seta &bits+%00100000
|
||||
longa on
|
||||
ENDIF
|
||||
|
||||
if &p1='x' OR &p2='x' THEN
|
||||
&bits seta &bits+%00010000
|
||||
longi on
|
||||
ENDIF
|
||||
|
||||
IF &bits<>0 THEN
|
||||
rep #&bits
|
||||
ENDIF
|
||||
|
||||
MEND
|
||||
|
||||
|
||||
MACRO
|
||||
short &p1,&p2
|
||||
|
||||
lcla &bits
|
||||
&bits seta %00000000
|
||||
;&p1 setc &lc(&p1)
|
||||
;&p2 setc &lc(&p2)
|
||||
|
||||
if &p1='m' OR &p2='m' THEN
|
||||
&bits seta &bits+%00100000
|
||||
longa off
|
||||
ENDIF
|
||||
|
||||
if &p1='x' OR &p2='x' THEN
|
||||
&bits seta &bits+%00010000
|
||||
longi off
|
||||
ENDIF
|
||||
|
||||
IF &bits<>0 THEN
|
||||
sep #&bits
|
||||
ENDIF
|
||||
|
||||
MEND
|
||||
|
||||
|
||||
|
||||
|
||||
a1 equ $3c
|
||||
a2 equ $3e
|
||||
prmtbl equ $e0
|
||||
lowtr equ $9b
|
||||
|
||||
TXTPTR equ $b8
|
||||
CHRGET equ $00b1
|
||||
FRMNUM equ $dd67
|
||||
GETADR equ $e752
|
||||
CHKCLS equ $deb8
|
||||
CHKOPN equ $debb
|
||||
CHKCOM equ $debe
|
||||
GETBYT equ $e6f8
|
||||
SYNERR equ $dec9
|
||||
|
||||
WDM_ID equ $fe
|
||||
|
||||
|
||||
tkDATA equ $83
|
||||
tkTEXT equ $89
|
||||
tkNEW equ $bf
|
||||
tkEND equ $80
|
||||
tkVAL equ $e5
|
||||
|
||||
entry end
|
||||
entry native_parse_str1
|
||||
entry native_parse_str2
|
||||
|
||||
proc proc
|
||||
hVERS dc.w $0000
|
||||
hID dc.w 'hh'
|
||||
hSIZE dc.w end-start
|
||||
hORG dc.w start
|
||||
hAMPC dc.w amperct
|
||||
hKIND dc.w $0000
|
||||
hRSRV1 dc.w $0000
|
||||
hRSRV2 dc.w $0000
|
||||
|
||||
|
||||
start
|
||||
|
||||
cmp #MSG_AMPR ;ampersand call?
|
||||
beq do_ampr ;yes
|
||||
cmp #MSG_INFO ;get info string?
|
||||
beq do_info
|
||||
;cmp #MSG_USER
|
||||
;beq native_dispatch
|
||||
rts
|
||||
|
||||
do_info
|
||||
lda a_info
|
||||
sta a1
|
||||
lda a_info+1
|
||||
sta a1+1
|
||||
rts
|
||||
|
||||
do_ampr
|
||||
; & hash NEW numexpr
|
||||
; & hash END ',' strvar
|
||||
; & hash DATA ( numexpr, numexpr)
|
||||
; & hash TEXT (strexpr)
|
||||
; & hash '(' strexpr ')' ',' strvar
|
||||
; & hash val (strexpr, strexpr), numvar
|
||||
|
||||
;jsr break
|
||||
|
||||
; can't pei since only want 1 byte.
|
||||
lda (TXTPTR)
|
||||
pha
|
||||
jsr CHRGET
|
||||
pla
|
||||
ldx #0
|
||||
cmp #'('
|
||||
beq @ok
|
||||
inx
|
||||
inx
|
||||
cmp #tkNEW
|
||||
beq @ok
|
||||
inx
|
||||
inx
|
||||
cmp #tkDATA
|
||||
beq @ok
|
||||
inx
|
||||
inx
|
||||
cmp #tkTEXT
|
||||
beq @ok
|
||||
inx
|
||||
inx
|
||||
cmp #tkEND
|
||||
inx
|
||||
inx
|
||||
cmp #tkVAL
|
||||
beq @ok
|
||||
|
||||
jmp SYNERR
|
||||
|
||||
@ok
|
||||
jmp (hash_table,x)
|
||||
|
||||
hash_new
|
||||
jsr GETBYT
|
||||
stx type
|
||||
stx prmtbl+0
|
||||
stz prmtbl+1
|
||||
brl hash_native_init
|
||||
|
||||
|
||||
hash_data
|
||||
jsr CHKOPN
|
||||
jsr FRMNUM
|
||||
jsr GETADR
|
||||
sty prmtbl+0
|
||||
sta prmtbl+1
|
||||
jsr CHKCOM
|
||||
jsr FRMNUM
|
||||
jsr GETADR
|
||||
sty prmtbl+2
|
||||
sta prmtbl+3
|
||||
|
||||
bsr hash_native_data
|
||||
|
||||
jmp CHKCLS
|
||||
|
||||
|
||||
|
||||
hash_text
|
||||
jsr CHKOPN
|
||||
ldy #OMM_GETSTR
|
||||
ldx #OMM_ID
|
||||
jsr OMMVEC
|
||||
; lowtr[0] = length, lowtr[1,2] = ptr
|
||||
|
||||
lda lowtr+1
|
||||
sta prmtbl+0
|
||||
lda lowtr+2
|
||||
sta prmtbl+1
|
||||
|
||||
lda lowtr
|
||||
sta prmtbl+2
|
||||
stz prmtbl+3
|
||||
|
||||
bsr hash_native_data
|
||||
|
||||
jmp CHKCLS
|
||||
|
||||
|
||||
|
||||
hash_paren
|
||||
; & hash ( type, strexpr ) , strvar
|
||||
|
||||
jsr GETBYT
|
||||
stx type
|
||||
stx prmtbl+0
|
||||
stz prmtbl+1
|
||||
bsr hash_native_init
|
||||
|
||||
jsr CHKCOM
|
||||
|
||||
ldy #OMM_GETSTR
|
||||
ldx #OMM_ID
|
||||
jsr OMMVEC
|
||||
|
||||
lda lowtr+1
|
||||
sta prmtbl+0
|
||||
lda lowtr+2
|
||||
sta prmtbl+1
|
||||
|
||||
lda lowtr
|
||||
sta prmtbl+2
|
||||
stz prmtbl+3
|
||||
|
||||
bsr hash_native_data
|
||||
|
||||
jsr CHKCLS
|
||||
jsr CHKCOM
|
||||
|
||||
; drop through...
|
||||
hash_end
|
||||
|
||||
; buffer
|
||||
|
||||
lda a_buffer
|
||||
sta lowtr+1
|
||||
sta prmtbl+0
|
||||
|
||||
lda a_buffer+1
|
||||
sta lowtr+2
|
||||
sta prmtbl+1
|
||||
|
||||
; length
|
||||
lda #64
|
||||
sta prmtbl+2
|
||||
stz prmtbl+3
|
||||
|
||||
; call native to finish it...
|
||||
bsr hash_native_finish
|
||||
stz type
|
||||
lda prmtbl+2 ; length
|
||||
sta lowtr
|
||||
|
||||
ldy #OMM_PUTSTR
|
||||
ldx #OMM_ID
|
||||
jmp OMMVEC
|
||||
|
||||
hash_val
|
||||
; &hash val(str1,str2),numvar
|
||||
; validates a plaintext password against a hashed password.
|
||||
; str1 = type $ salt $ hash
|
||||
; str2 = plaintext
|
||||
; returns 1 if & hash(type, salt+plaintext)=hash
|
||||
|
||||
bsr break
|
||||
|
||||
; a1 used for return value (OMM_PUTWORD)
|
||||
stz a1
|
||||
stz a1+1
|
||||
|
||||
jsr CHKOPN
|
||||
ldy #OMM_GETSTR
|
||||
ldx #OMM_ID
|
||||
jsr OMMVEC
|
||||
|
||||
bsr native_parse_str1
|
||||
|
||||
jsr CHKCOM
|
||||
ldy #OMM_GETSTR
|
||||
ldx #OMM_ID
|
||||
jsr OMMVEC
|
||||
|
||||
lda lowtr+1
|
||||
sta prmtbl+0
|
||||
lda lowtr+2
|
||||
sta prmtbl+1
|
||||
|
||||
lda lowtr
|
||||
sta prmtbl+2
|
||||
stz prmtbl+3
|
||||
|
||||
bsr native_parse_str2
|
||||
|
||||
jsr CHKCLS
|
||||
jsr CHKCOM
|
||||
ldy #OMM_PUTWORD
|
||||
ldx #OMM_ID
|
||||
jmp OMMVEC
|
||||
|
||||
|
||||
dc.b 0
|
||||
*
|
||||
* immediate table
|
||||
*
|
||||
hash_table
|
||||
dc.w hash_paren
|
||||
dc.w hash_new
|
||||
dc.w hash_data
|
||||
dc.w hash_text
|
||||
dc.w hash_end
|
||||
dc.w hash_val
|
||||
|
||||
|
||||
a_info dc.w info
|
||||
a_buffer
|
||||
dc.w buffer
|
||||
|
||||
|
||||
dc.w 0
|
||||
|
||||
*
|
||||
* data
|
||||
*
|
||||
|
||||
msb on
|
||||
info cstr '&SYSDATE Hash (KEGS) 1.0'
|
||||
msb off
|
||||
|
||||
amperct
|
||||
cstr 'HASH'
|
||||
dc.b -1
|
||||
|
||||
type dc.w 0
|
||||
|
||||
export buffer
|
||||
buffer
|
||||
ds.b 64+2
|
||||
|
||||
|
||||
hash_native_init
|
||||
native
|
||||
ldy #0
|
||||
bra n
|
||||
|
||||
hash_native_finish
|
||||
native
|
||||
ldy #2
|
||||
bra n
|
||||
|
||||
hash_native_data
|
||||
native
|
||||
ldy #1
|
||||
;bra n
|
||||
n
|
||||
ldx #'hh'
|
||||
lda #MSG_USER
|
||||
dc.b $42, WDM_ID
|
||||
emulated
|
||||
rts
|
||||
|
||||
break
|
||||
brk $ea
|
||||
rts
|
||||
endp
|
||||
|
||||
|
||||
native_parse_str1 proc
|
||||
|
||||
longa off
|
||||
longi off
|
||||
|
||||
; input - lowtr[0] = length, lowtr[1,2] = variable ptr.
|
||||
str equ lowtr+1
|
||||
type equ prmtbl
|
||||
|
||||
ldx lowtr
|
||||
native
|
||||
short m
|
||||
ldy #0
|
||||
sty type
|
||||
tt
|
||||
@loop
|
||||
lda (str),y
|
||||
cmp #'$'
|
||||
beq @fini
|
||||
cmp #'0'
|
||||
blt @bad
|
||||
cmp #'9'+1
|
||||
bge @bad
|
||||
|
||||
; type = type + a & 0x0f
|
||||
and #$0f
|
||||
pha
|
||||
lda type
|
||||
asl a ; x 2
|
||||
sta type
|
||||
asl a ; x 4
|
||||
asl a ; x 8
|
||||
clc
|
||||
adc type
|
||||
adc 1,s
|
||||
sta type
|
||||
pla
|
||||
iny
|
||||
dex
|
||||
bne @loop
|
||||
|
||||
@bad ldx #-1 ; length
|
||||
bra exit
|
||||
|
||||
@fini
|
||||
long m
|
||||
|
||||
iny ; skip '$'
|
||||
dex
|
||||
beq @bad
|
||||
phy
|
||||
phx ; save
|
||||
|
||||
; hash init
|
||||
;lda type
|
||||
;sta prmtbl
|
||||
lda #MSG_USER
|
||||
ldy #0
|
||||
ldx #'hh'
|
||||
dc.b $42, WDM_ID
|
||||
;
|
||||
; now reset the string pointer.
|
||||
plx ; remaining
|
||||
pla ; processed
|
||||
clc
|
||||
adc str
|
||||
sta str
|
||||
sta prmtbl
|
||||
ldy #0
|
||||
short m
|
||||
salt
|
||||
@loop
|
||||
lda (str),y
|
||||
cmp #'$'
|
||||
beq @fini
|
||||
iny
|
||||
dex
|
||||
bne @loop
|
||||
@bad
|
||||
; terminate the hash session
|
||||
long m
|
||||
stz prmtbl ; type = 0 closes it.
|
||||
lda #MSG_USER
|
||||
ldy #0
|
||||
ldx #'hh'
|
||||
dc.b $42, WDM_ID
|
||||
ldx #-1
|
||||
bra exit
|
||||
|
||||
@fini
|
||||
long m
|
||||
|
||||
sty prmtbl+2 ; count
|
||||
iny
|
||||
dex
|
||||
beq @bad
|
||||
|
||||
phx
|
||||
phy
|
||||
|
||||
; hash append the salt.
|
||||
lda #MSG_USER
|
||||
ldy #1
|
||||
ldx #'hh'
|
||||
dc.b $42, WDM_ID
|
||||
|
||||
; copy the hash...
|
||||
plx ; remaining
|
||||
pla ; offset
|
||||
clc
|
||||
adc str
|
||||
sta prmtbl+4
|
||||
|
||||
|
||||
exit
|
||||
stx a2 ; length / -1 on failure.
|
||||
emulated
|
||||
rts
|
||||
|
||||
endp
|
||||
|
||||
native_parse_str2 proc
|
||||
longa off
|
||||
longi off
|
||||
|
||||
str equ lowtr+1
|
||||
|
||||
ldx lowtr ; length
|
||||
native
|
||||
|
||||
bit a2 ; hash length
|
||||
bmi exit
|
||||
|
||||
lda #str
|
||||
sta prmtbl
|
||||
stx prmtbl+2
|
||||
; hash it
|
||||
lda #MSG_USER
|
||||
ldy #1
|
||||
ldx #'hh'
|
||||
dc.b $42, WDM_ID
|
||||
|
||||
; and finish it
|
||||
|
||||
per buffer
|
||||
pla
|
||||
sta prmtbl
|
||||
lda #64
|
||||
sta prmtbl+2
|
||||
|
||||
lda #MSG_USER
|
||||
ldy #2
|
||||
ldx #'hh'
|
||||
dc.b $42, WDM_ID
|
||||
|
||||
lda prmtbl+2 ; actual size
|
||||
bne exit
|
||||
cmp a2
|
||||
bne exit
|
||||
|
||||
lsr a ; / 2
|
||||
tay
|
||||
dey
|
||||
@loop
|
||||
lda (prmtbl),y
|
||||
cmp (prmtbl+4),y
|
||||
bne exit
|
||||
dey
|
||||
bpl @loop
|
||||
lda #1
|
||||
sta a1
|
||||
|
||||
exit
|
||||
emulated
|
||||
rts
|
||||
|
||||
endp
|
||||
|
||||
end proc
|
||||
endp
|
||||
end
|
Loading…
x
Reference in New Issue
Block a user