summaryrefslogtreecommitdiff
path: root/pkg/server/hook/zip.go
diff options
context:
space:
mode:
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)
+}