Encrypted messaging app
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

212 lines
4.5 KiB

  1. package Auth_test
  2. import (
  3. "bytes"
  4. "encoding/base64"
  5. "encoding/json"
  6. "io/ioutil"
  7. "log"
  8. "net/http"
  9. "net/http/cookiejar"
  10. "net/http/httptest"
  11. "net/url"
  12. "testing"
  13. "time"
  14. "git.tovijaeschke.xyz/tovi/Capsule/Backend/Api"
  15. "git.tovijaeschke.xyz/tovi/Capsule/Backend/Api/Auth"
  16. "git.tovijaeschke.xyz/tovi/Capsule/Backend/Database"
  17. "git.tovijaeschke.xyz/tovi/Capsule/Backend/Database/Seeder"
  18. "git.tovijaeschke.xyz/tovi/Capsule/Backend/Models"
  19. "github.com/gorilla/mux"
  20. )
  21. func Test_ChangeMessageExpiry(t *testing.T) {
  22. log.SetOutput(ioutil.Discard)
  23. Database.InitTest()
  24. r := mux.NewRouter()
  25. Api.InitAPIEndpoints(r)
  26. ts := httptest.NewServer(r)
  27. defer ts.Close()
  28. userKey, _ := Seeder.GenerateAesKey()
  29. pubKey := Seeder.GetPubKey()
  30. p, _ := Auth.HashPassword("password")
  31. u := Models.User{
  32. Username: "test",
  33. Password: p,
  34. AsymmetricPublicKey: Seeder.PublicKey,
  35. AsymmetricPrivateKey: Seeder.EncryptedPrivateKey,
  36. SymmetricKey: base64.StdEncoding.EncodeToString(
  37. Seeder.EncryptWithPublicKey(userKey.Key, pubKey),
  38. ),
  39. }
  40. err := Database.CreateUser(&u)
  41. if err != nil {
  42. t.Errorf("Expected nil, recieved %s", err.Error())
  43. return
  44. }
  45. session := Models.Session{
  46. UserID: u.ID,
  47. Expiry: time.Now().Add(12 * time.Hour),
  48. }
  49. err = Database.CreateSession(&session)
  50. if err != nil {
  51. t.Errorf("Expected nil, recieved %s", err.Error())
  52. return
  53. }
  54. jar, err := cookiejar.New(nil)
  55. if err != nil {
  56. t.Errorf("Expected nil, recieved %s", err.Error())
  57. return
  58. }
  59. url, _ := url.Parse(ts.URL)
  60. jar.SetCookies(
  61. url,
  62. []*http.Cookie{
  63. {
  64. Name: "session_token",
  65. Value: session.ID.String(),
  66. MaxAge: 300,
  67. },
  68. },
  69. )
  70. d := struct {
  71. MessageExpiry string `json:"message_expiry"`
  72. }{
  73. MessageExpiry: "fifteen_min",
  74. }
  75. jsonStr, _ := json.Marshal(d)
  76. req, _ := http.NewRequest("POST", ts.URL+"/api/v1/auth/message_expiry", bytes.NewBuffer(jsonStr))
  77. req.Header.Set("Content-Type", "application/json")
  78. client := &http.Client{
  79. Jar: jar,
  80. }
  81. resp, err := client.Do(req)
  82. if err != nil {
  83. t.Errorf("Expected nil, recieved %s", err.Error())
  84. return
  85. }
  86. if resp.StatusCode != http.StatusNoContent {
  87. t.Errorf("Expected %d, recieved %d", http.StatusNoContent, resp.StatusCode)
  88. }
  89. u, err = Database.GetUserById(u.ID.String())
  90. if err != nil {
  91. t.Errorf("Expected nil, recieved %s", err.Error())
  92. return
  93. }
  94. if u.MessageExpiryDefault.String() != "fifteen_min" {
  95. t.Errorf("Failed to verify the MessageExpiryDefault has been changed")
  96. }
  97. }
  98. func Test_ChangeMessageExpiryInvalidData(t *testing.T) {
  99. log.SetOutput(ioutil.Discard)
  100. Database.InitTest()
  101. r := mux.NewRouter()
  102. Api.InitAPIEndpoints(r)
  103. ts := httptest.NewServer(r)
  104. defer ts.Close()
  105. userKey, _ := Seeder.GenerateAesKey()
  106. pubKey := Seeder.GetPubKey()
  107. p, _ := Auth.HashPassword("password")
  108. u := Models.User{
  109. Username: "test",
  110. Password: p,
  111. AsymmetricPublicKey: Seeder.PublicKey,
  112. AsymmetricPrivateKey: Seeder.EncryptedPrivateKey,
  113. SymmetricKey: base64.StdEncoding.EncodeToString(
  114. Seeder.EncryptWithPublicKey(userKey.Key, pubKey),
  115. ),
  116. }
  117. err := Database.CreateUser(&u)
  118. if err != nil {
  119. t.Errorf("Expected nil, recieved %s", err.Error())
  120. return
  121. }
  122. session := Models.Session{
  123. UserID: u.ID,
  124. Expiry: time.Now().Add(12 * time.Hour),
  125. }
  126. err = Database.CreateSession(&session)
  127. if err != nil {
  128. t.Errorf("Expected nil, recieved %s", err.Error())
  129. return
  130. }
  131. jar, err := cookiejar.New(nil)
  132. if err != nil {
  133. t.Errorf("Expected nil, recieved %s", err.Error())
  134. return
  135. }
  136. url, _ := url.Parse(ts.URL)
  137. jar.SetCookies(
  138. url,
  139. []*http.Cookie{
  140. {
  141. Name: "session_token",
  142. Value: session.ID.String(),
  143. MaxAge: 300,
  144. },
  145. },
  146. )
  147. d := struct {
  148. MessageExpiry string `json:"message_expiry"`
  149. }{
  150. MessageExpiry: "invalid_message_expiry",
  151. }
  152. jsonStr, _ := json.Marshal(d)
  153. req, _ := http.NewRequest("POST", ts.URL+"/api/v1/auth/message_expiry", bytes.NewBuffer(jsonStr))
  154. req.Header.Set("Content-Type", "application/json")
  155. client := &http.Client{
  156. Jar: jar,
  157. }
  158. resp, err := client.Do(req)
  159. if err != nil {
  160. t.Errorf("Expected nil, recieved %s", err.Error())
  161. return
  162. }
  163. if resp.StatusCode != http.StatusUnprocessableEntity {
  164. t.Errorf("Expected %d, recieved %d", http.StatusUnprocessableEntity, resp.StatusCode)
  165. }
  166. u, err = Database.GetUserById(u.ID.String())
  167. if err != nil {
  168. t.Errorf("Expected nil, recieved %s", err.Error())
  169. return
  170. }
  171. if u.MessageExpiryDefault.String() != "no_expiry" {
  172. t.Errorf("Failed to verify the MessageExpiryDefault has not been changed")
  173. }
  174. }