Save new chr to PG (doesn't work yet because no account)
This commit is contained in:
@@ -1,19 +1,28 @@
|
||||
package client.creator;
|
||||
|
||||
import client.CharacterStats;
|
||||
import client.Job;
|
||||
import client.inventory.Item;
|
||||
import constants.id.ItemId;
|
||||
import constants.id.MapId;
|
||||
import database.PgDatabaseConnection;
|
||||
import database.character.CharacterRepository;
|
||||
|
||||
public class CharacterCreator {
|
||||
private final PgDatabaseConnection connection;
|
||||
private final CharacterRepository chrRepository;
|
||||
|
||||
public CharacterCreator(CharacterRepository chrRepository) {
|
||||
public CharacterCreator(PgDatabaseConnection connection, CharacterRepository chrRepository) {
|
||||
this.connection = connection;
|
||||
this.chrRepository = chrRepository;
|
||||
}
|
||||
|
||||
public boolean createNew(NewCharacterSpec spec, int accountId, int worldId) {
|
||||
int mapId = getStartingMap(spec.type());
|
||||
CharacterStats stats = getStarterStats(spec, accountId, worldId);
|
||||
|
||||
connection.getHandle().useTransaction(h -> {
|
||||
// chrRepository.insert(h, stats); // TODO: account needs to exist first
|
||||
});
|
||||
Item guide = getStarterGuide(spec.type());
|
||||
// TODO, save:
|
||||
// - character
|
||||
@@ -25,6 +34,51 @@ public class CharacterCreator {
|
||||
return false;
|
||||
}
|
||||
|
||||
private CharacterStats getStarterStats(NewCharacterSpec spec, int accountId, int worldId) {
|
||||
return CharacterStats.builder()
|
||||
.account(accountId)
|
||||
.world(worldId)
|
||||
.name(spec.name())
|
||||
.job(getJob(spec.type()).getId())
|
||||
.gender(spec.gender())
|
||||
.skin(spec.skin().getId())
|
||||
.hair(spec.hair() + spec.hairColor())
|
||||
.face(spec.face())
|
||||
.mapId(getStartingMap(spec.type()))
|
||||
.spawnPortal(0)
|
||||
.level(StarterStats.LEVEL)
|
||||
.exp(0)
|
||||
.str(StarterStats.STR)
|
||||
.dex(StarterStats.DEX)
|
||||
.int_(StarterStats.INT)
|
||||
.luk(StarterStats.LUK)
|
||||
.maxHp(StarterStats.HP)
|
||||
.hp(StarterStats.HP)
|
||||
.maxMp(StarterStats.MP)
|
||||
.mp(StarterStats.MP)
|
||||
.fame(0)
|
||||
.ap(0)
|
||||
.sp(0)
|
||||
.buddyCapacity(StarterStats.BUDDY_CAPACITY)
|
||||
.equipSlots(StarterStats.INVENTORY_SLOTS)
|
||||
.useSlots(StarterStats.INVENTORY_SLOTS)
|
||||
.setupSlots(StarterStats.INVENTORY_SLOTS)
|
||||
.etcSlots(StarterStats.INVENTORY_SLOTS)
|
||||
.gmLevel(StarterStats.GM_LEVEL)
|
||||
.gachaExp(0)
|
||||
.hpMpApUsed(0)
|
||||
.party(null)
|
||||
.build();
|
||||
}
|
||||
|
||||
private Job getJob(JobType type) {
|
||||
return switch (type) {
|
||||
case ADVENTURER -> Job.BEGINNER;
|
||||
case KNIGHT_OF_CYGNUS -> Job.NOBLESSE;
|
||||
case ARAN -> Job.LEGEND;
|
||||
};
|
||||
}
|
||||
|
||||
private int getStartingMap(JobType type) {
|
||||
return switch (type) {
|
||||
case ADVENTURER -> MapId.MUSHROOM_TOWN;
|
||||
|
||||
Reference in New Issue
Block a user