123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266 |
- /*
- * 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 <http://www.gnu.org/licenses/>.
- */
- 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());
- }
- }
- }
|