1/*2Maddy Mail Server - Composable all-in-one email server.3Copyright © 2019-2020 Max Mazurov <fox.cpp@disroot.org>, Maddy Mail Server contributors45This program is free software: you can redistribute it and/or modify6it under the terms of the GNU General Public License as published by7the Free Software Foundation, either version 3 of the License, or8(at your option) any later version.910This program is distributed in the hope that it will be useful,11but WITHOUT ANY WARRANTY; without even the implied warranty of12MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the13GNU General Public License for more details.1415You should have received a copy of the GNU General Public License16along with this program. If not, see <https://www.gnu.org/licenses/>.17*/1819package module2021import "errors"2223// ErrUnknownCredentials should be returned by auth. provider if supplied24// credentials are valid for it but are not recognized (e.g. not found in25// used DB).26var ErrUnknownCredentials = errors.New("unknown credentials")2728// PlainAuth is the interface implemented by modules providing authentication using29// username:password pairs.30//31// Modules implementing this interface should be registered with "auth." prefix in name.32type PlainAuth interface {33 AuthPlain(username, password string) error34}3536// PlainUserDB is a local credentials store that can be managed using maddy command37// utility.38type PlainUserDB interface {39 PlainAuth40 ListUsers() ([]string, error)41 CreateUser(username, password string) error42 SetUserPassword(username, password string) error43 DeleteUser(username string) error44}