]> git.netwichtig.de Git - user/henk/code/inspircd.git/blob - include/uid.h
c00161cac2104a533df6dc2762b8c390552ee5c7
[user/henk/code/inspircd.git] / include / uid.h
1 /*
2  * InspIRCd -- Internet Relay Chat Daemon
3  *
4  *   Copyright (C) 2013, 2019 Sadie Powell <sadie@witchery.services>
5  *   Copyright (C) 2013 Attila Molnar <attilamolnar@hush.com>
6  *   Copyright (C) 2012 Robby <robby@chatbelgie.be>
7  *   Copyright (C) 2010 Craig Edwards <brain@inspircd.org>
8  *   Copyright (C) 2007 Robin Burchell <robin+git@viroteck.net>
9  *
10  * This file is part of InspIRCd.  InspIRCd is free software: you can
11  * redistribute it and/or modify it under the terms of the GNU General Public
12  * License as published by the Free Software Foundation, version 2.
13  *
14  * This program is distributed in the hope that it will be useful, but WITHOUT
15  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
16  * FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more
17  * details.
18  *
19  * You should have received a copy of the GNU General Public License
20  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
21  */
22
23 #pragma once
24
25 class CoreExport UIDGenerator
26 {
27  private:
28         /** Holds the current UID. Used to generate the next one.
29          */
30         std::string current_uid;
31
32         /** Increments the current UID by one.
33          */
34         void IncrementUID(unsigned int pos);
35
36  public:
37         /**
38         * This is the maximum length of a UUID (unique user identifier).
39         * It allows up to 12,960 servers and 2,176,782,336 users per server.
40         */
41         static const unsigned int UUID_LENGTH = 9;
42
43         /** Initializes this UID generator with the given SID
44          * @param sid SID that conforms to InspIRCd::IsSID()
45          */
46         void init(const std::string& sid);
47
48         /** Returns the next available UID for this server.
49          */
50         std::string GetUID();
51
52         /** Generates a pseudorandom SID based on a servername and a description
53          * Guaranteed to return the same if invoked with the same parameters
54          * @param servername The server name to use as seed
55          * @param serverdesc The server description to use as seed
56          * @return A valid SID
57          */
58         static std::string GenerateSID(const std::string& servername, const std::string& serverdesc);
59 };