8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-31 19:23:03 +01:00
firebird-mirror/src/jrd/jrd_pwd.h

135 lines
3.6 KiB
C
Raw Normal View History

/*
* PROGRAM: JRD Access Method
2003-02-19 07:14:39 +01:00
* MODULE: jrd_pwd.h
* DESCRIPTION: User information database name
*
* The contents of this file are subject to the Interbase Public
* License Version 1.0 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy
* of the License at http://www.Inprise.com/IPL.html
*
* Software distributed under the License is distributed on an
* "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, either express
* or implied. See the License for the specific language governing
* rights and limitations under the License.
*
* The Original Code was created by Inprise Corporation
* and its predecessors. Portions created by Inprise Corporation are
* Copyright (C) Inprise Corporation.
*
* All Rights Reserved.
* Contributor(s): ______________________________________.
*
* 2002.10.29 Sean Leyne - Removed obsolete "Netware" port
* 2003.02.02 Dmitry Yemanov: Implemented cached security database connection
*/
#ifndef JRD_PWD_H
#define JRD_PWD_H
#include "../jrd/ibase.h"
#include "../common/utils_proto.h"
#include "../jrd/sha.h"
#include "gen/iberror.h"
#include "../common/classes/ClumpletWriter.h"
#include "../auth/AuthInterface.h"
2004-11-16 12:41:35 +01:00
#ifdef HAVE_STDLIB_H
#include <stdlib.h>
2004-11-16 12:41:35 +01:00
#endif
#include <time.h>
namespace Auth {
2009-04-03 12:49:07 +02:00
const size_t MAX_PASSWORD_ENC_LENGTH = 12; // passed by remote protocol
const size_t MAX_PASSWORD_LENGTH = 64; // used to store passwords internally
2009-04-04 18:28:33 +02:00
static const char* const PASSWORD_SALT = "9z"; // for old ENC_crypt()
2009-04-03 12:49:07 +02:00
const size_t SALT_LENGTH = 12; // measured after base64 coding
class SecurityDatabase
{
public:
static void getPath(char* path_buffer)
{
2008-01-16 10:29:37 +01:00
static const char* USER_INFO_NAME = "security2.fdb";
Firebird::PathName name = fb_utils::getPrefix(fb_utils::FB_DIR_SECDB, USER_INFO_NAME);
name.copyTo(path_buffer, MAXPATHLEN);
}
2010-01-24 16:18:43 +01:00
static Result verify(WriterInterface* authBlock,
Firebird::ClumpletReader& originalDpb);
2010-01-24 18:15:57 +01:00
static void shutdown(void*);
2008-12-22 10:00:05 +01:00
static void hash(Firebird::string& h, const Firebird::string& userName, const TEXT* passwd)
{
Firebird::string salt;
Jrd::CryptSupport::random(salt, SALT_LENGTH);
hash(h, userName, passwd, salt);
}
2008-12-05 01:56:15 +01:00
static void hash(Firebird::string& h,
const Firebird::string& userName,
const Firebird::string& passwd,
const Firebird::string& oldHash)
{
Firebird::string salt(oldHash);
salt.resize(SALT_LENGTH, '=');
Firebird::string allData(salt);
allData += userName;
allData += passwd;
Jrd::CryptSupport::hash(h, allData);
h = salt + h;
}
private:
Firebird::Mutex mutex;
2003-04-16 12:18:51 +02:00
ISC_STATUS_ARRAY status;
isc_db_handle lookup_db;
isc_req_handle lookup_req;
int timer;
char user_info_name[MAXPATHLEN];
void init();
void fini();
bool lookup_user(const char*, char*);
void prepare();
void checkStatus(const char* callName, ISC_STATUS userError = isc_psw_db_error);
2003-10-03 14:28:54 +02:00
static SecurityDatabase instance;
SecurityDatabase()
: lookup_db(0), lookup_req(0), timer(0)
{
}
};
class SecurityDatabaseServer : public ServerPlugin
2008-01-16 10:29:37 +01:00
{
public:
ServerInstance* instance();
void getName(const char** data, unsigned short* dataSize);
void release();
2008-01-16 10:29:37 +01:00
};
class SecurityDatabaseServerInstance : public ServerInstance
{
public:
2010-01-24 16:18:43 +01:00
Result startAuthentication(bool isService, const char* dbName,
const unsigned char* dpb, unsigned int dpbSize,
WriterInterface* writerInterface);
2010-01-24 16:18:43 +01:00
Result contAuthentication(WriterInterface* writerInterface,
const unsigned char* data, unsigned int size);
void getData(const unsigned char** data, unsigned short* dataSize);
void release();
};
2008-01-16 10:29:37 +01:00
} // namespace Auth
2008-01-16 10:29:37 +01:00
#endif // JRD_PWD_H