diff options
| author | Jacky Zhao <[email protected]> | 2020-05-15 18:53:37 -0700 |
|---|---|---|
| committer | GitHub <[email protected]> | 2020-05-15 18:53:37 -0700 |
| commit | 2e4a87393d6fdf0320696faedecdc7699289fffb (patch) | |
| tree | 7afe72a155fd9f6afd1bdded4a214b6fbba77fa0 /backend/db | |
| parent | Merge pull request #24 from jackyzha0/update-readme (diff) | |
| parent | Add comments and clean up encryption (diff) | |
| download | ctrl-v-2e4a87393d6fdf0320696faedecdc7699289fffb.tar.xz ctrl-v-2e4a87393d6fdf0320696faedecdc7699289fffb.zip | |
Merge pull request #25 from jackyzha0/security
Add encryption to content when password is specified
Diffstat (limited to 'backend/db')
| -rw-r--r-- | backend/db/db.go | 21 | ||||
| -rw-r--r-- | backend/db/schemas.go | 1 |
2 files changed, 19 insertions, 3 deletions
diff --git a/backend/db/db.go b/backend/db/db.go index 4e58188..df112d0 100644 --- a/backend/db/db.go +++ b/backend/db/db.go @@ -5,7 +5,7 @@ import ( "os" "time" - "github.com/jackyzha0/ctrl-v/hashing" + "github.com/jackyzha0/ctrl-v/security" "github.com/joho/godotenv" log "github.com/sirupsen/logrus" ) @@ -30,7 +30,7 @@ const ContentLimit = 100000 // creates a new paste with title, content and hash, returns the hash of the created paste func New(ip, content, expiry, title, password string) (string, error) { // generate hash from ip - hash := hashing.GenerateURI(ip) + hash := security.GenerateURI(ip) // check for size of title and content errs := checkLengths(title, content) @@ -45,9 +45,24 @@ func New(ip, content, expiry, title, password string) (string, error) { Title: title, } + // if there is a password, encrypt content and hash the password if password != "" { + // use pass to encrypt content + key, salt, err := security.DeriveKey(password, nil) + if err != nil { + return "", fmt.Errorf("could not generate key: %s", err.Error()) + } + new.Salt = salt + + encryptedContent, err := security.Encrypt(key, new.Content) + if err != nil { + return "", fmt.Errorf("could not encrypt content: %s", err.Error()) + } + + new.Content = encryptedContent + // hash given password - hashedPass, err := hashing.HashPassword(password) + hashedPass, err := security.HashPassword(password) if err != nil { return "", fmt.Errorf("could not hash password: %s", err.Error()) } diff --git a/backend/db/schemas.go b/backend/db/schemas.go index 4c73f82..d3551fc 100644 --- a/backend/db/schemas.go +++ b/backend/db/schemas.go @@ -14,4 +14,5 @@ type Paste struct { Expiry time.Time `bson:"expiry"` Title string Password string + Salt []byte } |