forked from Silverfish/proton-bridge
- Changed: Do not reauth controller clients. - Changed: Verbosisty is set only once before run - Changed: AddUser takes TestAccount as argument - Added: Setup/clean up before/after test run - Added: Access to the current refresh token from pmapi.Client interface. - Added: Context function to add test a user to bridge without login, just call users.FinishLogin. - Added: PMAPIController.GetAuthClient returns authenticated client for username. - Added: Persistent clients does not loggout after every scenario. - Changed: Disabled no-internet tests.
76 lines
1.9 KiB
Go
76 lines
1.9 KiB
Go
// Copyright (c) 2021 Proton Technologies AG
|
|
//
|
|
// This file is part of ProtonMail Bridge.Bridge.
|
|
//
|
|
// ProtonMail Bridge is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// ProtonMail Bridge is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with ProtonMail Bridge. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
package fakeapi
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/ProtonMail/proton-bridge/pkg/pmapi"
|
|
)
|
|
|
|
func (api *FakePMAPI) Auth2FA(_ context.Context, twoFactorCode string) error {
|
|
if err := api.checkAndRecordCall(POST, "/auth/2fa", twoFactorCode); err != nil {
|
|
return err
|
|
}
|
|
|
|
if api.uid == "" {
|
|
return pmapi.ErrUnauthorized
|
|
}
|
|
|
|
session, ok := api.controller.sessionsByUID[api.uid]
|
|
if !ok {
|
|
return pmapi.ErrUnauthorized
|
|
}
|
|
|
|
session.hasFullScope = true
|
|
|
|
return nil
|
|
}
|
|
|
|
func (api *FakePMAPI) AuthSalt(_ context.Context) (string, error) {
|
|
if err := api.checkAndRecordCall(GET, "/keys/salts", nil); err != nil {
|
|
return "", err
|
|
}
|
|
|
|
return "", nil
|
|
}
|
|
|
|
func (api *FakePMAPI) AddAuthRefreshHandler(handler pmapi.AuthRefreshHandler) {
|
|
api.authHandlers = append(api.authHandlers, handler)
|
|
}
|
|
|
|
func (api *FakePMAPI) AuthDelete(_ context.Context) error {
|
|
if err := api.checkAndRecordCall(DELETE, "/auth", nil); err != nil {
|
|
return err
|
|
}
|
|
|
|
api.controller.deleteSession(api.uid)
|
|
|
|
return nil
|
|
}
|
|
|
|
func (api *FakePMAPI) GetCurrentAuth() *pmapi.Auth {
|
|
return &pmapi.Auth{
|
|
UserID: api.userID,
|
|
AuthRefresh: pmapi.AuthRefresh{
|
|
UID: api.uid,
|
|
RefreshToken: api.ref,
|
|
},
|
|
}
|
|
}
|