summaryrefslogtreecommitdiffstats
path: root/vendor/github.com/Philipp15b/go-steam/cryptoutil/rsa.go
diff options
context:
space:
mode:
authorWim <wim@42.be>2017-06-22 01:00:27 +0200
committerWim <wim@42.be>2017-06-22 01:00:27 +0200
commit1f914618538920db4bfec7b106ee97038b157c9b (patch)
tree6bd0ab107fe1673dbacdf9dfd10004289cd7bfab /vendor/github.com/Philipp15b/go-steam/cryptoutil/rsa.go
parent1f9874102aaca09ce5e0289beff376c307b8c57b (diff)
downloadmatterbridge-msglm-1f914618538920db4bfec7b106ee97038b157c9b.tar.gz
matterbridge-msglm-1f914618538920db4bfec7b106ee97038b157c9b.tar.bz2
matterbridge-msglm-1f914618538920db4bfec7b106ee97038b157c9b.zip
Add vendor (steam)
Diffstat (limited to 'vendor/github.com/Philipp15b/go-steam/cryptoutil/rsa.go')
-rw-r--r--vendor/github.com/Philipp15b/go-steam/cryptoutil/rsa.go31
1 files changed, 31 insertions, 0 deletions
diff --git a/vendor/github.com/Philipp15b/go-steam/cryptoutil/rsa.go b/vendor/github.com/Philipp15b/go-steam/cryptoutil/rsa.go
new file mode 100644
index 00000000..78cd954a
--- /dev/null
+++ b/vendor/github.com/Philipp15b/go-steam/cryptoutil/rsa.go
@@ -0,0 +1,31 @@
+package cryptoutil
+
+import (
+ "crypto/rand"
+ "crypto/rsa"
+ "crypto/sha1"
+ "crypto/x509"
+ "errors"
+)
+
+// Parses a DER encoded RSA public key
+func ParseASN1RSAPublicKey(derBytes []byte) (*rsa.PublicKey, error) {
+ key, err := x509.ParsePKIXPublicKey(derBytes)
+ if err != nil {
+ return nil, err
+ }
+ pubKey, ok := key.(*rsa.PublicKey)
+ if !ok {
+ return nil, errors.New("not an RSA public key")
+ }
+ return pubKey, nil
+}
+
+// Encrypts a message with the given public key using RSA-OAEP and the sha1 hash function.
+func RSAEncrypt(pub *rsa.PublicKey, msg []byte) []byte {
+ b, err := rsa.EncryptOAEP(sha1.New(), rand.Reader, pub, msg, nil)
+ if err != nil {
+ panic(err)
+ }
+ return b
+}