| 
									
										
										
										
											2019-07-17 19:37:18 +02:00
										 |  |  | #include "log/LogUtils.h"
 | 
					
						
							| 
									
										
										
										
											2020-02-28 11:24:07 +01:00
										 |  |  | #include "DatabaseHandler.h"
 | 
					
						
							| 
									
										
										
										
											2019-07-17 19:37:18 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | using namespace license; | 
					
						
							| 
									
										
										
										
											2020-02-28 11:24:07 +01:00
										 |  |  | using namespace license::server::database; | 
					
						
							| 
									
										
										
										
											2019-07-17 19:37:18 +02:00
										 |  |  | using namespace std; | 
					
						
							|  |  |  | using namespace std::chrono; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-28 11:24:07 +01:00
										 |  |  | KeyIdCache::KeyIdCache(DatabaseHandler *handle) : handle(handle) {} | 
					
						
							| 
									
										
										
										
											2019-07-17 19:37:18 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-28 11:24:07 +01:00
										 |  |  | void KeyIdCache::clear_cache() { | 
					
						
							|  |  |  |     std::lock_guard elock{this->entry_lock}; | 
					
						
							|  |  |  |     this->entries.clear(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | std::string KeyIdCache::get_key_from_id(size_t keyId) { | 
					
						
							| 
									
										
										
										
											2019-07-17 19:37:18 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2020-02-28 11:24:07 +01:00
										 |  |  |         std::lock_guard elock{this->entry_lock}; | 
					
						
							| 
									
										
										
										
											2019-07-17 19:37:18 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         for(const auto& entry : this->entries) | 
					
						
							|  |  |  |             if(entry->keyId == keyId) return entry->key; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-28 11:24:07 +01:00
										 |  |  |     sql::command(this->handle->sql(), "SELECT `key`, `keyId` FROM `license` WHERE `keyId` = :key", variable{":key", keyId}) | 
					
						
							| 
									
										
										
										
											2019-07-17 19:37:18 +02:00
										 |  |  |             .query(&KeyIdCache::insert_entry, this); | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2020-02-28 11:24:07 +01:00
										 |  |  |         std::lock_guard elock{this->entry_lock}; | 
					
						
							| 
									
										
										
										
											2019-07-17 19:37:18 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         for(const auto& entry : this->entries) | 
					
						
							|  |  |  |             if(entry->keyId == keyId) return entry->key; | 
					
						
							|  |  |  |         return ""; //Key not found!
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-28 11:24:07 +01:00
										 |  |  | size_t KeyIdCache::get_key_id_from_key(const std::string &key) { | 
					
						
							| 
									
										
										
										
											2019-07-17 19:37:18 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2020-02-28 11:24:07 +01:00
										 |  |  |         std::lock_guard elock{this->entry_lock}; | 
					
						
							| 
									
										
										
										
											2019-07-17 19:37:18 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         for(const auto& entry : this->entries) | 
					
						
							|  |  |  |             if(entry->key == key) return entry->keyId; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-28 11:24:07 +01:00
										 |  |  |     auto result = sql::command(this->handle->sql(), "SELECT `key`, `keyId` FROM `license` WHERE `key` = :key", variable{":key", key}) | 
					
						
							| 
									
										
										
										
											2019-07-17 19:37:18 +02:00
										 |  |  |             .query(&KeyIdCache::insert_entry, this); | 
					
						
							|  |  |  |     if(!result) | 
					
						
							|  |  |  |         logError(LOG_GENERAL, "Failed to query key id for license. Query resulted in {}", result.fmtStr()); | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2020-02-28 11:24:07 +01:00
										 |  |  |         std::lock_guard elock{this->entry_lock}; | 
					
						
							| 
									
										
										
										
											2019-07-17 19:37:18 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         for(const auto& entry : this->entries) | 
					
						
							|  |  |  |             if(entry->key == key) | 
					
						
							|  |  |  |                 return entry->keyId; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return 0; //Key not found!
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int KeyIdCache::insert_entry(int length, std::string *value, std::string *names) { | 
					
						
							| 
									
										
										
										
											2020-02-28 11:24:07 +01:00
										 |  |  |     string key{"unknown"}; | 
					
						
							|  |  |  |     size_t keyId{0}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for(int index = 0; index < length; index++) { | 
					
						
							| 
									
										
										
										
											2019-07-17 19:37:18 +02:00
										 |  |  |         if(names[index] == "key") | 
					
						
							|  |  |  |             key = value[index]; | 
					
						
							|  |  |  |         else if(names[index] == "keyId") | 
					
						
							| 
									
										
										
										
											2020-02-28 11:24:07 +01:00
										 |  |  |             keyId = std::strtoll(value[index].c_str(), nullptr, 10); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if(!keyId) { | 
					
						
							|  |  |  |         logWarning(LOG_GENERAL, "Failed to parse key id for key {}", key); | 
					
						
							|  |  |  |         return 0; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-17 19:37:18 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2020-02-28 11:24:07 +01:00
										 |  |  |         auto entry = new KeyIdCache::CacheEntry{key, keyId, system_clock::now()}; | 
					
						
							|  |  |  |         std::lock_guard elock{this->entry_lock}; | 
					
						
							|  |  |  |         this->entries.emplace_back(entry); | 
					
						
							| 
									
										
										
										
											2019-07-17 19:37:18 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     return 0; | 
					
						
							|  |  |  | } |