mirror of
https://codeberg.org/demostf/plugin.git
synced 2026-06-04 00:54:08 +02:00
update sp to newdecls, recompile for sm 1.11
This commit is contained in:
parent
ba1b642b92
commit
e7576c7433
2 changed files with 47 additions and 43 deletions
BIN
demostf.smx
BIN
demostf.smx
Binary file not shown.
90
demostf.sp
90
demostf.sp
|
|
@ -1,8 +1,9 @@
|
||||||
#pragma semicolon 1
|
#pragma semicolon 1
|
||||||
|
#pragma newdecls required
|
||||||
#include <sourcemod>
|
#include <sourcemod>
|
||||||
#include <cURL>
|
#include <cURL>
|
||||||
|
|
||||||
public Plugin:myinfo =
|
public Plugin myinfo =
|
||||||
{
|
{
|
||||||
name = "demos.tf uploader",
|
name = "demos.tf uploader",
|
||||||
author = "Icewind",
|
author = "Icewind",
|
||||||
|
|
@ -11,45 +12,47 @@ public Plugin:myinfo =
|
||||||
url = "https://demos.tf"
|
url = "https://demos.tf"
|
||||||
};
|
};
|
||||||
|
|
||||||
new CURL_Default_opt[][2] = {
|
int CURL_Default_opt[][2] = {
|
||||||
{_:CURLOPT_NOSIGNAL,1},
|
{ view_as<int>(CURLOPT_NOSIGNAL), 1 },
|
||||||
{_:CURLOPT_NOPROGRESS,1},
|
{ view_as<int>(CURLOPT_NOPROGRESS), 1 },
|
||||||
{_:CURLOPT_TIMEOUT,600},
|
{ view_as<int>(CURLOPT_TIMEOUT), 600 },
|
||||||
{_:CURLOPT_CONNECTTIMEOUT,600},
|
{ view_as<int>(CURLOPT_CONNECTTIMEOUT), 600 },
|
||||||
{_:CURLOPT_USE_SSL,CURLUSESSL_TRY},
|
{ view_as<int>(CURLOPT_USE_SSL), CURLUSESSL_TRY },
|
||||||
{_:CURLOPT_SSL_VERIFYPEER,0},
|
{ view_as<int>(CURLOPT_SSL_VERIFYPEER), 0 },
|
||||||
{_:CURLOPT_SSL_VERIFYHOST,0},
|
{ view_as<int>(CURLOPT_SSL_VERIFYHOST), 0 },
|
||||||
{_:CURLOPT_VERBOSE,0}
|
{ view_as<int>(CURLOPT_VERBOSE), 0 }
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Converts a string to lowercase
|
* Converts a string to lowercase
|
||||||
*
|
*
|
||||||
* @param buffer String to convert
|
* @param buffer String to convert
|
||||||
* @noreturn
|
* @noreturn
|
||||||
*/
|
*/
|
||||||
public CStrToLower(String:buffer[]) {
|
public void CStrToLower(char[] buffer) {
|
||||||
new len = strlen(buffer);
|
int len = strlen(buffer);
|
||||||
for(new i = 0; i < len; i++) {
|
for(int i = 0; i < len; i++) {
|
||||||
buffer[i] = CharToLower(buffer[i]);
|
buffer[i] = CharToLower(buffer[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#define CURL_DEFAULT_OPT(%1) curl_easy_setopt_int_array(%1, CURL_Default_opt, sizeof(CURL_Default_opt))
|
#define CURL_DEFAULT_OPT(%1) curl_easy_setopt_int_array(%1, CURL_Default_opt, sizeof(CURL_Default_opt))
|
||||||
|
|
||||||
new String:g_sDemoName[256] = "";
|
char g_sDemoName[256] = "";
|
||||||
new String:g_sLastDemoName[256] = "";
|
char g_sLastDemoName[256] = "";
|
||||||
|
|
||||||
new Handle:g_hCvarAPIKey = INVALID_HANDLE;
|
Handle g_hCvarAPIKey = INVALID_HANDLE;
|
||||||
new Handle:g_hCvarUrl = INVALID_HANDLE;
|
Handle g_hCvarUrl = INVALID_HANDLE;
|
||||||
new Handle:output_file = INVALID_HANDLE;
|
Handle output_file = INVALID_HANDLE;
|
||||||
new Handle:postForm = INVALID_HANDLE;
|
Handle postForm = INVALID_HANDLE;
|
||||||
new Handle:g_hCvarRedTeamName = INVALID_HANDLE;
|
Handle g_hCvarRedTeamName = INVALID_HANDLE;
|
||||||
new Handle:g_hCvarBlueTeamName = INVALID_HANDLE;
|
Handle g_hCvarBlueTeamName = INVALID_HANDLE;
|
||||||
|
|
||||||
new Handle:g_hDemoUploaded = INVALID_HANDLE;
|
Handle g_hDemoUploaded = INVALID_HANDLE;
|
||||||
|
|
||||||
public OnPluginStart()
|
public void OnPluginStart()
|
||||||
{
|
{
|
||||||
g_hCvarAPIKey = CreateConVar("sm_demostf_apikey", "", "API key for demos.tf", FCVAR_PROTECTED);
|
g_hCvarAPIKey = CreateConVar("sm_demostf_apikey", "", "API key for demos.tf", FCVAR_PROTECTED);
|
||||||
g_hCvarUrl = CreateConVar("sm_demostf_url", "https://demos.tf", "demos.tf url", FCVAR_PROTECTED);
|
g_hCvarUrl = CreateConVar("sm_demostf_url", "https://demos.tf", "demos.tf url", FCVAR_PROTECTED);
|
||||||
|
|
@ -62,12 +65,12 @@ public OnPluginStart()
|
||||||
RegServerCmd("tv_stoprecord", Command_StopRecord);
|
RegServerCmd("tv_stoprecord", Command_StopRecord);
|
||||||
}
|
}
|
||||||
|
|
||||||
public OnPluginEnd()
|
public void OnPluginEnd()
|
||||||
{
|
{
|
||||||
CloseHandle(g_hDemoUploaded);
|
CloseHandle(g_hDemoUploaded);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Action:Command_StartRecord(args)
|
public Action Command_StartRecord(int args)
|
||||||
{
|
{
|
||||||
if (strlen(g_sDemoName) == 0) {
|
if (strlen(g_sDemoName) == 0) {
|
||||||
GetCmdArgString(g_sDemoName, sizeof(g_sDemoName));
|
GetCmdArgString(g_sDemoName, sizeof(g_sDemoName));
|
||||||
|
|
@ -77,7 +80,7 @@ public Action:Command_StartRecord(args)
|
||||||
return Plugin_Continue;
|
return Plugin_Continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Action:Command_StopRecord(args)
|
public Action Command_StopRecord(int args)
|
||||||
{
|
{
|
||||||
TrimString(g_sDemoName);
|
TrimString(g_sDemoName);
|
||||||
if (strlen(g_sDemoName) != 0) {
|
if (strlen(g_sDemoName) != 0) {
|
||||||
|
|
@ -89,26 +92,27 @@ public Action:Command_StopRecord(args)
|
||||||
return Plugin_Continue;
|
return Plugin_Continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Action:StartDemoUpload(Handle:timer)
|
public Action StartDemoUpload(Handle timer)
|
||||||
{
|
{
|
||||||
decl String:fullPath[128];
|
char fullPath[128];
|
||||||
Format(fullPath, sizeof(fullPath), "%s.dem", g_sLastDemoName);
|
Format(fullPath, sizeof(fullPath), "%s.dem", g_sLastDemoName);
|
||||||
UploadDemo(fullPath);
|
UploadDemo(fullPath);
|
||||||
|
return Plugin_Continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
UploadDemo(const String:fullPath[])
|
void UploadDemo(const char[] fullPath)
|
||||||
{
|
{
|
||||||
decl String:APIKey[128];
|
char APIKey[128];
|
||||||
GetConVarString(g_hCvarAPIKey, APIKey, sizeof(APIKey));
|
GetConVarString(g_hCvarAPIKey, APIKey, sizeof(APIKey));
|
||||||
decl String:BaseUrl[64];
|
char BaseUrl[64];
|
||||||
GetConVarString(g_hCvarUrl, BaseUrl, sizeof(BaseUrl));
|
GetConVarString(g_hCvarUrl, BaseUrl, sizeof(BaseUrl));
|
||||||
new String:Map[64];
|
char Map[64];
|
||||||
GetCurrentMap(Map, sizeof(Map));
|
GetCurrentMap(Map, sizeof(Map));
|
||||||
PrintToChatAll("[demos.tf]: Uploading demo %s", fullPath);
|
PrintToChatAll("[demos.tf]: Uploading demo %s", fullPath);
|
||||||
new Handle:curl = curl_easy_init();
|
Handle curl = curl_easy_init();
|
||||||
CURL_DEFAULT_OPT(curl);
|
CURL_DEFAULT_OPT(curl);
|
||||||
decl String:bluname[128];
|
char bluname[128];
|
||||||
decl String:redname[128];
|
char redname[128];
|
||||||
GetConVarString(g_hCvarRedTeamName, redname, sizeof(redname));
|
GetConVarString(g_hCvarRedTeamName, redname, sizeof(redname));
|
||||||
GetConVarString(g_hCvarBlueTeamName, bluname, sizeof(bluname));
|
GetConVarString(g_hCvarBlueTeamName, bluname, sizeof(bluname));
|
||||||
|
|
||||||
|
|
@ -122,17 +126,17 @@ UploadDemo(const String:fullPath[])
|
||||||
|
|
||||||
output_file = curl_OpenFile("output_demo.json", "w");
|
output_file = curl_OpenFile("output_demo.json", "w");
|
||||||
curl_easy_setopt_handle(curl, CURLOPT_WRITEDATA, output_file);
|
curl_easy_setopt_handle(curl, CURLOPT_WRITEDATA, output_file);
|
||||||
decl String:fullUrl[128];
|
char fullUrl[128];
|
||||||
Format(fullUrl, sizeof(fullUrl), "%s/upload", BaseUrl);
|
Format(fullUrl, sizeof(fullUrl), "%s/upload", BaseUrl);
|
||||||
curl_easy_setopt_string(curl, CURLOPT_URL, fullUrl);
|
curl_easy_setopt_string(curl, CURLOPT_URL, fullUrl);
|
||||||
curl_easy_perform_thread(curl, onComplete);
|
curl_easy_perform_thread(curl, onComplete);
|
||||||
}
|
}
|
||||||
|
|
||||||
public onComplete(Handle:hndl, CURLcode:code)
|
public void onComplete(Handle hndl, CURLcode code)
|
||||||
{
|
{
|
||||||
if(code != CURLE_OK)
|
if(code != CURLE_OK)
|
||||||
{
|
{
|
||||||
new String:error_buffer[256];
|
char error_buffer[256];
|
||||||
curl_easy_strerror(code, error_buffer, sizeof(error_buffer));
|
curl_easy_strerror(code, error_buffer, sizeof(error_buffer));
|
||||||
CloseHandle(output_file);
|
CloseHandle(output_file);
|
||||||
CloseHandle(hndl);
|
CloseHandle(hndl);
|
||||||
|
|
@ -149,16 +153,16 @@ public onComplete(Handle:hndl, CURLcode:code)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
public ShowResponse()
|
void ShowResponse()
|
||||||
{
|
{
|
||||||
new Handle:resultFile = OpenFile("output_demo.json", "r");
|
Handle resultFile = OpenFile("output_demo.json", "r");
|
||||||
new String:output[512];
|
char output[512];
|
||||||
ReadFileString(resultFile, output, sizeof(output));
|
ReadFileString(resultFile, output, sizeof(output));
|
||||||
PrintToChatAll("[demos.tf]: %s", output);
|
PrintToChatAll("[demos.tf]: %s", output);
|
||||||
LogToGame("[demos.tf]: %s", output);
|
LogToGame("[demos.tf]: %s", output);
|
||||||
|
|
||||||
new String:demoid[16];
|
char demoid[16];
|
||||||
new String:url[256];
|
char url[256];
|
||||||
|
|
||||||
char url_parts[4][16];
|
char url_parts[4][16];
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue