2023-07-20 22:07:47 +02:00
|
|
|
import { inject, injectable } from "tsyringe";
|
2023-10-19 19:21:17 +02:00
|
|
|
|
|
|
|
import { ProfileHelper } from "@spt-aki/helpers/ProfileHelper";
|
|
|
|
import { ConfigTypes } from "@spt-aki/models/enums/ConfigTypes";
|
|
|
|
import { GiftSenderType } from "@spt-aki/models/enums/GiftSenderType";
|
|
|
|
import { GiftSentResult } from "@spt-aki/models/enums/GiftSentResult";
|
|
|
|
import { MessageType } from "@spt-aki/models/enums/MessageType";
|
|
|
|
import { Traders } from "@spt-aki/models/enums/Traders";
|
|
|
|
import { Gift, IGiftsConfig } from "@spt-aki/models/spt/config/IGiftsConfig";
|
|
|
|
import { ISendMessageDetails } from "@spt-aki/models/spt/dialog/ISendMessageDetails";
|
|
|
|
import { ILogger } from "@spt-aki/models/spt/utils/ILogger";
|
|
|
|
import { ConfigServer } from "@spt-aki/servers/ConfigServer";
|
|
|
|
import { MailSendService } from "@spt-aki/services/MailSendService";
|
|
|
|
import { HashUtil } from "@spt-aki/utils/HashUtil";
|
|
|
|
import { TimeUtil } from "@spt-aki/utils/TimeUtil";
|
2023-07-20 22:07:47 +02:00
|
|
|
|
|
|
|
@injectable()
|
|
|
|
export class GiftService
|
|
|
|
{
|
2023-07-21 19:08:32 +02:00
|
|
|
protected giftConfig: IGiftsConfig;
|
2023-07-20 22:07:47 +02:00
|
|
|
|
|
|
|
constructor(
|
|
|
|
@inject("WinstonLogger") protected logger: ILogger,
|
2023-07-21 19:08:32 +02:00
|
|
|
@inject("MailSendService") protected mailSendService: MailSendService,
|
|
|
|
@inject("HashUtil") protected hashUtil: HashUtil,
|
|
|
|
@inject("TimeUtil") protected timeUtil: TimeUtil,
|
|
|
|
@inject("ProfileHelper") protected profileHelper: ProfileHelper,
|
2023-11-16 22:42:06 +01:00
|
|
|
@inject("ConfigServer") protected configServer: ConfigServer,
|
2023-07-20 22:07:47 +02:00
|
|
|
)
|
|
|
|
{
|
2023-07-21 19:08:32 +02:00
|
|
|
this.giftConfig = this.configServer.getConfig(ConfigTypes.GIFTS);
|
2023-07-20 22:07:47 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2023-07-21 19:08:32 +02:00
|
|
|
* Does a gift with a specific ID exist in db
|
|
|
|
* @param giftId Gift id to check for
|
|
|
|
* @returns True if it exists in db
|
2023-07-20 22:07:47 +02:00
|
|
|
*/
|
2023-07-21 19:08:32 +02:00
|
|
|
public giftExists(giftId: string): boolean
|
2023-07-20 22:07:47 +02:00
|
|
|
{
|
2023-07-21 19:08:32 +02:00
|
|
|
return !!this.giftConfig.gifts[giftId];
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Send player a gift from a range of sources
|
|
|
|
* @param playerId Player to send gift to / sessionId
|
|
|
|
* @param giftId Id of gift in configs/gifts.json to send player
|
|
|
|
* @returns outcome of sending gift to player
|
|
|
|
*/
|
|
|
|
public sendGiftToPlayer(playerId: string, giftId: string): GiftSentResult
|
|
|
|
{
|
|
|
|
const giftData = this.giftConfig.gifts[giftId];
|
|
|
|
if (!giftData)
|
|
|
|
{
|
|
|
|
return GiftSentResult.FAILED_GIFT_DOESNT_EXIST;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (this.profileHelper.playerHasRecievedGift(playerId, giftId))
|
|
|
|
{
|
|
|
|
this.logger.debug(`Player already recieved gift: ${giftId}`);
|
2023-07-20 22:29:27 +02:00
|
|
|
|
2023-07-21 19:08:32 +02:00
|
|
|
return GiftSentResult.FAILED_GIFT_ALREADY_RECEIVED;
|
|
|
|
}
|
2023-07-20 22:29:27 +02:00
|
|
|
|
2023-08-03 13:25:09 +02:00
|
|
|
if (giftData.items?.length > 0 && !giftData.collectionTimeHours)
|
|
|
|
{
|
|
|
|
this.logger.warning(`Gift ${giftId} has items but no collection time limit, defaulting to 48 hours`);
|
|
|
|
}
|
|
|
|
|
2023-07-21 19:08:32 +02:00
|
|
|
// Handle system messsages
|
|
|
|
if (giftData.sender === GiftSenderType.SYSTEM)
|
|
|
|
{
|
2023-08-09 15:22:16 +02:00
|
|
|
// Has a localisable text id to send to player
|
|
|
|
if (giftData.localeTextId)
|
|
|
|
{
|
|
|
|
this.mailSendService.sendLocalisedSystemMessageToPlayer(
|
|
|
|
playerId,
|
|
|
|
giftData.localeTextId,
|
|
|
|
giftData.items,
|
2023-12-07 21:16:04 +01:00
|
|
|
giftData.profileChangeEvents,
|
2023-11-16 22:42:06 +01:00
|
|
|
this.timeUtil.getHoursAsSeconds(giftData.collectionTimeHours),
|
|
|
|
);
|
2023-08-09 15:22:16 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
this.mailSendService.sendSystemMessageToPlayer(
|
|
|
|
playerId,
|
|
|
|
giftData.messageText,
|
|
|
|
giftData.items,
|
2023-11-16 22:42:06 +01:00
|
|
|
this.timeUtil.getHoursAsSeconds(giftData.collectionTimeHours),
|
|
|
|
);
|
2023-08-09 15:22:16 +02:00
|
|
|
}
|
2023-07-21 19:08:32 +02:00
|
|
|
}
|
|
|
|
// Handle user messages
|
|
|
|
else if (giftData.sender === GiftSenderType.USER)
|
|
|
|
{
|
|
|
|
this.mailSendService.sendUserMessageToPlayer(
|
|
|
|
playerId,
|
|
|
|
giftData.senderDetails,
|
|
|
|
giftData.messageText,
|
|
|
|
giftData.items,
|
2023-11-16 22:42:06 +01:00
|
|
|
this.timeUtil.getHoursAsSeconds(giftData.collectionTimeHours),
|
|
|
|
);
|
2023-07-21 19:08:32 +02:00
|
|
|
}
|
|
|
|
else if (giftData.sender === GiftSenderType.TRADER)
|
|
|
|
{
|
2023-07-23 00:23:42 +02:00
|
|
|
if (giftData.localeTextId)
|
|
|
|
{
|
|
|
|
this.mailSendService.sendLocalisedNpcMessageToPlayer(
|
|
|
|
playerId,
|
|
|
|
giftData.trader,
|
|
|
|
MessageType.MESSAGE_WITH_ITEMS,
|
|
|
|
giftData.localeTextId,
|
|
|
|
giftData.items,
|
2023-11-16 22:42:06 +01:00
|
|
|
this.timeUtil.getHoursAsSeconds(giftData.collectionTimeHours),
|
|
|
|
);
|
2023-07-23 00:23:42 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
this.mailSendService.sendDirectNpcMessageToPlayer(
|
|
|
|
playerId,
|
|
|
|
giftData.trader,
|
|
|
|
MessageType.MESSAGE_WITH_ITEMS,
|
|
|
|
giftData.messageText,
|
|
|
|
giftData.items,
|
2023-11-16 22:42:06 +01:00
|
|
|
this.timeUtil.getHoursAsSeconds(giftData.collectionTimeHours),
|
|
|
|
);
|
|
|
|
}
|
2023-07-21 19:08:32 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// TODO: further split out into different message systems like above SYSTEM method
|
|
|
|
// Trader / ragfair
|
|
|
|
const details: ISendMessageDetails = {
|
|
|
|
recipientId: playerId,
|
|
|
|
sender: this.getMessageType(giftData),
|
2024-01-06 14:49:48 +01:00
|
|
|
senderDetails: {
|
|
|
|
_id: this.getSenderId(giftData),
|
|
|
|
aid: 1234567, // TODO - pass proper aid value
|
|
|
|
Info: null },
|
2023-07-21 19:08:32 +02:00
|
|
|
messageText: giftData.messageText,
|
|
|
|
items: giftData.items,
|
2023-11-16 22:42:06 +01:00
|
|
|
itemsMaxStorageLifetimeSeconds: this.timeUtil.getHoursAsSeconds(giftData.collectionTimeHours),
|
2023-07-21 19:08:32 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
if (giftData.trader)
|
|
|
|
{
|
|
|
|
details.trader = giftData.trader;
|
|
|
|
}
|
|
|
|
|
|
|
|
this.mailSendService.sendMessageToPlayer(details);
|
2023-11-16 22:42:06 +01:00
|
|
|
}
|
2023-07-21 19:08:32 +02:00
|
|
|
|
|
|
|
this.profileHelper.addGiftReceivedFlagToProfile(playerId, giftId);
|
|
|
|
|
|
|
|
return GiftSentResult.SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get sender id based on gifts sender type enum
|
|
|
|
* @param giftData Gift to send player
|
|
|
|
* @returns trader/user/system id
|
|
|
|
*/
|
|
|
|
protected getSenderId(giftData: Gift): string
|
|
|
|
{
|
|
|
|
if (giftData.sender === GiftSenderType.TRADER)
|
|
|
|
{
|
2023-07-23 00:23:42 +02:00
|
|
|
return Traders[giftData.trader];
|
2023-07-21 19:08:32 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if (giftData.sender === GiftSenderType.USER)
|
|
|
|
{
|
|
|
|
return giftData.senderId;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Convert GiftSenderType into a dialog MessageType
|
|
|
|
* @param giftData Gift to send player
|
|
|
|
* @returns MessageType enum value
|
|
|
|
*/
|
|
|
|
protected getMessageType(giftData: Gift): MessageType
|
|
|
|
{
|
|
|
|
switch (giftData.sender)
|
|
|
|
{
|
|
|
|
case GiftSenderType.SYSTEM:
|
|
|
|
return MessageType.SYSTEM_MESSAGE;
|
|
|
|
case GiftSenderType.TRADER:
|
|
|
|
return MessageType.NPC_TRADER;
|
|
|
|
case GiftSenderType.USER:
|
|
|
|
return MessageType.USER_MESSAGE;
|
|
|
|
default:
|
|
|
|
this.logger.error(`Gift message type: ${giftData.sender} not handled`);
|
|
|
|
break;
|
|
|
|
}
|
2023-07-20 22:07:47 +02:00
|
|
|
}
|
2023-07-23 00:23:42 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Prapor sends gifts to player for first week after profile creation
|
|
|
|
* @param sessionId Player id
|
|
|
|
* @param day What day to give gift for
|
|
|
|
*/
|
|
|
|
public sendPraporStartingGift(sessionId: string, day: number): void
|
|
|
|
{
|
2023-11-16 22:42:06 +01:00
|
|
|
switch (day)
|
2023-07-23 00:23:42 +02:00
|
|
|
{
|
|
|
|
case 1:
|
2023-07-25 12:17:54 +02:00
|
|
|
if (this.profileHelper.playerHasRecievedGift(sessionId, "PraporGiftDay1"))
|
|
|
|
{
|
|
|
|
this.sendGiftToPlayer(sessionId, "PraporGiftDay1");
|
|
|
|
}
|
2023-07-23 00:23:42 +02:00
|
|
|
break;
|
|
|
|
case 2:
|
2023-07-25 12:17:54 +02:00
|
|
|
if (this.profileHelper.playerHasRecievedGift(sessionId, "PraporGiftDay2"))
|
|
|
|
{
|
|
|
|
this.sendGiftToPlayer(sessionId, "PraporGiftDay2");
|
|
|
|
}
|
2023-07-23 00:23:42 +02:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2023-11-16 22:42:06 +01:00
|
|
|
}
|