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 newdecls required
|
||||
#include <sourcemod>
|
||||
#include <cURL>
|
||||
|
||||
public Plugin:myinfo =
|
||||
public Plugin myinfo =
|
||||
{
|
||||
name = "demos.tf uploader",
|
||||
author = "Icewind",
|
||||
|
|
@ -11,45 +12,47 @@ public Plugin:myinfo =
|
|||
url = "https://demos.tf"
|
||||
};
|
||||
|
||||
new CURL_Default_opt[][2] = {
|
||||
{_:CURLOPT_NOSIGNAL,1},
|
||||
{_:CURLOPT_NOPROGRESS,1},
|
||||
{_:CURLOPT_TIMEOUT,600},
|
||||
{_:CURLOPT_CONNECTTIMEOUT,600},
|
||||
{_:CURLOPT_USE_SSL,CURLUSESSL_TRY},
|
||||
{_:CURLOPT_SSL_VERIFYPEER,0},
|
||||
{_:CURLOPT_SSL_VERIFYHOST,0},
|
||||
{_:CURLOPT_VERBOSE,0}
|
||||
int CURL_Default_opt[][2] = {
|
||||
{ view_as<int>(CURLOPT_NOSIGNAL), 1 },
|
||||
{ view_as<int>(CURLOPT_NOPROGRESS), 1 },
|
||||
{ view_as<int>(CURLOPT_TIMEOUT), 600 },
|
||||
{ view_as<int>(CURLOPT_CONNECTTIMEOUT), 600 },
|
||||
{ view_as<int>(CURLOPT_USE_SSL), CURLUSESSL_TRY },
|
||||
{ view_as<int>(CURLOPT_SSL_VERIFYPEER), 0 },
|
||||
{ view_as<int>(CURLOPT_SSL_VERIFYHOST), 0 },
|
||||
{ view_as<int>(CURLOPT_VERBOSE), 0 }
|
||||
|
||||
};
|
||||
|
||||
|
||||
/**
|
||||
* Converts a string to lowercase
|
||||
*
|
||||
* @param buffer String to convert
|
||||
* @noreturn
|
||||
*/
|
||||
public CStrToLower(String:buffer[]) {
|
||||
new len = strlen(buffer);
|
||||
for(new i = 0; i < len; i++) {
|
||||
public void CStrToLower(char[] buffer) {
|
||||
int len = strlen(buffer);
|
||||
for(int i = 0; i < len; i++) {
|
||||
buffer[i] = CharToLower(buffer[i]);
|
||||
}
|
||||
}
|
||||
|
||||
#define CURL_DEFAULT_OPT(%1) curl_easy_setopt_int_array(%1, CURL_Default_opt, sizeof(CURL_Default_opt))
|
||||
|
||||
new String:g_sDemoName[256] = "";
|
||||
new String:g_sLastDemoName[256] = "";
|
||||
char g_sDemoName[256] = "";
|
||||
char g_sLastDemoName[256] = "";
|
||||
|
||||
new Handle:g_hCvarAPIKey = INVALID_HANDLE;
|
||||
new Handle:g_hCvarUrl = INVALID_HANDLE;
|
||||
new Handle:output_file = INVALID_HANDLE;
|
||||
new Handle:postForm = INVALID_HANDLE;
|
||||
new Handle:g_hCvarRedTeamName = INVALID_HANDLE;
|
||||
new Handle:g_hCvarBlueTeamName = INVALID_HANDLE;
|
||||
Handle g_hCvarAPIKey = INVALID_HANDLE;
|
||||
Handle g_hCvarUrl = INVALID_HANDLE;
|
||||
Handle output_file = INVALID_HANDLE;
|
||||
Handle postForm = INVALID_HANDLE;
|
||||
Handle g_hCvarRedTeamName = 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_hCvarUrl = CreateConVar("sm_demostf_url", "https://demos.tf", "demos.tf url", FCVAR_PROTECTED);
|
||||
|
|
@ -62,12 +65,12 @@ public OnPluginStart()
|
|||
RegServerCmd("tv_stoprecord", Command_StopRecord);
|
||||
}
|
||||
|
||||
public OnPluginEnd()
|
||||
public void OnPluginEnd()
|
||||
{
|
||||
CloseHandle(g_hDemoUploaded);
|
||||
}
|
||||
|
||||
public Action:Command_StartRecord(args)
|
||||
public Action Command_StartRecord(int args)
|
||||
{
|
||||
if (strlen(g_sDemoName) == 0) {
|
||||
GetCmdArgString(g_sDemoName, sizeof(g_sDemoName));
|
||||
|
|
@ -77,7 +80,7 @@ public Action:Command_StartRecord(args)
|
|||
return Plugin_Continue;
|
||||
}
|
||||
|
||||
public Action:Command_StopRecord(args)
|
||||
public Action Command_StopRecord(int args)
|
||||
{
|
||||
TrimString(g_sDemoName);
|
||||
if (strlen(g_sDemoName) != 0) {
|
||||
|
|
@ -89,26 +92,27 @@ public Action:Command_StopRecord(args)
|
|||
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);
|
||||
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));
|
||||
decl String:BaseUrl[64];
|
||||
char BaseUrl[64];
|
||||
GetConVarString(g_hCvarUrl, BaseUrl, sizeof(BaseUrl));
|
||||
new String:Map[64];
|
||||
char Map[64];
|
||||
GetCurrentMap(Map, sizeof(Map));
|
||||
PrintToChatAll("[demos.tf]: Uploading demo %s", fullPath);
|
||||
new Handle:curl = curl_easy_init();
|
||||
Handle curl = curl_easy_init();
|
||||
CURL_DEFAULT_OPT(curl);
|
||||
decl String:bluname[128];
|
||||
decl String:redname[128];
|
||||
char bluname[128];
|
||||
char redname[128];
|
||||
GetConVarString(g_hCvarRedTeamName, redname, sizeof(redname));
|
||||
GetConVarString(g_hCvarBlueTeamName, bluname, sizeof(bluname));
|
||||
|
||||
|
|
@ -122,17 +126,17 @@ UploadDemo(const String:fullPath[])
|
|||
|
||||
output_file = curl_OpenFile("output_demo.json", "w");
|
||||
curl_easy_setopt_handle(curl, CURLOPT_WRITEDATA, output_file);
|
||||
decl String:fullUrl[128];
|
||||
char fullUrl[128];
|
||||
Format(fullUrl, sizeof(fullUrl), "%s/upload", BaseUrl);
|
||||
curl_easy_setopt_string(curl, CURLOPT_URL, fullUrl);
|
||||
curl_easy_perform_thread(curl, onComplete);
|
||||
}
|
||||
|
||||
public onComplete(Handle:hndl, CURLcode:code)
|
||||
public void onComplete(Handle hndl, CURLcode code)
|
||||
{
|
||||
if(code != CURLE_OK)
|
||||
{
|
||||
new String:error_buffer[256];
|
||||
char error_buffer[256];
|
||||
curl_easy_strerror(code, error_buffer, sizeof(error_buffer));
|
||||
CloseHandle(output_file);
|
||||
CloseHandle(hndl);
|
||||
|
|
@ -149,16 +153,16 @@ public onComplete(Handle:hndl, CURLcode:code)
|
|||
return;
|
||||
}
|
||||
|
||||
public ShowResponse()
|
||||
void ShowResponse()
|
||||
{
|
||||
new Handle:resultFile = OpenFile("output_demo.json", "r");
|
||||
new String:output[512];
|
||||
Handle resultFile = OpenFile("output_demo.json", "r");
|
||||
char output[512];
|
||||
ReadFileString(resultFile, output, sizeof(output));
|
||||
PrintToChatAll("[demos.tf]: %s", output);
|
||||
LogToGame("[demos.tf]: %s", output);
|
||||
|
||||
new String:demoid[16];
|
||||
new String:url[256];
|
||||
char demoid[16];
|
||||
char url[256];
|
||||
|
||||
char url_parts[4][16];
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue