/* * Copyright (C) 2004-2015 L2J Server * * This file is part of L2J Server. * * L2J Server 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. * * L2J Server 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 this program. If not, see . */ package com.l2jserver.tools.accountmanager; import java.security.MessageDigest; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.util.Base64; import java.util.Scanner; import com.l2jserver.Config; import com.l2jserver.Server; import com.l2jserver.commons.database.pool.impl.ConnectionFactory; /** * This class SQL Account Manager * @author netimperia */ public class SQLAccountManager { private static String _uname = ""; private static String _pass = ""; private static String _level = ""; private static String _mode = ""; public static void main(String[] args) { Server.serverMode = Server.MODE_LOGINSERVER; Config.load(); try (Scanner _scn = new Scanner(System.in)) { while (true) { System.out.println("Please choose an option"); System.out.println(); System.out.println("1 - Create new account or update existing one (change pass and access level)"); System.out.println("2 - Change access level"); System.out.println("3 - Delete existing account"); System.out.println("4 - List accounts and access levels"); System.out.println("5 - Exit"); while (!(_mode.equals("1") || _mode.equals("2") || _mode.equals("3") || _mode.equals("4") || _mode.equals("5"))) { System.out.print("Your choice: "); _mode = _scn.next(); } if (_mode.equals("1") || _mode.equals("2") || _mode.equals("3")) { while (_uname.trim().length() == 0) { System.out.print("Username: "); _uname = _scn.next().toLowerCase(); } if (_mode.equals("1")) { while (_pass.trim().length() == 0) { System.out.print("Password: "); _pass = _scn.next(); } } if (_mode.equals("1") || _mode.equals("2")) { while (_level.trim().length() == 0) { System.out.print("Access level: "); _level = _scn.next(); } } } if (_mode.equals("1")) { // Add or Update addOrUpdateAccount(_uname.trim(), _pass.trim(), _level.trim()); } else if (_mode.equals("2")) { // Change Level changeAccountLevel(_uname.trim(), _level.trim()); } else if (_mode.equals("3")) { // Delete System.out.print("WARNING: This will not delete the gameserver data (characters, items, etc..)"); System.out.print(" it will only delete the account login server data."); System.out.println(); System.out.print("Do you really want to delete this account? Y/N: "); String yesno = _scn.next(); if ((yesno != null) && yesno.equalsIgnoreCase("Y")) { deleteAccount(_uname.trim()); } else { System.out.println("Deletion cancelled."); } } else if (_mode.equals("4")) { // List _mode = ""; System.out.println(); System.out.println("Please choose a listing mode"); System.out.println(); System.out.println("1 - Banned accounts only (accessLevel < 0)"); System.out.println("2 - GM/privileged accounts (accessLevel > 0"); System.out.println("3 - Regular accounts only (accessLevel = 0)"); System.out.println("4 - List all"); while (!(_mode.equals("1") || _mode.equals("2") || _mode.equals("3") || _mode.equals("4"))) { System.out.print("Your choice: "); _mode = _scn.next(); } System.out.println(); printAccInfo(_mode); } else if (_mode.equals("5")) { System.exit(0); } _uname = ""; _pass = ""; _level = ""; _mode = ""; System.out.println(); } } } private static void printAccInfo(String m) { int count = 0; String q = "SELECT login, accessLevel FROM accounts "; if (m.equals("1")) { q = q.concat("WHERE accessLevel < 0"); } else if (m.equals("2")) { q = q.concat("WHERE accessLevel > 0"); } else if (m.equals("3")) { q = q.concat("WHERE accessLevel = 0"); } q = q.concat(" ORDER BY login ASC"); try (Connection con = ConnectionFactory.getInstance().getConnection(); PreparedStatement ps = con.prepareStatement(q); ResultSet rset = ps.executeQuery()) { while (rset.next()) { System.out.println(rset.getString("login") + " -> " + rset.getInt("accessLevel")); count++; } System.out.println("Displayed accounts: " + count); } catch (SQLException e) { System.out.println("There was error while displaying accounts:"); System.out.println(e.getMessage()); } } private static void addOrUpdateAccount(String account, String password, String level) { try (Connection con = ConnectionFactory.getInstance().getConnection(); PreparedStatement ps = con.prepareStatement("REPLACE accounts(login, password, accessLevel) VALUES (?, ?, ?)")) { MessageDigest md = MessageDigest.getInstance("SHA"); byte[] newPassword; newPassword = password.getBytes("UTF-8"); newPassword = md.digest(newPassword); ps.setString(1, account); ps.setString(2, Base64.getEncoder().encodeToString(newPassword)); ps.setString(3, level); if (ps.executeUpdate() > 0) { System.out.println("Account " + account + " has been created or updated"); } else { System.out.println("Account " + account + " does not exist"); } } catch (Exception e) { System.out.println("There was error while adding/updating account:"); System.out.println(e.getMessage()); } } private static void changeAccountLevel(String account, String level) { try (Connection con = ConnectionFactory.getInstance().getConnection(); PreparedStatement ps = con.prepareStatement("UPDATE accounts SET accessLevel = ? WHERE login = ?")) { ps.setString(1, level); ps.setString(2, account); if (ps.executeUpdate() > 0) { System.out.println("Account " + account + " has been updated"); } else { System.out.println("Account " + account + " does not exist"); } } catch (SQLException e) { System.out.println("There was error while updating account:"); System.out.println(e.getMessage()); } } private static void deleteAccount(String account) { try (Connection con = ConnectionFactory.getInstance().getConnection(); PreparedStatement ps = con.prepareStatement("DELETE FROM accounts WHERE login = ?")) { ps.setString(1, account); if (ps.executeUpdate() > 0) { System.out.println("Account " + account + " has been deleted"); } else { System.out.println("Account " + account + " does not exist"); } } catch (SQLException e) { System.out.println("There was error while deleting account:"); System.out.println(e.getMessage()); } } }