Raised This Month: $404 Target: $400
 101% 

Dailycredits


Post New Thread Reply   
 
Thread Tools Display Modes
Author Message
szogun
Senior Member
Join Date: Apr 2016
Old 10-12-2018 , 10:41   Dailycredits
Reply With Quote #1

I have a small request for people who have knowledge about coding.
My point is that this plugin can be adapted to another store exactly under the shop core.

PHP Code:
#pragma semicolon 1

#define PLUGIN_AUTHOR "Simon -edit by Nachtfrische"
#define PLUGIN_VERSION "2.2"

#include <sourcemod>
#include <sdktools>
#include <store>
#include <multicolors>

#pragma newdecls required

Database db;
ConVar g_hDailyEnable;
ConVar g_hDailyCredits;
ConVar g_hDailyBonus;
ConVar g_hDailyMax;
ConVar g_hDailyReset;
ConVar g_hDailyInterval;
char CurrentDate[20];
int ConnectTime[MAXPLAYERS 1];

public 
Plugin myinfo 
{
    
name "[Store] Daily Credits"
    
author PLUGIN_AUTHOR
    
description "Daily credits for regular players with MySQL support."
    
version PLUGIN_VERSION
    
url "[email protected]"
};

public 
void OnPluginStart()
{
    
LoadTranslations("dailycredits.phrases");
    
CreateConVar("sm_daily_credits_version"PLUGIN_VERSION"Daily Credits Version"FCVAR_DONTRECORD FCVAR_NOTIFY FCVAR_REPLICATED FCVAR_SPONLY);
    
g_hDailyEnable CreateConVar("sm_daily_credits_enable""1""Enable Daily Credits? 0 = disable, 1 = enable"0true0.0true1.0);
    
g_hDailyCredits CreateConVar("sm_daily_credits_amount""10""Amount of credits you recieve."0true0.0);
    
g_hDailyBonus CreateConVar("sm_daily_credits_bonus""2""Increase / Addition of the credits on consecutive days."0true0.0);
    
g_hDailyMax CreateConVar("sm_daily_credits_max""50""Maximum amount of credits that you can get daily."0true0.0);
    
g_hDailyReset CreateConVar("sm_daily_credits_resetperiod""7""Amount of days after which the streak should reset itself. Set to 0 to disable."0true0.0);
    
g_hDailyInterval CreateConVar("sm_daily_credits_interval""0""Number of minutes required by the player to play on the server before getting daily credits. Set to 0 to immediately give credits upon using !daily."0true0.0);
    
    
AutoExecConfig(true"dailycredits");
    
RegConsoleCmd("sm_daily"Cmd_Daily);
    
RegConsoleCmd("sm_dailies"Cmd_Daily);
    
InitializeDB();
}

public 
void OnClientConnected(int client)
{
    
ConnectTime[client] = GetTime();
}

public 
void OnClientDisconnect(int client)
{
    
ConnectTime[client] = 0;
}

public 
void InitializeDB()
{
    
char Error[255];
    
db SQL_Connect("dailycredits"trueErrorsizeof(Error));
    
SQL_SetCharset(db"utf8");
    if (
db == INVALID_HANDLE)
    {
        
SetFailState(Error);
    }
    
SQL_TQuery(dbSQLErrorCheckCallback"CREATE TABLE IF NOT EXISTS players (steam_id VARCHAR(20) UNIQUE, last_connect INT(12), bonus_amount INT(12));");
}

public 
Action Cmd_Daily(int clientint args)
{
    if (!
GetConVarBool(g_hDailyEnable)) return Plugin_Handled;
    if (!
IsValidClient(client)) return Plugin_Handled;
    if (
GetConVarInt(g_hDailyInterval) > 0)
    {
        
int TimeTillNow 0;
        
TimeTillNow RoundToFloor(float((GetTime() - ConnectTime[client]) / 60));
        if (
TimeTillNow GetConVarInt(g_hDailyInterval))
        {
            
CPrintToChatEx(clientclient"%t""WaitForInterval"GetConVarInt(g_hDailyInterval) - TimeTillNow);
            return 
Plugin_Handled;
        }
    }
    
FormatTime(CurrentDatesizeof(CurrentDate), "%Y%m%d"); // Save current date in variable
    
char steamId[32];
    if (
GetClientAuthId(clientAuthId_Steam2steamIdsizeof(steamId)))
    {
        
char buffer[200];
        
Format(buffersizeof(buffer), "SELECT * FROM players WHERE steam_id = '%s'"steamId);
        
SQL_LockDatabase(db);
        
DBResultSet query SQL_Query(dbbuffer);
        
SQL_UnlockDatabase(db);
        if (
SQL_GetRowCount(query) == 0)
        {
            
delete query;
            
GiveCredits(clienttrue);
        }
        else
        {
            
delete query;
            
GiveCredits(clientfalse);
        }
    }
    else 
LogError("Failed to get Steam ID");
    
    return 
Plugin_Handled;
}

stock void GiveCredits(int clientbool FirstTime)
{
    
char buffer[200];
    
char steamId[32];
    if (
GetClientAuthId(clientAuthId_Steam2steamIdsizeof(steamId)))
    {
        if (
FirstTime)
        {
            
Store_SetClientCredits(clientStore_GetClientCredits(client) + GetConVarInt(g_hDailyCredits));
            
CPrintToChatEx(clientclient"%t""CreditsRecieved"GetConVarInt(g_hDailyCredits));
            
Format(buffersizeof(buffer), "INSERT IGNORE INTO players (steam_id, last_connect, bonus_amount) VALUES ('%s', %d, 1)"steamIdStringToInt(CurrentDate));
            
SQL_TQuery(dbSQLErrorCheckCallbackbuffer);
        }
        else
        {
            
Format(buffersizeof(buffer), "SELECT * FROM players WHERE steam_id = '%s'"steamId);
            
SQL_LockDatabase(db);
            
DBResultSet query SQL_Query(dbbuffer);
            
SQL_UnlockDatabase(db);
            
SQL_FetchRow(query);
            
int date2 SQL_FetchInt(query1);
            
int bonus SQL_FetchInt(query2);
            
delete query;
            
int date1 StringToInt(CurrentDate);
            
int resetDaysSetting GetConVarInt(g_hDailyReset);
            
            if (
resetDaysSetting 0) {  //needed since after the reset, bonus starts at 0
                
resetDaysSetting--;
            }
            
            
//streak is currently continuing
            
if ((date1 date2) == 1)
            {
                
int TotalCredits GetConVarInt(g_hDailyCredits) + (bonus GetConVarInt(g_hDailyBonus)); //bonus can't start at 1, since the first day would get the player a bonus as well
                
if (TotalCredits GetConVarInt(g_hDailyMax))TotalCredits GetConVarInt(g_hDailyMax);
                
Store_SetClientCredits(clientStore_GetClientCredits(client) + TotalCredits);
                
                if (
resetDaysSetting != 0)
                {
                    if (
bonus >= resetDaysSetting)
                    {
                        
CPrintToChatEx(clientclient"%t""LastCreditsRecieved"TotalCredits);
                        
Format(buffersizeof(buffer), "UPDATE players SET last_connect = %i, bonus_amount = %i WHERE steam_id = '%s'"date10steamId);
                        
CPrintToChatEx(clientclient"%t""ResetDays"resetDaysSetting 1);
                    }
                    else
                    {
                        
CPrintToChatEx(clientclient"%t""CreditsRecieved"TotalCredits);
                        
Format(buffersizeof(buffer), "UPDATE players SET last_connect = %i, bonus_amount = %i WHERE steam_id = '%s'"date1bonus 1steamId);
                        
CPrintToChatEx(clientclient"%t""CurrentDay"bonus 1);
                    }
                }
                else
                {
                    
CPrintToChatEx(clientclient"%t""CreditsRecieved"TotalCredits);
                    
Format(buffersizeof(buffer), "UPDATE players SET last_connect = %i, bonus_amount = %i WHERE steam_id = '%s'"date1bonus 1steamId);
                    
CPrintToChatEx(clientclient"%t""CurrentDay"bonus 1);
                }
                
SQL_TQuery(dbSQLErrorCheckCallbackbuffer);
            }
            
//already recieved credits today
            
else if ((date1 date2) == 0)
            {
                
CPrintToChatEx(clientclient"%t""BackTomorrow");
            }
            
//streak ended
            
else if ((date1 date2) > 1)
            {
                
CPrintToChatEx(clientclient"%t""StreakEnded"bonus);
                
Store_SetClientCredits(clientStore_GetClientCredits(client) + GetConVarInt(g_hDailyCredits));
                
CPrintToChatEx(clientclient"%t""CreditsRecieved"GetConVarInt(g_hDailyCredits));
                
Format(buffersizeof(buffer), "UPDATE players SET last_connect = %i, bonus_amount = 1 WHERE steam_id = '%s'"date1steamId);
                
SQL_TQuery(dbSQLErrorCheckCallbackbuffer);
            }
        }
    }
    else 
LogError("Failed to get Steam ID");
}

stock bool IsValidClient(int client)
{
    if (
client <= 0)return false;
    if (
client MaxClients)return false;
    if (!
IsClientConnected(client))return false;
    return 
IsClientInGame(client);
}

public 
void SQLErrorCheckCallback(Handle ownerHandle hndl, const char[] errorany data)
{
    if (!
StrEqual(error""))
        
LogError(error);

szogun is offline
arne1288
SourceMod Moderator
Join Date: Apr 2012
Old 10-12-2018 , 21:23   Re: Dailycredits
Reply With Quote #2

Quote:
Originally Posted by szogun View Post
I have a small request [...]
Pay more attention in the future, you posted in Scripting, not in Plugin/Gameplay Ideas and Requests where requests belong!

I have moved your thread over there.
__________________
Mostly known as "DarkDeviL".

Dropbox FastDL: Public folder will no longer work after March 15, 2017!
For more info, see the [SRCDS Thread], or the [HLDS Thread]
arne1288 is offline
Reply


Thread Tools
Display Modes

Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is On
Smilies are On
[IMG] code is On
HTML code is Off

Forum Jump


All times are GMT -4. The time now is 07:39.


Powered by vBulletin®
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Theme made by Freecode