From b31df12a3d8f7e04ab168126197f5fc925fc9c69 Mon Sep 17 00:00:00 2001 From: Chakib Benziane Date: Sat, 23 Mar 2019 19:29:48 +0100 Subject: [PATCH] use docker, adding redis --- Dockerfile | 11 ---------- api.go | 2 +- bit4sat.sqbpro | 2 +- db/db.go | 16 ++++++++++---- docker-compose.yml | 31 +++++++++++++++++--------- go.mod | 11 +--------- go.sum | 48 ++++++----------------------------------- main.go | 4 ++-- storage/storage.go | 2 +- storage/upload_ctrl.go | 9 ++++---- storage/upload_model.go | 18 +++++++++------- web/src/worker.js | 2 +- 12 files changed, 62 insertions(+), 94 deletions(-) delete mode 100644 Dockerfile diff --git a/Dockerfile b/Dockerfile deleted file mode 100644 index d38d273..0000000 --- a/Dockerfile +++ /dev/null @@ -1,11 +0,0 @@ -FROM golang:alpine - -RUN mkdir -p /src -WORKDIR /src - -ENV GO111MODULE=on - -COPY . . -RUN go build - -CMD ["bit4sat"] diff --git a/api.go b/api.go index 4f4e481..38c59cb 100644 --- a/api.go +++ b/api.go @@ -1,7 +1,7 @@ package main import ( - "git.sp4ke.com/sp4ke/bit4sat-server.git/storage" + "git.sp4ke.com/sp4ke/bit4sat/storage" "github.com/gin-contrib/cors" "github.com/gin-gonic/gin" ) diff --git a/bit4sat.sqbpro b/bit4sat.sqbpro index af12da3..9930014 100644 --- a/bit4sat.sqbpro +++ b/bit4sat.sqbpro @@ -1 +1 @@ -
SELECT EXISTS (SELECT upload_id FROM upload WHERE upload_id = '1Ijbco3pYIrl2VzTslERxszEHG1');SELECT * FROM upload JOIN upload_status ON upload.status = upload_status.type;
+
SELECT EXISTS (SELECT upload_id FROM upload WHERE upload_id = '1Ijbco3pYIrl2VzTslERxszEHG1');SELECT * FROM upload JOIN upload_status ON upload.status = upload_status.type;
diff --git a/db/db.go b/db/db.go index ac23664..fd94dc4 100644 --- a/db/db.go +++ b/db/db.go @@ -7,9 +7,10 @@ import ( "os" "path/filepath" - "git.sp4ke.com/sp4ke/bit4sat-server.git/utils" + "git.sp4ke.com/sp4ke/bit4sat/utils" "github.com/jmoiron/sqlx" _ "github.com/mattn/go-sqlite3" + "github.com/mediocregopher/radix/v3" ) const ( @@ -28,7 +29,8 @@ var ( ) type Database struct { - Handle *sqlx.DB + Sql *sqlx.DB + Redis *radix.Pool } func (d *Database) Open() error { @@ -57,13 +59,13 @@ func (d *Database) Open() error { log.Printf("Opening sqlite db %s\n", dsn) - d.Handle, err = sqlx.Open("sqlite3", dsn) + d.Sql, err = sqlx.Open("sqlite3", dsn) if err != nil { log.Fatal(err) } // Execute Pragmas - d.Handle.MustExec(DBPragma) + d.Sql.MustExec(DBPragma) return nil } @@ -83,4 +85,10 @@ func RollbackTx(tx *sqlx.Tx, callback func()) { func init() { DB = &Database{} DB.Open() + + var err error + DB.Redis, err = radix.NewPool("tcp", "redis:6379", 10) + if err != nil { + log.Fatal(err) + } } diff --git a/docker-compose.yml b/docker-compose.yml index e3d20a8..32320d9 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -2,27 +2,38 @@ version: "3.4" volumes: redis: - name: bit4sat-data + file-storage: + sqlite: + gocache: services: bit4sat: image: sp4ke/bit4sat - build: - context: . - - + build: ./docker environment: - GO111MODULE=on + - BIT4SAT_DB_PATH=/sqlite + - GOPATH=/go - deploy: - replicas: 1 + #deploy: + #replicas: 1 + # + ports: + - "8880:8880" volumes: - $PWD:/src + - gocache:/go + - ./db-storage:/sqlite working_dir: /src - command: - - go - - "run *.go" + redis: + image: redis:alpine + volumes: + - redis:/data + + command: + - redis-server + - --appendonly yes diff --git a/go.mod b/go.mod index 1403f3d..2ddede6 100644 --- a/go.mod +++ b/go.mod @@ -4,18 +4,9 @@ go 1.12 require ( github.com/gin-contrib/cors v0.0.0-20190301062745-f9e10995c85a - github.com/gin-contrib/sse v0.0.0-20190301062529-5545eab6dad3 // indirect github.com/gin-gonic/gin v1.3.0 - github.com/golang/protobuf v1.3.1 // indirect github.com/jmoiron/sqlx v1.2.0 - github.com/kr/pretty v0.1.0 // indirect - github.com/mattn/go-isatty v0.0.7 // indirect github.com/mattn/go-sqlite3 v1.10.0 + github.com/mediocregopher/radix/v3 v3.2.3 github.com/segmentio/ksuid v1.0.2 - github.com/stretchr/testify v1.3.0 // indirect - github.com/ugorji/go/codec v0.0.0-20190315113641-a70535d8491c // indirect - golang.org/x/net v0.0.0-20190320064053-1272bf9dcd53 // indirect - golang.org/x/sys v0.0.0-20190321052220-f7bb7a8bee54 // indirect - google.golang.org/appengine v1.5.0 // indirect - gopkg.in/check.v1 v1.0.0-20180628173108-788fd7840127 // indirect ) diff --git a/go.sum b/go.sum index 743531b..b45ec52 100644 --- a/go.sum +++ b/go.sum @@ -1,71 +1,37 @@ -github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= -github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c= github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= github.com/gin-contrib/cors v0.0.0-20190301062745-f9e10995c85a h1:zBycVvXa03SIX+jdMv8wGu9TMDMWdN8EhaR1FoeKHNo= github.com/gin-contrib/cors v0.0.0-20190301062745-f9e10995c85a/go.mod h1:pL2kNE+DgDU+eQ+dary5bX0Z6LPP8nR6Mqs1iejILw4= +github.com/gin-contrib/sse v0.0.0-20170109093832-22d885f9ecc7 h1:AzN37oI0cOS+cougNAV9szl6CVoj2RYwzS3DpUQNtlY= github.com/gin-contrib/sse v0.0.0-20170109093832-22d885f9ecc7/go.mod h1:VJ0WA2NBN22VlZ2dKZQPAPnyWw5XTlK1KymzLKsr59s= -github.com/gin-contrib/sse v0.0.0-20190301062529-5545eab6dad3 h1:t8FVkw33L+wilf2QiWkw0UV77qRpcH/JHPKGpKa2E8g= -github.com/gin-contrib/sse v0.0.0-20190301062529-5545eab6dad3/go.mod h1:VJ0WA2NBN22VlZ2dKZQPAPnyWw5XTlK1KymzLKsr59s= github.com/gin-gonic/gin v1.3.0 h1:kCmZyPklC0gVdL728E6Aj20uYBJV93nj/TkwBTKhFbs= github.com/gin-gonic/gin v1.3.0/go.mod h1:7cKuhb5qV2ggCFctp2fJQ+ErvciLZrIeoOSOm6mUr7Y= -github.com/go-sql-driver/mysql v1.4.0 h1:7LxgVwFb2hIQtMm87NdgAVfXjnt4OePseqT1tKx+opk= github.com/go-sql-driver/mysql v1.4.0/go.mod h1:zAC/RDZ24gD3HViQzih4MyKcchzm+sOG5ZlKdlhCg5w= +github.com/golang/protobuf v1.2.0 h1:P3YflyNX/ehuJFLhxviNdFxQPkGK5cDcApsge1SqnvM= github.com/golang/protobuf v1.2.0/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U= -github.com/golang/protobuf v1.3.1 h1:YF8+flBXS5eO826T4nzqPrxfhQThhXl0YzfuUPu4SBg= -github.com/golang/protobuf v1.3.1/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U= github.com/jmoiron/sqlx v1.2.0 h1:41Ip0zITnmWNR/vHV+S4m+VoUivnWY5E4OJfLZjCJMA= github.com/jmoiron/sqlx v1.2.0/go.mod h1:1FEQNm3xlJgrMD+FBdI9+xvCksHtbpVBBw5dYhBSsks= -github.com/json-iterator/go v1.1.5 h1:gL2yXlmiIo4+t+y32d4WGwOjKGYcGOuyrg46vadswDE= github.com/json-iterator/go v1.1.5/go.mod h1:+SdeFBvtyEkXs7REEP0seUULqWtbJapLOCVDaaPEHmU= -github.com/kr/pretty v0.1.0 h1:L/CwN0zerZDmRFUapSPitk6f+Q3+0za1rQkzVuMiMFI= -github.com/kr/pretty v0.1.0/go.mod h1:dAy3ld7l9f0ibDNOQOHHMYYIIbhfbHSm3C4ZsoJORNo= -github.com/kr/pty v1.1.1/go.mod h1:pFQYn66WHrOpPYNljwOMqo10TkYh1fy3cYio2l3bCsQ= -github.com/kr/text v0.1.0 h1:45sCR5RtlFHMR4UwH9sdQ5TC8v0qDQCHnXt+kaKSTVE= -github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI= -github.com/lib/pq v1.0.0 h1:X5PMW56eZitiTeO7tKzZxFCSpbFZJtkMMooicw2us9A= github.com/lib/pq v1.0.0/go.mod h1:5WUZQaWbwv1U+lTReE5YruASi9Al49XbQIvNi/34Woo= +github.com/mattn/go-isatty v0.0.4 h1:bnP0vzxcAdeI1zdubAl5PjU6zsERjGZb7raWodagDYs= github.com/mattn/go-isatty v0.0.4/go.mod h1:M+lRXTBqGeGNdLjl/ufCoiOlB5xdOkqRJdNxMWT7Zi4= -github.com/mattn/go-isatty v0.0.7 h1:UvyT9uN+3r7yLEYSlJsbQGdsaB/a0DlgWP3pql6iwOc= -github.com/mattn/go-isatty v0.0.7/go.mod h1:Iq45c/XA43vh69/j3iqttzPXn0bhXyGjM0Hdxcsrc5s= github.com/mattn/go-sqlite3 v1.9.0/go.mod h1:FPy6KqzDD04eiIsT53CuJW3U88zkxoIYsOqkbpncsNc= github.com/mattn/go-sqlite3 v1.10.0 h1:jbhqpg7tQe4SupckyijYiy0mJJ/pRyHvXf7JdWK860o= github.com/mattn/go-sqlite3 v1.10.0/go.mod h1:FPy6KqzDD04eiIsT53CuJW3U88zkxoIYsOqkbpncsNc= -github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd h1:TRLaZ9cD/w8PVh93nsPXa1VrQ6jlwL5oN8l14QlcNfg= +github.com/mediocregopher/mediocre-go-lib v0.0.0-20181029021733-cb65787f37ed/go.mod h1:dSsfyI2zABAdhcbvkXqgxOxrCsbYeHCPgrZkku60dSg= +github.com/mediocregopher/radix/v3 v3.2.3 h1:TbcGCZdo9zfPYPgevsqRn+OjvCyfOK6TzuXhqzWdCt0= +github.com/mediocregopher/radix/v3 v3.2.3/go.mod h1:EmfVyvspXz1uZEyPBMyGK+kjWiKQGvsUt6O3Pj+LDCQ= github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= -github.com/modern-go/reflect2 v1.0.1 h1:9f412s+6RmYXLWZSEzVVgPGK7C2PphHj5RJrvfx9AWI= github.com/modern-go/reflect2 v1.0.1/go.mod h1:bx2lNnkwVCuqBIxFjflWJWanXIb3RllmbCylyMrvgv0= -github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM= github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= github.com/segmentio/ksuid v1.0.2 h1:9yBfKyw4ECGTdALaF09Snw3sLJmYIX6AbPJrAy6MrDc= github.com/segmentio/ksuid v1.0.2/go.mod h1:BXuJDr2byAiHuQaQtSKoXh1J0YmUDurywOXgB2w+OSU= -github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME= github.com/stretchr/testify v1.2.2/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs= -github.com/stretchr/testify v1.3.0 h1:TivCn/peBQ7UY8ooIcPgZFpTNSz0Q2U6UrFlUfqbe0Q= -github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI= -github.com/ugorji/go v1.1.2 h1:JON3E2/GPW2iDNGoSAusl1KDf5TRQ8k8q7Tp097pZGs= -github.com/ugorji/go v1.1.2/go.mod h1:hnLbHMwcvSihnDhEfx2/BzKp2xb0Y+ErdfYcrs9tkJQ= +github.com/ugorji/go/codec v0.0.0-20181209151446-772ced7fd4c2 h1:EICbibRW4JNKMcY+LsWmuwob+CRS1BmdRdjphAm9mH4= github.com/ugorji/go/codec v0.0.0-20181209151446-772ced7fd4c2/go.mod h1:VFNgLljTbGfSG7qAOspJ7OScBnGdDN/yBr0sguwnwf0= -github.com/ugorji/go/codec v0.0.0-20190315113641-a70535d8491c h1:20Yyqg0mvFOyG3m7ejVqHEa03CBa3hTttx9jiYLkjYU= -github.com/ugorji/go/codec v0.0.0-20190315113641-a70535d8491c/go.mod h1:iT03XoTwV7xq/+UGwKO3UbC1nNNlopQiY61beSdrtOA= -golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= -golang.org/x/net v0.0.0-20180724234803-3673e40ba225/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= golang.org/x/net v0.0.0-20181220203305-927f97764cc3/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= -golang.org/x/net v0.0.0-20190320064053-1272bf9dcd53 h1:kcXqo9vE6fsZY5X5Rd7R1l7fTgnWaDCVmln65REefiE= -golang.org/x/net v0.0.0-20190320064053-1272bf9dcd53/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= golang.org/x/sync v0.0.0-20181221193216-37e7f081c4d4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sys v0.0.0-20181228144115-9a3f9b0469bb/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= -golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= -golang.org/x/sys v0.0.0-20190222072716-a9d3bda3a223 h1:DH4skfRX4EBpamg7iV4ZlCpblAHI6s6TDM39bFZumv8= -golang.org/x/sys v0.0.0-20190222072716-a9d3bda3a223/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= -golang.org/x/sys v0.0.0-20190321052220-f7bb7a8bee54 h1:xe1/2UUJRmA9iDglQSlkx8c5n3twv58+K0mPpC2zmhA= -golang.org/x/sys v0.0.0-20190321052220-f7bb7a8bee54/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= -google.golang.org/appengine v1.5.0 h1:KxkO13IPW4Lslp2bz+KHP2E3gtFlrIGNThxkZQ3g+4c= -google.golang.org/appengine v1.5.0/go.mod h1:xpcJRLb0r/rnEns0DIKYYv+WjYCduHsrkT7/EB5XEv4= gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= -gopkg.in/check.v1 v1.0.0-20180628173108-788fd7840127 h1:qIbj1fsPNlZgppZ+VLlY7N33q108Sa+fhmuc+sWQYwY= -gopkg.in/check.v1 v1.0.0-20180628173108-788fd7840127/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= -gopkg.in/go-playground/assert.v1 v1.2.1 h1:xoYuJVE7KT85PYWrN730RguIQO0ePzVRfFMXadIrXTM= gopkg.in/go-playground/assert.v1 v1.2.1/go.mod h1:9RXL0bg/zibRAgZUYszZSwO/z8Y/a8bDuhia5mkpMnE= gopkg.in/go-playground/validator.v8 v8.18.2 h1:lFB4DoMU6B626w8ny76MV7VX6W2VHct2GVOI3xgiMrQ= gopkg.in/go-playground/validator.v8 v8.18.2/go.mod h1:RX2a/7Ha8BgOhfk7j780h4/u/RRjR0eouCJSH80/M2Y= diff --git a/main.go b/main.go index c07017f..0b84327 100644 --- a/main.go +++ b/main.go @@ -1,9 +1,9 @@ package main -import "git.sp4ke.com/sp4ke/bit4sat-server.git/db" +import "git.sp4ke.com/sp4ke/bit4sat/db" func main() { - defer db.DB.Handle.Close() + defer db.DB.Sql.Close() api := NewAPI() api.Run() diff --git a/storage/storage.go b/storage/storage.go index fd8eb81..7538fc8 100644 --- a/storage/storage.go +++ b/storage/storage.go @@ -9,7 +9,7 @@ import ( "os" "path/filepath" - "git.sp4ke.com/sp4ke/bit4sat-server.git/utils" + "git.sp4ke.com/sp4ke/bit4sat/utils" ) const ( diff --git a/storage/upload_ctrl.go b/storage/upload_ctrl.go index 208840b..545ad0b 100644 --- a/storage/upload_ctrl.go +++ b/storage/upload_ctrl.go @@ -9,8 +9,8 @@ import ( "net/http" "os" - "git.sp4ke.com/sp4ke/bit4sat-server.git/db" - "git.sp4ke.com/sp4ke/bit4sat-server.git/utils" + "git.sp4ke.com/sp4ke/bit4sat/db" + "git.sp4ke.com/sp4ke/bit4sat/utils" "github.com/gin-gonic/gin" "github.com/segmentio/ksuid" ) @@ -29,7 +29,7 @@ func (ctrl UploadCtrl) New(c *gin.Context) { // Create unique id id := ksuid.New() - tx, err := db.DB.Handle.Beginx() + tx, err := db.DB.Sql.Beginx() if err != nil { utils.JSONErrPriv(c, http.StatusInternalServerError, err) return @@ -61,6 +61,7 @@ func (ctrl UploadCtrl) New(c *gin.Context) { return } + log.Println("new upload created") c.JSON(http.StatusOK, gin.H{ "status": http.StatusOK, "result": gin.H{ @@ -94,7 +95,7 @@ func (ctrl UploadCtrl) Upload(c *gin.Context) { files := form.File["upload[]"] - tx, err := db.DB.Handle.Beginx() + tx, err := db.DB.Sql.Beginx() if err != nil { utils.JSONErrPriv(c, http.StatusInternalServerError, err) return diff --git a/storage/upload_model.go b/storage/upload_model.go index ff6b5a8..dcdb28f 100644 --- a/storage/upload_model.go +++ b/storage/upload_model.go @@ -5,7 +5,7 @@ import ( "errors" "log" - "git.sp4ke.com/sp4ke/bit4sat-server.git/db" + "git.sp4ke.com/sp4ke/bit4sat/db" "github.com/jmoiron/sqlx" "github.com/mattn/go-sqlite3" ) @@ -87,7 +87,7 @@ func IdExists(id string) (exists bool, err error) { qUploadExists := ` SELECT EXISTS (SELECT upload_id FROM upload where upload_id = ?) ` - err = DB.Handle.Get(&exists, qUploadExists, id) + err = DB.Sql.Get(&exists, qUploadExists, id) // No result found is also no result if err == sql.ErrNoRows { @@ -100,7 +100,7 @@ func IdExists(id string) (exists bool, err error) { // Get a file by upload id and hash func GetByHashID(sha256 string, id string) (*Upload, error) { var up Upload - err := DB.Handle.Get(&up, QGetByHashID, sha256, id) + err := DB.Sql.Get(&up, QGetByHashID, sha256, id) if err == sql.ErrNoRows { return nil, ErrDoesNotExist @@ -126,7 +126,9 @@ func (u *Upload) TxSetState(tx *sqlx.Tx, status int) error { func (u *Upload) TxWrite(tx *sqlx.Tx) error { _, err := tx.NamedExec(QNewUpload, u) + sqlErr, isSqlErr := err.(sqlite3.Error) + if isSqlErr && sqlErr.Code == sqlite3.ErrConstraint { return ErrAlreadyExists } @@ -139,7 +141,7 @@ func (u *Upload) TxWrite(tx *sqlx.Tx) error { } func (u *Upload) Write() error { - _, err := DB.Handle.NamedExec(QNewUpload, u) + _, err := DB.Sql.NamedExec(QNewUpload, u) sqlErr, isSqlErr := err.(sqlite3.Error) if isSqlErr && sqlErr.Code == sqlite3.ErrConstraint { return ErrAlreadyExists @@ -153,17 +155,17 @@ func (u *Upload) Write() error { } func init() { - _, err := DB.Handle.Exec(DBUploadSchema) + _, err := DB.Sql.Exec(DBUploadSchema) if err != nil { log.Fatal(err) } - _, err = DB.Handle.Exec(DBUploadView) + _, err = DB.Sql.Exec(DBUploadView) if err != nil { log.Fatal(err) } - _, err = DB.Handle.Exec(DBUploadStatusSchema) + _, err = DB.Sql.Exec(DBUploadStatusSchema) if err != nil { log.Fatal(err) } @@ -171,7 +173,7 @@ func init() { // Populate status types query := `INSERT INTO upload_status (type, status) VALUES(?,?)` for k, v := range UploadStatus { - _, err := DB.Handle.Exec(query, k, v) + _, err := DB.Sql.Exec(query, k, v) if err != nil { sqlErr, ok := err.(sqlite3.Error) if ok && sqlErr.ExtendedCode == sqlite3.ErrConstraintUnique { diff --git a/web/src/worker.js b/web/src/worker.js index 50bd737..fdda35b 100644 --- a/web/src/worker.js +++ b/web/src/worker.js @@ -59,7 +59,7 @@ async function newUpload(files){ postMessage({msg: 'upload-id', id: id}) // Send the files - upload.send() + //upload.send() }) }