mirror of
https://github.com/bobbimanners/emailler.git
synced 2025-01-06 23:30:04 +00:00
Removed HTTP output post processing completely.
I don't see the use case for inserting HTTP variables as-is into the HTTP output.
This commit is contained in:
parent
7ef7414fef
commit
d282290cf0
93
ip65/httpd.s
93
ip65/httpd.s
@ -16,13 +16,11 @@ HTTPD_TIMEOUT_SECONDS = 5 ; what's the maximum time we let 1 connection be
|
|||||||
.export httpd_send_response
|
.export httpd_send_response
|
||||||
|
|
||||||
.import http_parse_request
|
.import http_parse_request
|
||||||
.import http_get_value
|
|
||||||
.import tcp_listen
|
.import tcp_listen
|
||||||
.import tcp_callback
|
.import tcp_callback
|
||||||
.import ip65_process
|
.import ip65_process
|
||||||
.import check_for_abort_key
|
.import check_for_abort_key
|
||||||
.import ip65_error
|
.import ip65_error
|
||||||
.import parse_hex_digits
|
|
||||||
.import print
|
.import print
|
||||||
.import copymem
|
.import copymem
|
||||||
.importzp copy_src
|
.importzp copy_src
|
||||||
@ -47,8 +45,6 @@ sent_header: .res 1
|
|||||||
connection_timeout_seconds: .res 1
|
connection_timeout_seconds: .res 1
|
||||||
tcp_buffer_ptr: .res 2
|
tcp_buffer_ptr: .res 2
|
||||||
buffer_size: .res 1
|
buffer_size: .res 1
|
||||||
skip_mode: .res 1
|
|
||||||
temp_x: .res 1
|
|
||||||
|
|
||||||
|
|
||||||
.data
|
.data
|
||||||
@ -58,9 +54,6 @@ httpd_port_number: .word 80
|
|||||||
jump_to_callback:
|
jump_to_callback:
|
||||||
jmp $ffff
|
jmp $ffff
|
||||||
|
|
||||||
jump_to_embedded_routine:
|
|
||||||
jmp $ffff
|
|
||||||
|
|
||||||
get_next_byte:
|
get_next_byte:
|
||||||
lda $ffff
|
lda $ffff
|
||||||
inc get_next_byte+1
|
inc get_next_byte+1
|
||||||
@ -70,14 +63,10 @@ get_next_byte:
|
|||||||
rts
|
rts
|
||||||
|
|
||||||
emit_a:
|
emit_a:
|
||||||
stx temp_x
|
|
||||||
ldx skip_mode
|
|
||||||
bne skip_emit_a
|
|
||||||
emit_a_ptr:
|
|
||||||
sta $ffff
|
sta $ffff
|
||||||
inc emit_a_ptr+1
|
inc emit_a+1
|
||||||
bne :+
|
bne :+
|
||||||
inc emit_a_ptr+2
|
inc emit_a+2
|
||||||
: inc output_buffer_length
|
: inc output_buffer_length
|
||||||
bne :+
|
bne :+
|
||||||
inc output_buffer_length+1
|
inc output_buffer_length+1
|
||||||
@ -85,10 +74,7 @@ emit_a_ptr:
|
|||||||
cmp #2
|
cmp #2
|
||||||
bne :+
|
bne :+
|
||||||
jsr send_buffer
|
jsr send_buffer
|
||||||
:
|
: rts
|
||||||
skip_emit_a:
|
|
||||||
ldx temp_x
|
|
||||||
rts
|
|
||||||
|
|
||||||
|
|
||||||
.code
|
.code
|
||||||
@ -217,12 +203,11 @@ http_callback:
|
|||||||
|
|
||||||
reset_output_buffer:
|
reset_output_buffer:
|
||||||
ldax #io_buf
|
ldax #io_buf
|
||||||
sta emit_a_ptr+1
|
sta emit_a+1
|
||||||
stx emit_a_ptr+2
|
stx emit_a+2
|
||||||
lda #0
|
lda #0
|
||||||
sta output_buffer_length
|
sta output_buffer_length
|
||||||
sta output_buffer_length+1
|
sta output_buffer_length+1
|
||||||
sta skip_mode
|
|
||||||
rts
|
rts
|
||||||
|
|
||||||
; send HTTP response
|
; send HTTP response
|
||||||
@ -243,77 +228,9 @@ httpd_send_response:
|
|||||||
@send_buffer:
|
@send_buffer:
|
||||||
jmp send_buffer
|
jmp send_buffer
|
||||||
@not_last_byte:
|
@not_last_byte:
|
||||||
cmp #'%'
|
|
||||||
beq @escape
|
|
||||||
@back_from_escape:
|
|
||||||
jsr emit_a
|
jsr emit_a
|
||||||
jmp @response_loop
|
jmp @response_loop
|
||||||
|
|
||||||
@escape:
|
|
||||||
jsr get_next_byte
|
|
||||||
cmp #0
|
|
||||||
beq @send_buffer
|
|
||||||
cmp #'%'
|
|
||||||
beq @back_from_escape
|
|
||||||
cmp #'$'
|
|
||||||
bne :+
|
|
||||||
jsr get_next_byte
|
|
||||||
jsr http_get_value
|
|
||||||
bcs @response_loop
|
|
||||||
jsr emit_string
|
|
||||||
jmp @response_loop
|
|
||||||
: cmp #'.'
|
|
||||||
bne :+
|
|
||||||
lda #0
|
|
||||||
sta skip_mode
|
|
||||||
jmp @response_loop
|
|
||||||
: cmp #'?'
|
|
||||||
bne :+
|
|
||||||
lda #0
|
|
||||||
sta skip_mode
|
|
||||||
jsr get_next_byte
|
|
||||||
jsr http_get_value
|
|
||||||
bcc @response_loop
|
|
||||||
inc skip_mode
|
|
||||||
jmp @response_loop
|
|
||||||
: cmp #'!'
|
|
||||||
bne :+
|
|
||||||
lda #0
|
|
||||||
sta skip_mode
|
|
||||||
jsr get_next_byte
|
|
||||||
jsr http_get_value
|
|
||||||
bcs @response_loop
|
|
||||||
inc skip_mode
|
|
||||||
jmp @response_loop
|
|
||||||
: cmp #';'
|
|
||||||
bne :+
|
|
||||||
jsr get_next_byte
|
|
||||||
sta jump_to_embedded_routine+1
|
|
||||||
jsr get_next_byte
|
|
||||||
sta jump_to_embedded_routine+2
|
|
||||||
jmp @call_embedded_routine
|
|
||||||
: cmp #':'
|
|
||||||
bne :+
|
|
||||||
jsr @get_next_hex_value
|
|
||||||
sta jump_to_embedded_routine+2
|
|
||||||
jsr @get_next_hex_value
|
|
||||||
sta jump_to_embedded_routine+1
|
|
||||||
@call_embedded_routine:
|
|
||||||
lda skip_mode
|
|
||||||
bne @dont_call_embedded_routine
|
|
||||||
ldax #emit_a
|
|
||||||
jsr jump_to_embedded_routine
|
|
||||||
@dont_call_embedded_routine:
|
|
||||||
jmp @response_loop
|
|
||||||
: ; if we got here, it's an invalid escape code
|
|
||||||
jmp @response_loop
|
|
||||||
|
|
||||||
@get_next_hex_value:
|
|
||||||
jsr get_next_byte
|
|
||||||
tax
|
|
||||||
jsr get_next_byte
|
|
||||||
jmp parse_hex_digits
|
|
||||||
|
|
||||||
send_buffer:
|
send_buffer:
|
||||||
ldax output_buffer_length
|
ldax output_buffer_length
|
||||||
stax tcp_send_data_len
|
stax tcp_send_data_len
|
||||||
|
@ -35,7 +35,7 @@ start:
|
|||||||
: jmp exit_to_basic
|
: jmp exit_to_basic
|
||||||
|
|
||||||
print_vars:
|
print_vars:
|
||||||
lda #'h'
|
lda #'n'
|
||||||
jsr http_get_value
|
jsr http_get_value
|
||||||
bcs :+
|
bcs :+
|
||||||
jsr print
|
jsr print
|
||||||
@ -63,9 +63,9 @@ initializing:
|
|||||||
listening:
|
listening:
|
||||||
.byte "LISTENING",13,0
|
.byte "LISTENING",13,0
|
||||||
said:
|
said:
|
||||||
.byte ":",0
|
.byte " said ",0
|
||||||
html:
|
html:
|
||||||
.byte "<h1>hello world</h1>%?mMessage recorded as '%$h:%$m'%.<form>Your Handle:<input name=h type=text length=20 value='%$h'><br>Your Message: <input type=text lengh=60 name='m'><br><input type=submit></form><br>",0
|
.byte "<h1>Hello World</h1><form>Your Name: <input name=n type=text length=20><br>Your Message: <input name=m type=text lengh=60><br><input type=submit></form>",0
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user