mirror of
https://github.com/correl/mage.git
synced 2025-01-11 19:13:02 +00:00
[refactor] replaced JDBC implementation of logging with OrmLite
This commit is contained in:
parent
d44e3f1190
commit
01eee3995c
6 changed files with 119 additions and 314 deletions
|
@ -1,79 +1,52 @@
|
||||||
package mage.db;
|
package mage.db;
|
||||||
|
|
||||||
import mage.db.model.Feedback;
|
import com.j256.ormlite.dao.Dao;
|
||||||
import mage.db.model.Log;
|
import com.j256.ormlite.dao.DaoManager;
|
||||||
import org.apache.log4j.Logger;
|
import com.j256.ormlite.jdbc.JdbcConnectionSource;
|
||||||
|
import com.j256.ormlite.support.ConnectionSource;
|
||||||
|
import com.j256.ormlite.table.TableUtils;
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.sql.*;
|
import java.sql.SQLException;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import mage.db.model.Feedback;
|
||||||
|
import mage.db.model.Log;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author noxx
|
* @author noxx, North
|
||||||
*/
|
*/
|
||||||
public enum EntityManager implements Storage {
|
public enum EntityManager implements Storage {
|
||||||
|
|
||||||
instance;
|
instance;
|
||||||
|
|
||||||
private static final Logger log = Logger.getLogger(EntityManager.class);
|
private static final String LOG_JDBC_URL = "jdbc:sqlite:db/mage.db";
|
||||||
|
private static final String FEEDBACK_JDBC_URL = "jdbc:sqlite:db/feedback.db";
|
||||||
|
|
||||||
private static final String MAGE_JDBC_URL = "jdbc:sqlite:db/mage.db";
|
private Dao<Log, Object> logDao;
|
||||||
|
private Dao<Feedback, Object> feedbackDao;
|
||||||
|
|
||||||
private static final String MAGE_JDBC_URL_FEEDBACK_DB = "jdbc:sqlite:db/feedback.db";
|
private EntityManager() {
|
||||||
|
File file = new File("db");
|
||||||
private static String QUERY_SAVE_LOG = "insert into logs values (?, ?, ?, ?, ?, ?, ?, ?)";
|
if (!file.exists()) {
|
||||||
private static String QUERY_GET_ALL_LOGS = "select * from logs";
|
file.mkdirs();
|
||||||
|
}
|
||||||
private static String QUERY_SAVE_FEEDBACK = "insert into feedbacks values (?, ?, ?, ?, ?, ?, ?, ?)";
|
|
||||||
private static String QUERY_GET_ALL_FEEDBACKS = "select * from feedbacks";
|
|
||||||
|
|
||||||
static {
|
|
||||||
try {
|
try {
|
||||||
init();
|
ConnectionSource logConnectionSource = new JdbcConnectionSource(LOG_JDBC_URL);
|
||||||
initFeedbackDB();
|
TableUtils.createTableIfNotExists(logConnectionSource, Log.class);
|
||||||
} catch (Exception e) {
|
logDao = DaoManager.createDao(logConnectionSource, Log.class);
|
||||||
log.fatal(e);
|
|
||||||
e.printStackTrace();
|
ConnectionSource feedbackConnectionSource = new JdbcConnectionSource(FEEDBACK_JDBC_URL);
|
||||||
|
TableUtils.createTableIfNotExists(feedbackConnectionSource, Feedback.class);
|
||||||
|
feedbackDao = DaoManager.createDao(feedbackConnectionSource, Feedback.class);
|
||||||
|
} catch (SQLException ex) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static EntityManager getInstance() {
|
@Override
|
||||||
return instance;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Inserts log entry to DB.
|
|
||||||
*
|
|
||||||
* @param key
|
|
||||||
* @param date
|
|
||||||
* @param args
|
|
||||||
* @throws Exception
|
|
||||||
*/
|
|
||||||
public void insertLog(String key, java.util.Date date, String... args) throws SQLException {
|
public void insertLog(String key, java.util.Date date, String... args) throws SQLException {
|
||||||
Connection conn = DriverManager.getConnection(MAGE_JDBC_URL);
|
Log logEntity = new Log(key, date);
|
||||||
|
logEntity.setArguments(args);
|
||||||
try {
|
logDao.create(logEntity);
|
||||||
PreparedStatement prep = conn.prepareStatement(QUERY_SAVE_LOG);
|
|
||||||
|
|
||||||
prep.setString(1, key);
|
|
||||||
prep.setDate(2, new java.sql.Date(date.getTime()));
|
|
||||||
|
|
||||||
int index = 3;
|
|
||||||
for (String arg : args) {
|
|
||||||
if (index > 8) break;
|
|
||||||
prep.setString(index++, arg);
|
|
||||||
}
|
|
||||||
|
|
||||||
prep.execute();
|
|
||||||
|
|
||||||
} finally {
|
|
||||||
try {
|
|
||||||
if (conn != null) conn.close();
|
|
||||||
} catch (Exception e) {
|
|
||||||
// swallow
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -83,256 +56,27 @@ public enum EntityManager implements Storage {
|
||||||
@Override
|
@Override
|
||||||
public List<Log> getAllLogs() {
|
public List<Log> getAllLogs() {
|
||||||
List<Log> logs = new ArrayList<Log>();
|
List<Log> logs = new ArrayList<Log>();
|
||||||
|
|
||||||
try {
|
try {
|
||||||
Connection conn = DriverManager.getConnection(MAGE_JDBC_URL);
|
logs = logDao.queryForAll();
|
||||||
try {
|
} catch (SQLException ex) {
|
||||||
Statement stat = conn.createStatement();
|
|
||||||
ResultSet rs = stat.executeQuery(QUERY_GET_ALL_LOGS);
|
|
||||||
while (rs.next()) {
|
|
||||||
Log log = new Log(rs.getString(1), rs.getDate(2));
|
|
||||||
List<String> args = new ArrayList<String>();
|
|
||||||
for (int index = 0; index < 6; index++) {
|
|
||||||
String arg = rs.getString(3 + index);
|
|
||||||
if (arg == null) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
args.add(arg);
|
|
||||||
}
|
|
||||||
log.setArguments(args);
|
|
||||||
logs.add(log);
|
|
||||||
}
|
|
||||||
rs.close();
|
|
||||||
} finally {
|
|
||||||
try {
|
|
||||||
if (conn != null) conn.close();
|
|
||||||
} catch (Exception e) {
|
|
||||||
// swallow
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} catch (SQLException e) {
|
|
||||||
log.fatal("SQL Exception: ", e);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return logs;
|
return logs;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
@Override
|
||||||
* Inserts feedback entry to DB.
|
|
||||||
*
|
|
||||||
*
|
|
||||||
* @param username
|
|
||||||
* @param title
|
|
||||||
* @param type
|
|
||||||
* @param message
|
|
||||||
* @param email
|
|
||||||
* @param host
|
|
||||||
* @param created
|
|
||||||
* @throws SQLException
|
|
||||||
*/
|
|
||||||
public void insertFeedback(String username, String title, String type, String message, String email, String host, java.util.Date created) throws SQLException {
|
public void insertFeedback(String username, String title, String type, String message, String email, String host, java.util.Date created) throws SQLException {
|
||||||
Connection conn = DriverManager.getConnection(MAGE_JDBC_URL_FEEDBACK_DB);
|
Feedback feedback = new Feedback(username, title, type, message, email, host, created, "new");
|
||||||
|
feedbackDao.create(feedback);
|
||||||
try {
|
|
||||||
PreparedStatement prep = conn.prepareStatement(QUERY_SAVE_FEEDBACK);
|
|
||||||
|
|
||||||
prep.setString(1, username);
|
|
||||||
prep.setString(2, title);
|
|
||||||
prep.setString(3, type);
|
|
||||||
prep.setString(4, message);
|
|
||||||
prep.setString(5, email);
|
|
||||||
prep.setString(6, host);
|
|
||||||
prep.setDate(7, new java.sql.Date(created.getTime()));
|
|
||||||
prep.setString(8, "new");
|
|
||||||
|
|
||||||
prep.execute();
|
|
||||||
} finally {
|
|
||||||
try {
|
|
||||||
if (conn != null) conn.close();
|
|
||||||
} catch (Exception e) {
|
|
||||||
// swallow
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Get all feedbacks
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
@Override
|
@Override
|
||||||
public List<Feedback> getAllFeedbacks() {
|
public List<Feedback> getAllFeedbacks() {
|
||||||
List<Feedback> feedbacks = new ArrayList<Feedback>();
|
List<Feedback> feedbacks = new ArrayList<Feedback>();
|
||||||
|
|
||||||
try {
|
try {
|
||||||
Connection conn = DriverManager.getConnection(MAGE_JDBC_URL_FEEDBACK_DB);
|
feedbacks = feedbackDao.queryForAll();
|
||||||
try {
|
} catch (SQLException ex) {
|
||||||
Statement stat = conn.createStatement();
|
|
||||||
ResultSet rs = stat.executeQuery(QUERY_GET_ALL_FEEDBACKS);
|
|
||||||
while (rs.next()) {
|
|
||||||
Feedback feedback = new Feedback();
|
|
||||||
|
|
||||||
feedback.setUsername(rs.getString(1));
|
|
||||||
feedback.setTitle(rs.getString(2));
|
|
||||||
feedback.setType(rs.getString(3));
|
|
||||||
feedback.setMessage(rs.getString(4));
|
|
||||||
feedback.setEmail(rs.getString(5));
|
|
||||||
feedback.setHost(rs.getString(6));
|
|
||||||
feedback.setCreatedDate(rs.getDate(7));
|
|
||||||
feedback.setStatus(rs.getString(8));
|
|
||||||
|
|
||||||
feedbacks.add(feedback);
|
|
||||||
}
|
|
||||||
rs.close();
|
|
||||||
} finally {
|
|
||||||
try {
|
|
||||||
if (conn != null) conn.close();
|
|
||||||
} catch (Exception e) {
|
|
||||||
// swallow
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} catch (SQLException e) {
|
|
||||||
log.fatal("SQL Exception: ", e);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return feedbacks;
|
return feedbacks;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Inits database. Creates tables if they don't exist.
|
|
||||||
*
|
|
||||||
* @throws Exception
|
|
||||||
*/
|
|
||||||
protected static void init() throws Exception {
|
|
||||||
Class.forName("org.sqlite.JDBC");
|
|
||||||
checkDBFolderExistance();
|
|
||||||
Connection conn = DriverManager.getConnection(MAGE_JDBC_URL);
|
|
||||||
try {
|
|
||||||
Statement stat = conn.createStatement();
|
|
||||||
stat.executeUpdate("create table if not exists users (login, password, status);");
|
|
||||||
stat.executeUpdate("create table if not exists logs (key, created_dt, arg0, arg1, arg2, arg3, arg4, arg5);");
|
|
||||||
} finally {
|
|
||||||
try {
|
|
||||||
conn.close();
|
|
||||||
} catch (Exception e) {
|
|
||||||
// swallow
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
protected static void initFeedbackDB() throws Exception {
|
|
||||||
Class.forName("org.sqlite.JDBC");
|
|
||||||
checkDBFolderExistance();
|
|
||||||
Connection conn = DriverManager.getConnection(MAGE_JDBC_URL_FEEDBACK_DB);
|
|
||||||
try {
|
|
||||||
Statement stat = conn.createStatement();
|
|
||||||
stat.executeUpdate("create table if not exists feedbacks (username, title, type, message, email, host, created_dt, status);");
|
|
||||||
} finally {
|
|
||||||
try {
|
|
||||||
conn.close();
|
|
||||||
} catch (Exception e) {
|
|
||||||
// swallow
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Reinits database. Drops all tables and then creates them from scratch.
|
|
||||||
* BE CAREFUL! THIS METHOD WILL DESTROY ALL DATA.
|
|
||||||
*
|
|
||||||
* @throws Exception
|
|
||||||
*/
|
|
||||||
public static void reinit() throws Exception {
|
|
||||||
Class.forName("org.sqlite.JDBC");
|
|
||||||
checkDBFolderExistance();
|
|
||||||
Connection conn = DriverManager.getConnection(MAGE_JDBC_URL);
|
|
||||||
try {
|
|
||||||
Statement stat = conn.createStatement();
|
|
||||||
stat.executeUpdate("drop table users;");
|
|
||||||
init();
|
|
||||||
} finally {
|
|
||||||
try {
|
|
||||||
conn.close();
|
|
||||||
} catch (Exception e) {
|
|
||||||
// swallow
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates folders for Mage sqlite db.
|
|
||||||
*/
|
|
||||||
protected static void checkDBFolderExistance() {
|
|
||||||
File file = new File("db");
|
|
||||||
if (!file.exists()) {
|
|
||||||
file.mkdirs();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Tests DB with base operations.
|
|
||||||
*
|
|
||||||
* @throws Exception
|
|
||||||
*/
|
|
||||||
public void testDB() throws Exception {
|
|
||||||
|
|
||||||
Connection conn = DriverManager.getConnection(MAGE_JDBC_URL);
|
|
||||||
|
|
||||||
try {
|
|
||||||
Statement stat = conn.createStatement();
|
|
||||||
|
|
||||||
ResultSet rs = stat.executeQuery("select * from users where login = 'testtest';");
|
|
||||||
|
|
||||||
if (rs.next()) {
|
|
||||||
checkTestUser(conn, stat);
|
|
||||||
} else {
|
|
||||||
log.debug("[DBTest] creating test user...");
|
|
||||||
PreparedStatement prep = conn.prepareStatement("insert into users values (?, ?, ?);");
|
|
||||||
|
|
||||||
prep.setString(1, "testtest");
|
|
||||||
prep.setString(2, "12345");
|
|
||||||
prep.setString(3, "disabled");
|
|
||||||
|
|
||||||
prep.execute();
|
|
||||||
|
|
||||||
log.debug("[DBTest] creating test user [OK]");
|
|
||||||
|
|
||||||
checkTestUser(conn, stat);
|
|
||||||
}
|
|
||||||
|
|
||||||
rs.close();
|
|
||||||
} finally {
|
|
||||||
try {
|
|
||||||
if (conn != null) conn.close();
|
|
||||||
} catch (Exception e) {
|
|
||||||
// swallow
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Checks test user existence and its parameters.
|
|
||||||
*
|
|
||||||
* @param conn
|
|
||||||
* @param stat
|
|
||||||
* @throws Exception
|
|
||||||
*/
|
|
||||||
private void checkTestUser(Connection conn, Statement stat) throws Exception {
|
|
||||||
ResultSet rs = stat.executeQuery("select * from users where login = 'testtest';");
|
|
||||||
if (rs.next()) {
|
|
||||||
log.debug("[DBTest] checking test user [OK]");
|
|
||||||
if (rs.getString("login").equals("testtest") && rs.getString("password").equals("12345") && rs.getString("status").equals("disabled")) {
|
|
||||||
log.debug("[DBTest] checking test user parameters [OK]");
|
|
||||||
} else {
|
|
||||||
log.debug("[DBTest] checking test user parameters [ERROR]");
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
log.debug("[DBTest] checking test user [ERROR]");
|
|
||||||
log.debug("[DBTest] couldn't find test user");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void main(String[] args) throws Exception {
|
|
||||||
//EntityManager.getInstance().reinit();
|
|
||||||
EntityManager.getInstance().testDB();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,7 +15,6 @@ public class EntityManagerTest {
|
||||||
private static DateFormat timeFormatter = SimpleDateFormat.getTimeInstance(SimpleDateFormat.FULL);
|
private static DateFormat timeFormatter = SimpleDateFormat.getTimeInstance(SimpleDateFormat.FULL);
|
||||||
|
|
||||||
public static void main(String[] args) throws Exception {
|
public static void main(String[] args) throws Exception {
|
||||||
EntityManager.instance.testDB();
|
|
||||||
List<Log> logs = EntityManager.instance.getAllLogs();
|
List<Log> logs = EntityManager.instance.getAllLogs();
|
||||||
System.out.println("logs found: " + logs.size());
|
System.out.println("logs found: " + logs.size());
|
||||||
for (Log log : logs) {
|
for (Log log : logs) {
|
||||||
|
|
|
@ -10,7 +10,6 @@ import java.util.*;
|
||||||
public class Statistics {
|
public class Statistics {
|
||||||
|
|
||||||
public static void main(String[] args) throws Exception {
|
public static void main(String[] args) throws Exception {
|
||||||
EntityManager.instance.testDB();
|
|
||||||
List<Log> logs = EntityManager.instance.getAllLogs();
|
List<Log> logs = EntityManager.instance.getAllLogs();
|
||||||
System.out.println("logs found: " + logs.size());
|
System.out.println("logs found: " + logs.size());
|
||||||
|
|
||||||
|
|
|
@ -1,28 +1,48 @@
|
||||||
package mage.db.model;
|
package mage.db.model;
|
||||||
|
|
||||||
|
import com.j256.ormlite.field.DatabaseField;
|
||||||
|
import com.j256.ormlite.table.DatabaseTable;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Feedback entity.
|
|
||||||
*
|
*
|
||||||
* @author noxx
|
* @author noxx, North
|
||||||
*/
|
*/
|
||||||
|
@DatabaseTable(tableName = "feedbacks")
|
||||||
public class Feedback {
|
public class Feedback {
|
||||||
|
|
||||||
|
@DatabaseField
|
||||||
private String username;
|
private String username;
|
||||||
|
@DatabaseField
|
||||||
private String title;
|
private String title;
|
||||||
|
@DatabaseField
|
||||||
private String type;
|
private String type;
|
||||||
|
@DatabaseField
|
||||||
private String message;
|
private String message;
|
||||||
|
@DatabaseField
|
||||||
private String email;
|
private String email;
|
||||||
|
@DatabaseField
|
||||||
private String host;
|
private String host;
|
||||||
|
@DatabaseField(columnName = "created_dt")
|
||||||
private Date createdDate;
|
private Date createdDate;
|
||||||
|
|
||||||
|
@DatabaseField
|
||||||
private String status;
|
private String status;
|
||||||
|
|
||||||
public Feedback() {
|
public Feedback() {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Feedback(String username, String title, String type, String message, String email, String host, Date createdDate, String status) {
|
||||||
|
this.username = username;
|
||||||
|
this.title = title;
|
||||||
|
this.type = type;
|
||||||
|
this.message = message;
|
||||||
|
this.email = email;
|
||||||
|
this.host = host;
|
||||||
|
this.createdDate = createdDate;
|
||||||
|
this.status = status;
|
||||||
|
}
|
||||||
|
|
||||||
public String getUsername() {
|
public String getUsername() {
|
||||||
return username;
|
return username;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,18 +1,36 @@
|
||||||
package mage.db.model;
|
package mage.db.model;
|
||||||
|
|
||||||
|
import com.j256.ormlite.field.DatabaseField;
|
||||||
|
import com.j256.ormlite.table.DatabaseTable;
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author noxx
|
* @author noxx, North
|
||||||
*/
|
*/
|
||||||
|
@DatabaseTable(tableName = "logs")
|
||||||
public class Log {
|
public class Log {
|
||||||
|
|
||||||
|
@DatabaseField
|
||||||
private String key;
|
private String key;
|
||||||
|
@DatabaseField(columnName = "created_dt")
|
||||||
private Date createdDate;
|
private Date createdDate;
|
||||||
|
@DatabaseField
|
||||||
|
private String arg0;
|
||||||
|
@DatabaseField
|
||||||
|
private String arg1;
|
||||||
|
@DatabaseField
|
||||||
|
private String arg2;
|
||||||
|
@DatabaseField
|
||||||
|
private String arg3;
|
||||||
|
@DatabaseField
|
||||||
|
private String arg4;
|
||||||
|
@DatabaseField
|
||||||
|
private String arg5;
|
||||||
|
|
||||||
private List<String> arguments;
|
public Log() {
|
||||||
|
}
|
||||||
|
|
||||||
public Log(String key, Date createdDate) {
|
public Log(String key, Date createdDate) {
|
||||||
this.key = key;
|
this.key = key;
|
||||||
|
@ -36,10 +54,46 @@ public class Log {
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<String> getArguments() {
|
public List<String> getArguments() {
|
||||||
|
ArrayList<String> arguments = new ArrayList<String>();
|
||||||
|
if (arg0 != null) {
|
||||||
|
arguments.add(arg0);
|
||||||
|
}
|
||||||
|
if (arg1 != null) {
|
||||||
|
arguments.add(arg1);
|
||||||
|
}
|
||||||
|
if (arg2 != null) {
|
||||||
|
arguments.add(arg2);
|
||||||
|
}
|
||||||
|
if (arg3 != null) {
|
||||||
|
arguments.add(arg3);
|
||||||
|
}
|
||||||
|
if (arg4 != null) {
|
||||||
|
arguments.add(arg4);
|
||||||
|
}
|
||||||
|
if (arg5 != null) {
|
||||||
|
arguments.add(arg5);
|
||||||
|
}
|
||||||
return arguments;
|
return arguments;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setArguments(List<String> arguments) {
|
public void setArguments(String... arguments) {
|
||||||
this.arguments = arguments;
|
if (arguments.length > 0) {
|
||||||
|
arg0 = arguments[0];
|
||||||
|
}
|
||||||
|
if (arguments.length > 1) {
|
||||||
|
arg1 = arguments[1];
|
||||||
|
}
|
||||||
|
if (arguments.length > 2) {
|
||||||
|
arg2 = arguments[2];
|
||||||
|
}
|
||||||
|
if (arguments.length > 3) {
|
||||||
|
arg3 = arguments[3];
|
||||||
|
}
|
||||||
|
if (arguments.length > 4) {
|
||||||
|
arg4 = arguments[4];
|
||||||
|
}
|
||||||
|
if (arguments.length > 5) {
|
||||||
|
arg5 = arguments[5];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,11 +0,0 @@
|
||||||
package mage.db.model;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @author noxx
|
|
||||||
*/
|
|
||||||
public class User {
|
|
||||||
|
|
||||||
private String login;
|
|
||||||
|
|
||||||
private String password;
|
|
||||||
}
|
|
Loading…
Reference in a new issue