2020-01-29 21:23:07 +00:00
|
|
|
#lang racket
|
|
|
|
|
|
|
|
(require racket/struct)
|
|
|
|
|
2020-01-30 23:09:05 +00:00
|
|
|
(provide (struct-out peer) (struct-out subnet)
|
2020-01-29 21:23:07 +00:00
|
|
|
string->ip
|
|
|
|
ip->string
|
|
|
|
string->subnet
|
|
|
|
subnet->string
|
|
|
|
string->peer)
|
|
|
|
|
|
|
|
(struct peer [ip type]
|
2020-01-30 23:09:05 +00:00
|
|
|
#:methods gen:custom-write
|
|
|
|
[(define write-proc
|
|
|
|
(make-constructor-style-printer
|
|
|
|
(lambda (x) 'peer)
|
|
|
|
(lambda (x) (list (ip->string (peer-ip x)) (peer-type x)))))])
|
2020-01-29 21:23:07 +00:00
|
|
|
|
|
|
|
(struct subnet [ip mask]
|
2020-01-30 23:09:05 +00:00
|
|
|
#:methods gen:custom-write
|
|
|
|
[(define write-proc
|
|
|
|
(make-constructor-style-printer
|
|
|
|
(lambda (x) 'subnet)
|
|
|
|
(lambda (x) (list (subnet->string x)))))])
|
2020-01-29 21:23:07 +00:00
|
|
|
|
|
|
|
(define (string->ip str)
|
2020-01-30 23:09:05 +00:00
|
|
|
(define parts (reverse (string-split str ".")))
|
|
|
|
(for/sum ([part (in-list parts)]
|
|
|
|
[i (in-naturals)])
|
|
|
|
(arithmetic-shift (string->number part)
|
|
|
|
(* i 8))))
|
2020-01-29 21:23:07 +00:00
|
|
|
|
|
|
|
(define (ip->string ip)
|
2020-01-30 23:09:05 +00:00
|
|
|
(define parts
|
|
|
|
(reverse (for/list ([i (in-range 4)])
|
|
|
|
(number->string (bitwise-and (arithmetic-shift ip (* i -8))
|
|
|
|
255)))))
|
|
|
|
(string-join parts "."))
|
2020-01-29 21:23:07 +00:00
|
|
|
|
|
|
|
(define (string->subnet str)
|
2020-01-30 23:09:05 +00:00
|
|
|
(match-define (list ipstr maskstr) (string-split str "/"))
|
|
|
|
(subnet (string->ip ipstr)
|
|
|
|
(string->number maskstr)))
|
2020-01-29 21:23:07 +00:00
|
|
|
|
|
|
|
(define (subnet->string sub)
|
2020-01-30 23:09:05 +00:00
|
|
|
(format "~a/~a"
|
|
|
|
(subnet-ip sub)
|
|
|
|
(subnet-mask sub)))
|
2020-01-29 21:23:07 +00:00
|
|
|
|
|
|
|
(define (string->peer str)
|
2020-01-30 23:09:05 +00:00
|
|
|
(match-define (list ip type) (string-split str "-"))
|
|
|
|
(peer (string->ip ip) (string->symbol type)))
|