summaryrefslogtreecommitdiff
path: root/pkg/server/hook/zip.go
diff options
context:
space:
mode:
authorMikhail Osipov <mike.osipov@gmail.com>2020-02-29 00:58:01 +0300
committerMikhail Osipov <mike.osipov@gmail.com>2020-02-29 00:58:01 +0300
commitc55afd2de177f128fae6e1c52d0c56af17096258 (patch)
tree2b06eeabf4db3a6c7ef357fb1569c4e8f72aab68 /pkg/server/hook/zip.go
parent11501b56a751d2959480aaeaf2036eff586e5629 (diff)
rename module to hook
Diffstat (limited to 'pkg/server/hook/zip.go')
-rw-r--r--pkg/server/hook/zip.go55
1 files changed, 55 insertions, 0 deletions
diff --git a/pkg/server/hook/zip.go b/pkg/server/hook/zip.go
new file mode 100644
index 0000000..61264c9
--- /dev/null
+++ b/pkg/server/hook/zip.go
@@ -0,0 +1,55 @@
+package hook
+
+import (
+ "compress/flate"
+ "io"
+ "tunnel/pkg/server/env"
+ "tunnel/pkg/server/opts"
+ "tunnel/pkg/server/queue"
+)
+
+type zipHook struct{}
+
+func (m zipHook) Send(rq, wq queue.Q) error {
+ w, err := flate.NewWriter(wq.Writer(), flate.BestCompression)
+ if err != nil {
+ return err
+ }
+
+ for b := range rq {
+ if _, err := w.Write(b); err != nil {
+ return err
+ }
+ if err := w.Flush(); err != nil {
+ return err
+ }
+ }
+
+ return w.Close()
+}
+
+func (m zipHook) Recv(rq, wq queue.Q) error {
+ r := flate.NewReader(rq.Reader())
+
+ // FIXME: not received ending due to ultimate conn.Close
+ if err := queue.IoCopy(r, wq.Writer()); err != nil {
+ if err == io.ErrUnexpectedEOF {
+ return nil
+ }
+ return err
+ }
+
+ return r.Close()
+}
+
+func (m zipHook) Open(env.Env) (interface{}, error) {
+ return m, nil
+}
+
+func newZipHook(opts.Opts, env.Env) (hook, error) {
+ return zipHook{}, nil
+}
+
+func init() {
+ register("zip", newZipHook)
+}