#NoEnv ; Recommended for performance and compatibility with future AutoHotkey releases. ; #Warn ; Enable warnings to assist with detecting common errors. #SingleInstance, Force SendMode Input ; Recommended for new scripts due to its superior speed and reliability. SetWorkingDir %A_ScriptDir% ; Ensures a consistent starting directory. CoordMode, ToolTip, Screen CoordMode, Mouse, Screen FileEncoding, UTF-8-RAW ; Needed for special symbols that are used in video descritions if(InStr(A_ScriptFullPath, ".ahk")){ try Menu, Tray, Icon, %A_ScriptDir%\Assets\FreedomainVideo.ico } PassedParameter = %1% ; Add menus to the toolbar icon Menu, tray, NoStandard Menu, Tray, Add, Exit, KillScript Menu, Tray, Add, Pause, PauseScript Menu, Tray, Add, Open New Project, ReloadScript ; Menu, Tray, Add, Restart to Last Project Upload Results, ReloadToResults ; @todo fix this as it currently just loads the last project Menu, Tray, Add, Restart with Last Project, RetryUpload Menu, Tray, Default, Restart with Last Project global ScriptName global ScriptVersion global FullScriptName ScriptName = Freedomain Video Uploader ScriptVersion = 3.19 FullScriptName := ScriptName . " - " . ScriptVersion ; UStartTime := A_TickCount ; start time ; Included Files - These have to be included at the top for the Global variables to get registered early? #Include %A_ScriptDir%\Lib\Freedomain-Posters-Shared-Functions\General-Functions.ahk #Include %A_ScriptDir%\Lib\Freedomain-Posters-Shared-Functions\Selenium-Functions.ahk #Include %A_ScriptDir%\Lib\Freedomain-Posters-Shared-Functions\Chrome-Functions.ahk #Include %A_ScriptDir%\Lib\Freedomain-Posters-Shared-Functions\Gitea-Functions.ahk #Include %A_ScriptDir%\Lib\Freedomain-Posters-Shared-Functions\API-Functions.ahk #Include %A_ScriptDir%\Lib\Freedomain-Posters-Shared-Functions\JSON.ahk #Include %A_ScriptDir%\Lib\Freedomain-Posters-Shared-Functions\RunCMD.ahk #include %A_ScriptDir%\Lib\Freedomain-Posters-Shared-Functions\StdOutToVar.ahk ;---ToDo--- ;------------------------------------------------ ; @todo: Update Locals Share link grabbing ; @todo: finish show results functionality on line 430 ; @todo: fix uploader saying there's been failures b/c there was no lbry audio upload ; @todo: finish telegram multi-message split functionality. ; @todo: add different icon when update is available ; @todo: fix telegram post getting cut off if too long instead of splitting into 2 ; @todo: fix ping always saying that there was failures ; @todo: let user make last minute changes to text before submitting to telegram and discord ; @todo: replace all .Attribute("innerText") with js ; @todo: Fix locals not grabbing url if a post is pinned ; @todo: Add an input box for sources in the new frontend ; @todo: Fix bitchute title getting input twice ; @todo: Add login check for each website and ability to auto login ; @todo: ; add to statistics in statusbar - length of philosophy uploaded... total hours uploaded? ; @todo: add support for unauthorized.tv ; @todo: Bitchute has a 5k char limit for description as well. split description to remove reocurring bits and Add freedomainpodcasts.com/podcast/# link if still not big enough ; @todo: Split long discord/telegram messages into multiple messages ; @todo: Redo Discord posting with "PostErrors" function from social media poster ; @todo: Save updates made to GUi text to .ini file on changes ; @todo: add a SaveDriverURL() next to each RETURN in the code so reusable tabs can be grouped together ;---Global Variables--- ;------------------------------------------------ global LBRYResolveAPICommand global LBRYPermanentURL global VideoTitle global VideoFilepath global VideoThumbFilepath global VideoTags global VideoDescription global SocialMediaDescription global DiscordErrorLoggingWebhookBotURL global DiscordVideosWebhookURL global VideoFolderDir global LogErrorsToMsgbox ; global LogErrorsToTextFile global CurrentSite global Driver global DriverStatus global ChromeProfile global ShowTooltipProgressCheckStatus global ShowTooltipProgress global ErrorLogSummary global DiscordParlerWebhookURL global ErrorLoggingFilePath ; global TotalTabLoops global ErrorLogVar ErrorLogVar := global ReuseTabs ; reuse tabs variable global DevMode global ScreenshotResult global LBRYNetFilepath LBRYNetFilepath := "C:\Program Files\LBRY\resources\static\daemon\lbrynet.exe" global Number_of_loops_to_Check_Upload_status Number_of_loops_to_Check_Upload_status = 720 ; 720 loops, at 5 seonds each = 3600 seconds (60 mins) ; number of seconds to wait between loops when checking video upload status global Time_Between_Loops_Upload_Status Time_Between_Loops_Upload_Status = 5000 ; loop Index number to check if video is stuck uploading global Array_Index_Num_of_Upload_StatusChecks Array_Index_Num_of_Upload_StatusChecks := [144,288,432, 576,720,864] ; loop number that discord message gets sent off at to track upload progress ; 144 x 5 seconds = 12 minutes ; Check if Lib folder exists and create it if not LibFolder := A_ScriptDir . "\Lib" ErrorLoggingFolder := A_ScriptDir . "\Lib\ErrorLogging" FileCreateDir, %ErrorLoggingFolder% ; Set filepaths for different files and folders global SettingsIniFilepath SettingsIniFilepath := A_ScriptDir . "\Settings.ini" global ChangelogIniFilepath ChangelogIniFilepath := A_ScriptDir . "\Lib\FreedomScriptsChangelogINI" global ScriptSettingsSection ScriptSettingsSection := "VideoUploader" ;---Script Settings--- ;------------------------------------------------ ; Checkbox Settings IniRead, ShowTooltipProgress, %SettingsIniFilepath%, General, ShowTooltipProgress, 1 (ShowTooltipProgress)?(ShowTooltipProgressCheckStatus := 1) : (ShowTooltipProgressCheckStatus := 0) ; Message = Reading Settings from .ini files ; ToolTip, reading settings ; SaveOrPostProgress(Message:=Message,PostType:="Tooltip") IniRead, RootDirToStartIn, %SettingsIniFilepath%, General, RootDirToStartIn IniRead, LogErrorsToMsgbox, %SettingsIniFilepath%, General, LogErrorsToMsgbox, %A_Space% IniRead, UpdateAvailable, %SettingsIniFilepath%, %ScriptSettingsSection%, UpdateAvailable, 0 ; Msgbox % "SettingsIniFilepath: " SettingsIniFilepath ; Msgbox % "UpdateAvailable: " UpdateAvailable IniRead, DevMode, %SettingsIniFilepath%, General, DevMode, 0 IniRead, ScreenshotResult, %SettingsIniFilepath%, General, ScreenshotResult, 0 IniRead, TotalVideosUploaded, %SettingsIniFilepath%, General, TotalVideosUploaded, 0 ; Checkbox Settings IniRead, ShowTooltipProgress, %SettingsIniFilepath%, General, ShowTooltipProgress, 1 (ShowTooltipProgress)?(ShowTooltipProgressCheckStatus := 1) : (ShowTooltipProgressCheckStatus := 0) IniRead, ReuseTabs, %SettingsIniFilepath%, General, ReuseTabs, 1 (ReuseTabs)?(ReuseTabsCheckStatus := 1) : (ReuseTabsCheckStatus := 0) IniRead, AutoUpdateCheck, %SettingsIniFilepath%, General, AutoUpdateCheck, 1 (AutoUpdateCheck)?(AutoUpdateCheckCheckStatus := 1) : (AutoUpdateCheckCheckStatus := 0) ; AutoLogin setting IniRead, AutoLogin, %SettingsIniFilepath%, General, AutoLogin, 1 (AutoUpdateCheck)?(AutoUpdateCheckCheckStatus := 1) : (AutoUpdateCheckCheckStatus := 0) IniRead, PingOnCompletion, %SettingsIniFilepath%, General, PingOnCompletion, 1 (PingOnCompletion)?(PingOnCompletionCheckStatus := 1) : (PingOnCompletionCheckStatus := 0) if(PingOnCompletion){ IniRead, DiscordUsernameID, %SettingsIniFilepath%, General, DiscordUsernameID, %A_space% if(!DiscordUsernameID){ Message = DiscordUsernameID is blank. Will not be able to ping to notify when uploads are complete.`nPlease add user ID in settings.ini under: `n`n[General]`nDiscordUsernameID=`nOr Uncheck "Discord Ping on Completion" ; SaveOrPostProgress(Message:=Message,PostType:="ErrorLoggingTextFile") SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar") } } IniRead, KillLBRYAfterUpload, %SettingsIniFilepath%, General, KillLBRYAfterUpload, 1 (KillLBRYAfterUpload)?(=KillLBRYAfterUploadCheckStatus := 1) : (KillLBRYAfterUploadCheckStatus := 0) IniRead, DiscordErrorLoggingWebhookBotURL, %SettingsIniFilepath%, General, DiscordWebhookBotURL, %A_space% if(DiscordErrorLoggingWebhookBotURL = ""){ Message = DiscordErrorLoggingWebhookBotURL is blank. `nWill not be able to post error messages or upload status to discord.`nPlease add discord webhook URL in settings.ini under: `n`n[General]`DiscordErrorLoggingWebhookBotURL= SaveOrPostProgress(Message:=Message,PostType:="ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") } ;---Auto Updater Settings--- ;------------------------------------------------ global GitReleasesAPIURL GitReleasesAPIURL = https://git.freedomainplaylists.com/api/v1/repos/yuriy/Freedomain-Video-Uploader/releases global GitReleasesLBRYKillerAPIURL GitReleasesLBRYKillerAPIURL = https://git.freedomainplaylists.com/api/v1/repos/yuriy/LBRY-Process-Killer/releases ;---LBRY Settings--- ;------------------------------------------------ IniRead, LBRYNewVideoStakeAmount, %SettingsIniFilepath%, General, LBRYNewVideoStakeAmount, %A_Space% if(LBRYNewVideoStakeAmount = ""){ LBRYNewVideoStakeAmount = 1.0 IniWrite, %LBRYNewVideoStakeAmount%, %SettingsIniFilepath%, General, LBRYNewVideoStakeAmount } IniRead, LBRYChannelID, %SettingsIniFilepath%, General, LBRYChannelID, %A_Space% if(LBRYChannelID = ""){ LBRYChannelID = b89ed227c49e726fcccf913bdc9dec4c8fec99c2 IniWrite, %LBRYChannelID%, %SettingsIniFilepath%, General, LBRYChannelID } ;---Read Info From Project Files--- ;------------------------------------------------ ; if passed argument is .exe file, then script has just been udpated and we need to move the old version if(InStr(PassedParameter,ScriptName) and InStr(PassedParameter,".exe")){ ; create backups folder if it doesn't exist BackupsFolder = %LibFolder%\Backups\ ; Msgbox % "BackupsFolder: " BackupsFolder if(!FileExist(BackupsFolder)){ FileCreateDir, %BackupsFolder% } ; move old version to backups folder, overwrite if name conflict FileMove, %PassedParameter%, %BackupsFolder%\*, 1 if(ErrorLevel){ ; most likely because the old version hasn't finished exiting yet SaveOrPostProgress(Message:="Moving Old Version to Backups",PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar") sleep, 2000 FileMove, %PassedParameter%, %BackupsFolder%\*, 1 if(ErrorLevel){ MsgBox,,Update Successful, Update was successful`, but unable to move old version to the Backups folder.`nPlease move it or delete it manually. } ToolTip } ; Change paramter to LastPost so last post gets automatically opened instead of user having to re-select the file again PassedParameter = LastPost } if(PassedParameter = "LastPost"){ IniRead, PassedParameter, %SettingsIniFilepath%, %ScriptSettingsSection%, LastPost, %A_Space% } if(PassedParameter = "ShowResults"){ IniRead, PassedParameter, %SettingsIniFilepath%, %ScriptSettingsSection%, LastPost, %A_Space% } PassedParameterLength := StrLen(PassedParameter) if(PassedParameterLength < 5 and !InStr(PassedParameter, ".exe")){ FileSelectFile, BodyTextFilePath,,%RootDirToStartIn%,Please Select ANY File Within the Project Folder if(ErrorLevel) Return } else, { SkipUpdateCheckThisRun := 1 BodyTextFilePath := PassedParameter } ; @todo Do this with an array. Add all filepaths to array and then pull out the ones with the extension. ; get directory from the filepath grabbed SplitPath, BodyTextFilePath, OutFileName, VideoFolderDir, OutExtension, OutNameNoExt, OutDrive Loop, files, %VideoFolderDir%\*.*, F ; loop through the files in the directory { ; D = Directories, F = Files, R = Recursive SplitPath, A_LoopFileFullPath, FileNameWExt, FileDir, FileExt, FileNameNoExt, if(FileNameWExt = "title.txt"){ FileRead, VideoTitle, %A_LoopFileFullPath% LBRYURLSlug := VideoTitle OriginalVideoTitle := VideoTitle OriginalLBRYURLSlug := LBRYURLSlug } if(FileNameWExt = "body.txt"){ FileRead, VideoDescription, %A_LoopFileFullPath% DescriptionCharCount := StrLen(VideoDescription) OriginalVideoDescription := VideoDescription } if(FileNameWExt = "keywords.txt"){ FileRead, VideoTags, %A_LoopFileFullPath% FileRead, PodcastTags, %A_LoopFileFullPath% OriginalVideoTags := VideoTags OriginalPodcastTags := PodcastTags } if(FileNameWExt = "keywords_podcast.txt"){ FileRead, PodcastTags, %A_LoopFileFullPath% OriginalPodcastTags := PodcastTags } if(FileExt = "mp4"){ VideoFilepath := A_LoopFileFullPath SplitPath, A_LoopFileFullPath,,,, VideoFileNameNoExt FileGetSize, VideoFileSizeInMB, %A_LoopFileFullPath%, M } if(FileExt = "png" OR FileExt = "jpg"){ VideoThumbFilepath := A_LoopFileFullPath } } if(VideoDescription = ""){ ; @todo: is this used anymore? FileRead, VideoDescription, %A_scriptDir%\Lib\DescriptionTemplate.txt } ; Loop through the folder again to find the correct .WAV audio file as Stef has multiple in there and we need the .mp4 file to be found first so we know what to look for file name wise. Loop, files, %VideoFolderDir%\*.WAV, F ; loop through the files in the directory { ; D = Directories, F = Files, R = Recursive SplitPath, A_LoopFileFullPath, FileNameWExt, FileDir, FileExt, FileNameNoExt if(FileNameNoExt = VideoFileNameNoExt){ WavAudioFilepath := A_LoopFileFullPath } } ; Loop through the folder again to find the correct .WAV audio file as Stef has multiple in there and we need the .mp4 file to be found first so we know what to look for file name wise. Loop, files, %VideoFolderDir%\*.mp3, F ; loop through the files in the directory { ; D = Directories, F = Files, R = Recursive SplitPath, A_LoopFileFullPath, FileNameWExt, FileDir, FileExt, FileNameNoExt if(FileNameNoExt = VideoFileNameNoExt){ MP3AudioFilepath := A_LoopFileFullPath } } ;---Read Info From Previous Run (If Any)--- ;------------------------------------------------ ; @todo: Figure out a way to do this with an array VideoLinksIniFile = %VideoFolderDir%\VideoLinks.ini if(FileExist(VideoLinksIniFile)){ ; IniRead, StreamanityURL, %VideoLinksIniFile%, URLs, StreamanityURL, %A_Space% IniRead, BitChuteURL, %VideoLinksIniFile%, URLs, BitChuteURL, %A_Space% ; LBRY IniRead, LBRYURLSlug, %VideoLinksIniFile%, Misc, LBRYURLSlug, %A_Space% if(LBRYURLSlug = ""){ LBRYURLSlug := OriginalLBRYURLSlug ; video title } ; LBRY Video IniRead, LBRYVideoURL, %VideoLinksIniFile%, URLs, LBRYVideoURL, %A_Space% IniRead, LBRYVideoThumb, %VideoLinksIniFile%, Misc, LBRYVideoThumb, %A_Space% IniRead, LBRYVideoPermanentURL, %VideoLinksIniFile%, URLs, LBRYVideoPermanentURL, %A_Space% IniRead, OdyseeVideoURL, %VideoLinksIniFile%, URLs, OdyseeVideoURL, %A_Space% IniRead, OdyseeVideoThumb, %VideoLinksIniFile%, Misc, OdyseeVideoThumb, %A_Space% OdyseeVideoThumb := StrReplace(OdyseeVideoThumb, "Thumb:", "") ; LBRY Audio IniRead, LBRYAudioURL, %VideoLinksIniFile%, URLs, LBRYAudioURL, %A_Space% IniRead, LBRYAudioThumb, %VideoLinksIniFile%, Misc, LBRYAudioThumb, %A_Space% IniRead, LBRYAudioPermanentURL, %VideoLinksIniFile%, URLs, LBRYAudioPermanentURL, %A_Space% IniRead, OdyseeAudioURL, %VideoLinksIniFile%, URLs, OdyseeAudioURL, %A_Space% IniRead, OdyseeAudioThumb, %VideoLinksIniFile%, Misc, OdyseeAudioThumb, %A_Space% OdyseeAudioThumb := StrReplace(OdyseeAudioThumb, "Thumb:", "") ; Others IniRead, RumbleURL, %VideoLinksIniFile%, URLs, RumbleURL, %A_Space% IniRead, BrighteonURL, %VideoLinksIniFile%, URLs, BrighteonURL, %A_Space% IniRead, DailyMotionURL, %VideoLinksIniFile%, URLs, DailyMotionURL, %A_Space% IniRead, PodcastNumber, %VideoLinksIniFile%, Misc, PodcastNumber, %A_Space% IniRead, LocalsURL, %VideoLinksIniFile%, URLs, LocalsURL, %A_Space% IniRead, FacebookURL, %VideoLinksIniFile%, URLs, FacebookURL, %A_Space% ; MISC IniRead, ErrorLoggingFilePath, %VideoLinksIniFile%, Misc, ErrorLoggingFilePath, %A_Space% IniRead, ScreenShotSavePath, %VideoLinksIniFile%, Misc, ScreenShotSavePath, %A_Space% if(VideoFileSizeInMB < 50){ IniRead, Telegram, %VideoLinksIniFile%, Misc, Telegram, %A_Space% } } ; Create a directory for errorlogging and screenshots if this is the first time working on this project if(ErrorLoggingFilePath = ""){ ; DevModeMsgBox("generating filepath") FormatTime, TodayDate , YYYYMMDDHH24MISS, yyyyMMdd_hhmmss ErrorLoggingDirectory := ErrorLoggingFolder . "\" . TodayDate . "_FVU" FileCreateDir, %ErrorLoggingDirectory% ErrorLoggingFilePath := ErrorLoggingFolder . "\" . TodayDate . "_FVU\ErrorLogging.txt" ; Set locaiton where error logging text will go ScreenShotSavePath = %ErrorLoggingDirectory% ; Write both filepaths to .ini file IniWrite, %ErrorLoggingFilePath%, %VideoLinksIniFile%, Misc, ErrorLoggingFilePath IniWrite, %ScreenShotSavePath%, %VideoLinksIniFile%, Misc, ScreenShotSavePath } if(PodcastNumber = ""){ PodcastNumber := StrSplit(VideoFileNameNoExt, "_") PodcastNumber := PodcastNumber[2] } ; Set the checkmark status of each item based on the variable status ; (StreamanityURL != "")?(StreamanityCheckStatus := 0) : (StreamanityCheckStatus := 1) (BitChuteURL != "")?(BitChuteCheckStatus := 0) : (BitChuteCheckStatus := 1) (OdyseeVideoURL != "")?(OdyseeVideoCheckStatus := 0) : (OdyseeVideoCheckStatus := 1) (OdyseeVideoThumb != "")?(OdyseeVideoThumbCheckStatus := 0) : (OdyseeVideoThumbCheckStatus := 0) OdyseeAudioThumbCheckStatus := 0 if(OdyseeAudioURL OR WavAudioFilepath = "") OdyseeAudioCheckStatus := 0 /* if(OdyseeAudioThumb OR WavAudioFilepath = "") OdyseeAudioThumbCheckStatus := 0 */ (RumbleURL != "")?(RumbleCheckStatus := 0) : (RumbleCheckStatus := 1) ; if user tried to upload to locals already and still needs to grab the url, check (LocalsURL = "LocalsUploadStartedNeedToGrabURL")?(LocalsCheckStatus := 1) : (LocalsCheckStatus := 0) (BrighteonURL != "")?(BrighteonCheckStatus := 0) : (BrighteonCheckStatus := 1) if(VideoFileSizeInMB > 6144){ VideoFileSizeOver6GB := 1 BrighteonCheckStatus := 0 } (DailyMotionURL != "")?(DailyMotionCheckStatus := 0) : (DailyMotionCheckStatus := 1) FacebookCheckStatus := 0 TelegramCheckStatus := 0 ;---Testing Mode Overrides--- ;------------------------------------------------ IniRead, TestingMode, %SettingsIniFilepath%, General, TestingMode, 0 if(TestingMode){ ; save currently seelcted sites to ini file for next test ; IniRead, Streamanity, %SettingsIniFilepath%, Testing, Streamanity, %A_Space% ; (Streamanity)?(StreamanityCheckStatus := 1) : (StreamanityCheckStatus := 0) IniRead, BitChute, %SettingsIniFilepath%, Testing, BitChute, %A_Space% (BitChute)?(BitChuteCheckStatus := 1) : (BitChuteCheckStatus := 0) IniRead, OdyseeVideo, %SettingsIniFilepath%, Testing, OdyseeVideo, %A_Space% (OdyseeVideo)?(OdyseeVideoCheckStatus := 1) : (OdyseeVideoCheckStatus := 0) IniRead, OdyseeVideoThumb, %SettingsIniFilepath%, Testing, OdyseeVideoThumb, %A_Space% (OdyseeVideoThumb)?(OdyseeVideoThumbCheckStatus := 1) : (OdyseeVideoThumbCheckStatus := 0) IniRead, OdyseeAudio, %SettingsIniFilepath%, Testing, OdyseeAudio, %A_Space% (OdyseeAudio)?(OdyseeAudioCheckStatus := 1) : (OdyseeAudioCheckStatus := 0) IniRead, OdyseeAudioThumb, %SettingsIniFilepath%, Testing, OdyseeAudioThumb, %A_Space% (OdyseeAudioThumb)?(OdyseeAudioThumbCheckStatus := 1) : (OdyseeAudioThumbCheckStatus := 0) IniRead, Rumble, %SettingsIniFilepath%, Testing, Rumble, %A_Space% (Rumble)?(RumbleCheckStatus := 1) : (RumbleCheckStatus := 0) IniRead, Brighteon, %SettingsIniFilepath%, Testing, Brighteon, %A_Space% (Brighteon)?(BrighteonCheckStatus := 1) : (BrighteonCheckStatus := 0) IniRead, DailyMotion, %SettingsIniFilepath%, Testing, DailyMotion, %A_Space% (DailyMotion)?(DailyMotionCheckStatus := 1) : (DailyMotionCheckStatus := 0) IniRead, Locals, %SettingsIniFilepath%, Testing, Locals, %A_Space% (Locals)?(LocalsCheckStatus := 1) : (LocalsCheckStatus := 0) IniRead, Telegram, %SettingsIniFilepath%, Testing, Telegram, %A_Space% (Telegram)?(TelegramCheckStatus := 1) : (TelegramCheckStatus := 0) IniRead, Facebook, %SettingsIniFilepath%, Testing, Facebook, %A_Space% (Facebook)?(FacebookCheckStatus := 1) : (FacebookCheckStatus := 0) } ; @todo: DELETE if(DevMode){ ; IniWrite, 0, %SettingsIniFilepath%, %ScriptSettingsSection%, UpdateAvailable ; UpdateAvailable := 0 ; Menu, Tray, Add, Reload to Results, ReloadToResults } ; Msgbox % "PassedParameter: " PassedParameter ; Msgbox % "PassedParameter: " PassedParameter if(PassedParameter = "ShowResults"){ msgbox, we are showing results goto, DisplayResults } ;---GUI Variables--- ;------------------------------------------------ GuiHeight = 800 GuiWidth = 1366 GuiFontSize = 10 ButtonHeights := 30 MarginSpace := 10 MarginSpaceDoubled := MarginSpace * 2 EditBoxWidths := (GuiWidth / 100) * 60 EditBoxHalfWidths := (EditBoxWidths / 2) - (MarginSpace / 2) OdyseeURLSlugEditWidth := (EditBoxHalfWidths / 4) * 3 PodcastNumberTextXPos := EditBoxHalfWidths + OdyseeURLSlugEditWidth + (MarginSpace * 3) PodcastNumberEditWidth := (EditBoxHalfWidths / 4) - MarginSpace EditBoxOneFourthWidth := (EditBoxWidths / 4 ) EditBoxThreeFourthsWidth := (EditBoxWidths / 4 ) * 3 ColumnOneHalfWidthXPos := EditBoxHalfWidths + MarginSpaceDoubled EditBoxThirdsWidths := (EditBoxWidths / 3) - (MarginSpace / 2) OdyseeURLSlugXPos := EditBoxHalfWidths + (MarginSpace * 2) EditBoxFourthWidths := (EditBoxWidths / 4) - (MarginSpace - 2) VideoTagsTextXPos := EditBoxHalfWidths + (MarginSpace * 2) ; EditBoxHalfWidthsWithMargin := (EditBoxWidths / 2) DescriptionCharCountXPos := EditBoxWidths - 40 PageTwoXStartPos := EditBoxWidths + 50 CopyButtonWidths := 150 ResultEditBoxXPos := CopyButtonWidths + MarginSpace + 5 ResultEditBoxWidths := EditBoxWidths - CopyButtonWidths ResultEditBoxHalfWidths := (ResultEditBoxWidths / 2) - (MarginSpace /2) ResultLBRYURLEditBoxWidthPieces := (ResultEditBoxWidths / 4) ResultLBRYURLEditBoxWidths := ResultLBRYURLEditBoxWidthPieces * 3 ResultEditBoxThirdsWidths := (ResultEditBoxWidths / 3) - (MarginSpace /3) ResultLBRYThumbEditBoxWidth := ResultLBRYURLEditBoxWidthPieces - 5 ErrorLogEditBoxXPos := ResultEditBoxWidths + CopyButtonWidths + 30 ErrorLogEditBoxHeight := GuiHeight - (MarginSpace * 20) - (ButtonHeights * 2) ErrorLogEditBoxWidth := GuiWidth - ErrorLogEditBoxXPos - (MarginSpace * 12) ButtonWidths := 150 ButtonXPos := GuiWidth - ButtonWidths - 15 SubmitButtonYLocation := GuiHeight - 50 SubmitButtonXLocation := GuiWidth - 90 CancelButtonXLocation := GuiWidth - 180 EditBoxHeight := 25 ThumbnailPreviewWidth := 300 PageTwoGroupBoxWidth := ThumbnailPreviewWidth + 20 ; Size of Description Edit Box and the location of the checkboxes underneath them VideoDescriptionEditBoxHeight = 100 CheckboxesStartYPos := 630 FilePathEditBoxWidths := EditBoxWidths - MarginSpace - 70 SelectFileButtonWidths := 30 ButtonStartYPos := CheckboxesStartYPos + 10 MarginSquared := MarginSpace * 2 if(DevMode){ MainButtonHeight := 30 SecondaryButtonHeights := 30 } else, { MainButtonHeight := 30 SecondaryButtonHeights := 35 } ;---Check for Update--- ;------------------------------------------------ if(AutoUpdateCheck AND !UpdateAvailable){ ; DevModeMsgBox("checking for updates") ; msgbox, checkin for update ; DevModeMsgBox(GitReleasesAPIURL) UpdateAvailable := CheckForUpdates(GitReleasesAPIURL) } ; DevModeMsgBox(AutoUpdateCheck) ; DevModeMsgBox(UpdateAvailable) ; -------------------------------GUI------------------------------- Gui, Font, s%GuiFontSize% Gui, Margin, %MarginSpace%, %MarginSpace% ; Video Title Gui, Font, Bold Gui, Add, Text,, Show Title Gui, Add, Text, x%ColumnOneHalfWidthXPos% yp+0,Odysee URL Slug Gui, Add, Text, x%PodcastNumberTextXPos% yp+0,Podcast # Gui, Font, Normal Gui, Add, Edit, y+5 x%MarginSpace% w%EditBoxHalfWidths% h%EditBoxHeight% gUpdateVars vVideoTitle, %VideoTitle% Gui, Add, Edit, yp+0 x+%Marginspace% w%OdyseeURLSlugEditWidth% h%EditBoxHeight% gUpdateVars vLBRYURLSlug, %LBRYURLSlug% Gui, Add, Edit, yp+0 x+%Marginspace% w%PodcastNumberEditWidth% h%EditBoxHeight% gUpdateVars vPodcastNumber, %PodcastNumber% ; LBRY URL Gui, Font, Bold Gui, Add, Text, x%Marginspace%,Video Tags Gui, Add, Text,x%ColumnOneHalfWidthXPos% yp+0,Podcast Tags Gui, Font, Normal Gui, Add, Edit, x%Marginspace% Y+5 w%EditBoxHalfWidths% h%EditBoxHeight% gUpdateVars vVideoTags, %VideoTags% Gui, Add, Edit, yp+0 x+%Marginspace% w%EditBoxHalfWidths% h%EditBoxHeight% gUpdateVars vPodcastTags, %PodcastTags% /*; Podcast Number & Tags Gui, Font, Bold Gui, Add, Text,x%MarginSpace% y+%Marginspace%,Podcast Number Gui, Font, Normal */ ; Video Description Gui, Font, Bold if(NoOriginalVideoDescription) Gui, Add, Text,cRed y+%Marginspace% x%Marginspace%,Video Description else, Gui, Add, Text,y+%Marginspace% x%Marginspace%,Video Description: if(TestingMode){ Gui, Add, Text,cRed yp+0 xp+150 ,TESTING MODE } if(DevMode){ Gui, Add, Text,cRed yp+0 xp+150 ,DEV MODE } Gui, Font, Normal Gui, Add, Edit,x%Marginspace% y+2 w%EditBoxWidths% h%VideoDescriptionEditBoxHeight% vVideoDescription gSubmitDescription,%VideoDescription% gui, font, s8 Gui, font, Bold if(DescriptionCharCount > 3000){ Gui, Add, Edit,cRed w50 h20 x%DescriptionCharCountXPos% y+1 vDescriptionCharCount, %DescriptionCharCount% } else, Gui, Add, Edit, w50 h20 x%DescriptionCharCountXPos% y+1 vDescriptionCharCount, %DescriptionCharCount% Gui, Font, Normal Gui, Add,Text, yp+3 xp-310, (Platform Char. Limits: DM+Bitchute = 3K, Odysee,Brighteon = 5K) Gui, Font, s%GuiFontSize% Gui, font, Bold Gui, Add, GroupBox,r8.5 x%MarginSpace% yp+10 w%EditBoxWidths% Center, Filepaths ; Video Filepath Gui, Font, Bold Gui, Add, Text,xp+5 yp+15,Video Filepath Gui, Font, Normal Gui, Add, Edit, x%MarginSquared% y+2 w%FilePathEditBoxWidths% h%EditBoxHeight% gUpdateVars vVideoFilepath,%VideoFilepath% Gui, Add, Button, x+5 yp+0 h%EditBoxHeight% gSelectVideoFilepath, Select ; Video Thumbnail Filepath Gui, Font, Bold if(NoOriginalVideoThumbFilepath) Gui, Add, Text, x%MarginSquared% CRed y+15,Video Thumbnail Filepath else, Gui, Add, Text,y+15 x%MarginSquared% ,Video Thumbnail Filepath Gui, Font, Normal Gui, Add, Edit, x%MarginSquared% y+2 w%FilePathEditBoxWidths% h%EditBoxHeight% gUpdateVars vVideoThumbFilepath,%VideoThumbFilepath% Gui, Add, Button, x+5 yp+0 h%EditBoxHeight% gSelectVideoThumbFilepath, Select ; WAV Audio File Filepath Gui, Font, Bold if(WavAudioFilepath = "") Gui, Add, Text,cRed x%MarginSquared% y+15,WAV Filepath else, Gui, Add, Text,x%MarginSquared% y+15,WAV Filepath Gui, Font, Normal Gui, Add, Edit, x%MarginSquared% y+2 w%FilePathEditBoxWidths% h%EditBoxHeight% gUpdateVars vWavAudioFilepath,%WavAudioFilepath% Gui, Add, Button, x+5 yp+0 h%EditBoxHeight% gSelectWAVFilepath, Select Gui, Font, Bold if(MP3AudioFilepath = "") Gui, Add, Text,cRed x%MarginSquared% y+15,Podcast MP3 Filepath else, Gui, Add, Text,x%MarginSquared% y+15,Podcast MP3 Filepath Gui, Font, Normal Gui, Add, Edit, x%MarginSquared% y+2 w%FilePathEditBoxWidths% h%EditBoxHeight% gUpdateVars vMP3AudioFilepath,%MP3AudioFilepath% Gui, Add, Button, x+5 yp+0 h%EditBoxHeight% gSelectMP3Filepath, Select ; Submit Button Gui, Font, s%GuiFontSize% gui, Font, Bold ; if(DevMode) ; Gui, Add, Button, x%MarginSpace% w%EditBoxHalfWidths% y+25 h%MainButtonHeight% gCancelPost hwndIcon, Close ; else, Gui, Add, Button, x%MarginSpace% w%EditBoxHalfWidths% y+25 h%MainButtonHeight% gCancelPost hwndIcon, Exit GuiButtonIcon(Icon, "imageres.dll",208, "s20 a1 r2") Gui, Add, Button, x+%MarginSpace% w%EditBoxHalfWidths% h%MainButtonHeight% gStartScript hwndIcon, Upload GuiButtonIcon(Icon, "shell32.dll", 136, "s20 a1 r2") if(DevMode) Gui, Add, Button, x%MarginSpace% w%EditBoxFourthWidths% y+%Marginspace% h%SecondaryButtonHeights% gDisplayResults hwndIcon, View Results else, Gui, Add, Button, x%MarginSpace% w%EditBoxFourthWidths% y+%Marginspace% h%SecondaryButtonHeights% gDisplayResults hwndIcon, View Results GuiButtonIcon(Icon, "shell32.dll", 210, "s20 a1 r2") Gui, Add, Button, w%EditBoxFourthWidths% x+%Marginspace% h%SecondaryButtonHeights% gOpenProjectFolder hwndIcon, Open Project Folder GuiButtonIcon(Icon, "shell32.dll", 267, "s20 a1 r2") if(UpdateAvailable){ Gui, Add, Button, w%EditBoxHalfWidths% x+%Marginspace% gUpdateScript vUpdateAvailable h%SecondaryButtonHeights% hwndIcon, Update Available - Click to Install GuiButtonIcon(Icon, "shell32.dll", 278, "s20 a1 r2") } else, { Gui, Add, Button, w%EditBoxHalfWidths% x+%Marginspace% gUpdateScript vUpdateAvailable h%SecondaryButtonHeights% hwndIcon, Up-to-Date ; Gui, Add, Button, w%EditBoxHalfWidths% x+%Marginspace% vUpdateAvailable hwndIcon, Script is Up-to-Date GuiButtonIcon(Icon, "shell32.dll", 239, "s20 a1 r2") } if(DevMode){ Gui, Add, Button, x%MarginSpace% w%EditBoxFourthWidths% h30 y+5 h%SecondaryButtonHeights% gOpenErrorLog, Open ErrorLog Gui, Add, Button, x+%MarginSpace% w%EditBoxFourthWidths% h30 h%SecondaryButtonHeights% gClearVideoLinks, Clear VideoLinks } ; -------------------------------Page 2 Side of Main GUI Window------------------------------- LineSplitXPosition := PageTwoXStartPos - ( MarginSpace * 2) gui, add, text, x%LineSplitXPosition% y20 h500 0x11 ; 0x11 is a "line" ; refer to here: https://autohotkey.com/board/topic/50910-draw-line-gui/ ; Thumbnail Preview Gui, Font, Normal gui, Font, s4 ; Miscellaneous Settings DevModToggleButton := PageTwoXStartPos + 160 Gui, Add, Button, x%DevModToggleButton% y5 w50 h10 gToggleDevMode,DevMode Gui, Add, Button, x+5 y5 w50 h10 gToggleTestingMode, Testing Mode Gui, Add, Button, x+5 y5 w50 h10 gOpenGiteaPage, Gitea Gui, Font, s%GuiFontSize% Gui, Font, Bold Gui, Add, GroupBox,r5 y+0 x%PageTwoXStartPos% w%PageTwoGroupBoxWidth%,Settings ; Gui, Add, Text, y%CheckboxesStartYPos% x+80, Miscellaneous Settings: ; Gui, Font, Normal ; Gui, Add, Checkbox, vIncludeDescriptionWhenPostingToVideos %IncludeDescriptionWhenPostingToVideos%, Include Description in #videos Posts Gui, Add, Checkbox, xp+10 yp+20 vReuseTabs Checked%ReuseTabsCheckStatus% gUpdateVars, Try to Re-Use Tabs Gui, Add, Checkbox, vShowTooltipProgress Checked%ShowTooltipProgressCheckStatus% gUpdateVars,Show Tooltip Progress Gui, Add, Checkbox, vKillLBRYAfterUpload Checked%KillLBRYAfterUploadCheckStatus% ,Kill LBRY After Uploading Gui, Add, Checkbox, vAutoUpdateCheck gUpdateVars Checked%AutoUpdateCheckCheckStatus%, Auto Update Check Gui, Add, Checkbox, vAutoLogin gUpdateVars Checked%AutoLoginCheckStatus%, Try to Login Automatically Gui, Add, Checkbox, vPingOnCompletion gUpdateVars Checked%PingOnCompletionCheckStatus%, Discord Ping Upon Finish ; Gui, Add, Checkbox, vAutoUploadErrorLog gUpdateVars Checked%AutoUploadErrorLog%, Auto-Upload Large Errors GroupBoxCheckboxPos := PageTwoXStartPos + MarginSpace ; -------------------------------PLATFORMS------------------------------- Gui, Add, GroupBox,r8 y+15 x%PageTwoXStartPos% w%PageTwoGroupBoxWidth%, Platforms ; Gui, Add, Text,y+25 x%PageTwoXStartPos%, ---Platforms---- ; Gui, Font, Bold ; Msgbox % "LocalsURL: " LocalsURL if(LocalsURL = "LocalsUploadStartedNeedToGrabURL"){ Gui, Add, Checkbox, xp+10 yp+25 vLocalsGrabURL Checked%LocalsCheckStatus%, Locals (Grab URL) } else, { Gui, Add, Checkbox, xp+10 yp+25 vLocals Checked%LocalsCheckStatus%, Locals } ; if(VideoFileSizeInMB < 1792) ; Gui, Add, Checkbox, x+%MarginSpaceDoubled% vFacebook Checked%FacebookCheckStatus%, Facebook Gui, Add, Checkbox, x%GroupBoxCheckboxPos% y+%MarginSpace% vBitChute Checked%BitChuteCheckStatus%, BitChute if(VideoFileSizeInMB < 50) Gui, Add, Checkbox, vTelegram x+%MarginSpaceDoubled% Checked%TelegramCheckStatus%, Telegram Gui, Add, Checkbox, x%GroupBoxCheckboxPos% y+%MarginSpace% vOdyseeVideo Checked%OdyseeVideoCheckStatus%, Odysee Video ; Gui, Add, Checkbox, x+%MarginSpace% vOdyseeVideoThumb Checked%OdyseeVideoThumbCheckStatus%,Thumbnail Gui, Add, Checkbox, x%GroupBoxCheckboxPos% y+%MarginSpace% vOdyseeAudio Checked%OdyseeAudioCheckStatus%, Odysee Audio ; Gui, Add, Checkbox, x+%MarginSpace% vOdyseeAudioThumb Checked%OdyseeAudioThumbCheckStatus%, Thumbnail Gui, Add, Checkbox, x%GroupBoxCheckboxPos% y+%MarginSpace% vRumble Checked%RumbleCheckStatus%, Rumble Gui, Add, Checkbox, vBrighteon y+%MarginSpace% Checked%BrighteonCheckStatus%, Brighteon Gui, Add, Checkbox, vDailyMotion y+%MarginSpace% Checked%DailyMotionCheckStatus%, DailyMotion ; Gui, Add, Checkbox, vStreamanity Checked%StreamanityCheckStatus%, Streamanity ; Gui, Font, s12 gui, Font, Bold Gui, Add, GroupBox, r6.5 y+15 vImageThumbnail x%PageTwoXStartPos% w%PageTwoGroupBoxWidth%,Thumbnail gui, Font, Normal Gui, Add, Picture, xp+10 yp+20 w%ThumbnailPreviewWidth% h-1, %VideoThumbFilepath% gui, Font, Normal gui, font, s7 Gui, Add, StatusBar,Center, Total Videos Uploaded: %TotalVideosUploaded% ; SB_SetText("There are " . RowCount . " rows selected.") ; Show GUI to the user Gui, +Resize +MaximizeBox Gui, Show,, %FullScriptName% - Upload Settings - %BodyTextFilePath% ControlFocus, Edit1, %FullScriptName% ToolTip ; Gui, Maximize ; Gui, Show, w%GuiWidth% h%GuiHeight%, %ScriptName% if(SkipToDBInfo){ gui, submit goto, DisplayResults } ; Write current project to ini file for easy reloading IniWrite, %BodyTextFilePath%, %SettingsIniFilepath%, %ScriptSettingsSection%, LastPost ; calculate run time and convert to seconds ; URunTime := round(((A_TickCount - UStartTime) / 1000), 2) ; Msgbox % "URunTime: " URunTime Return ; -------------------------------GUI GoSubs------------------------------- ; Kill the script if user clicks on cancel button KillScript: ; GuiClose: ExitApp Return PauseScript: Pause,Toggle Return CancelPost: GuiClose: ; ExitApp Gui, Submit, Return ReloadScript: Reload Return ; Gets activated each time that text gets input into any of the text boxes ; updates the variables with the new text UpdateVars: Gui, Submit, NoHide Return SubmitDescription: Gui, Submit, NoHide DescriptionCharCount := StrLen(VideoDescription) GuiControl,, DescriptionCharCount, %DescriptionCharCount% Return ; Open folder of the project OpenProjectFolder: run, %VideoFolderDir% Return ClearVideoLinks: FileDelete, %VideoLinksIniFile% Return OpenErrorLog: run, %ErrorLoggingFilePath% Return ToggleTestingMode: ToggleTestingMode() run, "%A_ScriptFullPath%" "LastPost" Return ToggleDevMode: ToggleDevMode() run, "%A_ScriptFullPath%" "LastPost" Return OpenGiteaPage: run, https://git.freedomainplaylists.com/yuriy/Freedomain-Video-Uploader Return SelectVideoFilepath: FileSelectFile, VideoFilepath,, %FileDir%, Select Video File GuiControl,, VideoFilepath, %VideoFilepath% Return SelectWAVFilepath: FileSelectFile, WavAudioFilepath,, %FileDir%, Select WAV File GuiControl,, WavAudioFilepath, %WavAudioFilepath% GuiControl,, OdyseeAudio, 1 GuiControl,, OdyseeAudioThumb, 1 Return SelectMP3Filepath: FileSelectFile, MP3AudioFilepath,, %FileDir%, Select MP3 File if(!InStr(MP3AudioFilepath, ".mp3")){ msgbox, 4096, Error, Selected File is not an .mp3 file. `nPlease try again. Return } GuiControl,, MP3AudioFilepath, %MP3AudioFilepath% Return SelectVideoThumbFilepath: FileSelectFile, VideoThumbFilepath,, %FileDir%, Select Thumbnail File if(!InStr(VideoThumbFilepath, FileDir)){ ; ToolTip, Thumbnail Copied to Project Folder, 850, 0 TimedToolTip("Thumbnail Copied to Project Folder",,,1000) SplitPath, VideoThumbFilepath, OutFileName, OutDir, OutExtension, OutNameNoExt, OutDrive FileCopy, %VideoThumbFilepath%, %FileDir%\*,1 VideoThumbFilepath = %FileDir%\%OutFileName% ; Msgbox % "VideoThumbFilepath: " VideoThumbFilepath } GuiControl,, VideoThumbFilepath, %VideoThumbFilepath% ; GuiControl,, ImageThumbnail,%VideoThumbFilepath% Return ; Download updates from google drive and save it to the location of the script and then reload the script UpdateScript: UpdateScript() ; @todo: Save any changes made to the script before installing update Return ; now defunt, safe to remove CreateDescriptionForVideosPosting: ; msgbox, here Gui, VideoDescriptionTrimmer:New, Gui, Font, s%GuiFontSize% Gui, Add, Text,, Discord and Telegram have a maximum API post length of 2000 Characters `nwhich the curent description exceeds.`nPlease Trim down the description and then click submit. Gui, Font, s%GuiFontSize% Gui, Add, Edit, w800 h500 gUpdateVars vVideoDescriptionForVideosChannel, %VideoDescription% Gui, Add, Button, gSubmitDescriptionForVideosChannel, Submit gui, Show,w820, Video Description Trimmer ; msgbox Return SubmitDescriptionForVideosChannel: Gui, Submit ; msgbox, submitted if(CurrentSocialMediaPosting = "Discord") Goto, SubmitDescriptionForDiscordVideosChannel if(CurrentSocialMediaPosting = "Telegram") Goto, SubmitDescriptionForTelegramVideosChannel if(CurrentSocialMediaPosting = "Telegram Video") goto, SubmitDescriptionForTelegramVideoUpload Return CreateDescriptionForSocialMedia(){ SplitText = Free Documentaries: SocialMediaDescription := StrSplit(VideoDescription, SplitText) SocialMediaDescription := SocialMediaDescription[1] if(strlen(SocialMediaDescription) > 1400){ SocialMediaDescription := SubStr(SocialMediaDescription, 1, 1400) SocialMediaDescription .= "..." } Return } ; -------------------------------Upload Video Functionality------------------------------- StartScript: WinGetPos, XPosition, YPosition, , , A ; Msgbox % "XPosition: " XPosition ; Msgbox % "YPosition: " YPosition Gui, Submit Gui, Destroy ;---Save Testing Mode Info--- ;------------------------------------------------ if(TestingMode){ ; save currently seelcted sites to ini file for next test ; IniWrite, %Streamanity%, %SettingsIniFilepath%, Testing, Streamanity IniWrite, %BitChute%, %SettingsIniFilepath%, Testing, BitChute IniWrite, %OdyseeVideo%, %SettingsIniFilepath%, Testing, OdyseeVideo IniWrite, %OdyseeVideoThumb%, %SettingsIniFilepath%, Testing, OdyseeVideoThumb IniWrite, %OdyseeAudio%, %SettingsIniFilepath%, Testing, OdyseeAudio IniWrite, %OdyseeAudioThumb%, %SettingsIniFilepath%, Testing, OdyseeAudioThumb IniWrite, %Rumble%, %SettingsIniFilepath%, Testing, Rumble IniWrite, %Brighteon%, %SettingsIniFilepath%, Testing, Brighteon IniWrite, %DailyMotion%, %SettingsIniFilepath%, Testing, DailyMotion IniWrite, %Locals%, %SettingsIniFilepath%, Testing, Locals IniWrite, %Telegram%, %SettingsIniFilepath%, Testing, Telegram IniWrite, %Facebook%, %SettingsIniFilepath%, Testing, Facebook } ;---\Save Testing Mode Info--- ;------------------------------------------------ ; -------------------------------Save All Info .txt Files------------------------------- /*; Msgbox % "NOOriginalVideoTitle: " NOOriginalVideoTitle if(VideoTitleEmpty){ ; msgbox, appending title. FileAppend, %VideoTitle%, %VideoFolderDir%\title.txt } if(VideoDescriptionEmpty){ ; msgbox, appending description FileAppend, %VideoDescription%, %VideoFolderDir%\body.txt } if(VideoTagsEmpty){ ; msgbox, appending vieo tags FileAppend, %VideoTags%, %VideoFolderDir%\keywords.txt } if(PodcastTagsEmpty){ ; msgbox, appending vieo tags FileAppend, %VideoTags%, %VideoFolderDir%\keywords.txt } */ ; -------------------------------Save Video Info------------------------------- ; if changes made, delete the original file and save the new content to it if(VideoTitle != OriginalVideoTitle){ VideoTitleFilepath = %VideoFolderDir%\title.txt FileDelete, %VideoTitleFilepath% FileAppend, %VideoTitle%, %VideoTitleFilepath% } if(VideoTags != OriginalVideoTags){ VideoTagsFilepath = %VideoFolderDir%\keywords.txt FileDelete, %VideoTagsFilepath% FileAppend, %VideoTags%, %VideoTagsFilepath% } if(PodcastTags != OriginalPodcastTags){ PodcastTagsFilepath = %VideoFolderDir%\keywords_podcast.txt FileDelete, %PodcastTagsFilepath% FileAppend, %PodcastTags%, %PodcastTagsFilepath% } if(VideoDescription != OriginalVideoDescription){ VideoBodyFilepath = %VideoFolderDir%\body.txt FileDelete, %VideoBodyFilepath% FileAppend, %VideoDescription%, %VideoBodyFilepath% } ; -------------------------------/Save Video Info------------------------------- ; Save settings to config file IniWrite, %ReuseTabs%, %SettingsIniFilepath%, General, ReuseTabs IniWrite, %ShowTooltipProgress%, %SettingsIniFilepath%, General, ShowTooltipProgress IniWrite, %AutoUpdateCheck%, %SettingsIniFilepath%, General, AutoUpdateCheck IniWrite, %AutoLogin%, %SettingsIniFilepath%, General, AutoLogin IniWrite, %PingOnCompletion%, %SettingsIniFilepath%, General, PingOnCompletion IniWrite, %KillLBRYAfterUpload%, %SettingsIniFilepath%, General, KillLBRYAfterUpload if(VideoFilepath = ""){ Msgbox,4096,Error,No Video Filepath Found.`nPlease Input Video Filepath to Upload a Video. run, "%A_ScriptFullPath%" "LastPost" ExitApp } ; -------------------------------/Save All Info .txt Files------------------------------- ; Format the LBRYURLSlug to be API Compatible if(LBRYURLSlug = "") ; if slug spot is blank, then set it to video title LBRYURLSlug := VideoTitle LBRYURLSlug := LBRYCMDTextReplacement(LBRYURLSlug) ; Msgbox % "LBRYURLSlug: " LBRYURLSlug ; Save the LBRY URL Slug to .ini file in case it's needed later IniWrite, %LBRYURLSlug%, %VideoLinksIniFile%, Misc, LBRYUrlSlug IniWrite, %VideoThumbFilepath%, %VideoLinksIniFile%, Misc, VideoThumbFilepath IniWrite, %PodcastNumber%, %VideoLinksIniFile%, Misc, PodcastNumber ; -------------------------------Log Info To Text------------------------------- (Facebook = 1)?(PostedWebsites .= "Facebook|") : () (Bitchute = 1)?(PostedWebsites .= "Bitchute|") : () (Locals = 1)?(PostedWebsites .= "Locals|") : () (Rumble = 1)?(PostedWebsites .= "Rumble|") : () (Brighteon = 1)?(PostedWebsites .= "Brighteon|") : () ; (Streamanity = 1)?(PostedWebsites .= "Streamanity|") : () (Telegram = 1)?(PostedWebsites .= "Telegram|") : () (DailyMotion = 1)?(PostedWebsites .= "DailyMotion|") : () (OdyseeVideo = 1)?(PostedWebsites .= "OdyseeVideo|") : () (OdyseeAudio = 1)?(PostedWebsites .= "OdyseeAudio|") : () ; Log Basic info to the errorlogging file Message = %ScriptName% v%ScriptVersion%: Starting Upload `nFor: **%VideoTitle%**`nTo: %PostedWebsites% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") Message := "VideoTitle: " VideoTitle SaveOrPostProgress(Message:=Message,PostType:=",ErrorLoggingTextFile") Message := "VideoDescription: `n" VideoDescription SaveOrPostProgress(Message:=Message,PostType:=",ErrorLoggingTextFile") Message := "VideoTags: " VideoTags SaveOrPostProgress(Message:=Message,PostType:=",ErrorLoggingTextFile") Message := "VideoFilepath: " VideoFilepath SaveOrPostProgress(Message:=Message,PostType:=",ErrorLoggingTextFile") Message := "VideoThumbFilepath: " VideoThumbFilepath SaveOrPostProgress(Message:=Message,PostType:=",ErrorLoggingTextFile") Message := "TotalVideosUploaded: " TotalVideosUploaded SaveOrPostProgress(Message:=Message,PostType:=",ErrorLoggingTextFile") ; Convert Video Description into javascript text format for sending to selenium JSVideoDescription := FormatTextToJSText(VideoDescription) JSVideoTitle := FormatTextToJSText(VideoTitle) ; Save json description to errorlogging file ; Message = JSVideoDescription: `n" %JSVideoDescription% ; SaveOrPostProgress(Message:=Message,PostType:=",ErrorLoggingTextFile") ; -------------------------------/Log Info To Text------------------------------- ; Create an array out of the keywords to be used in different places VideoTags := StrReplace(VideoTags, ", ",",") VideoTags := StrReplace(VideoTags, " ,",",") VideoTags := StrReplace(VideoTags, " ",",") KeywordsArray := StrSplit(VideoTags,",") ; Initiate Chrome Filepath Variable ; @todo: find a better location for this? GetChromeFilepath() if(Facebook){ UploadedToSites .= "Facebook," ; gosub, FacebookUpload } if(Telegram){ UploadedToSites .= "Telegram," gosub, TelegramVideoUpload } ; Call each sub one by one, if errors occur then an upload will be stopped and the next upload will then proceed if(Locals){ UploadedToSites .= "Locals," gosub, LocalsUpload } if(BitChute){ UploadedToSites .= "Bitchute," Gosub, BitChuteUpload } if(OdyseeVideo){ UploadedToSites .= "LBRYVideo," LBRYUploadType := "Video" Gosub, LBRYVideoUpload } if(OdyseeAudio){ UploadedToSites .= "LBRYAudio," LBRYUploadType := "Audio" Gosub, LBRYAudioUpload } if(Rumble){ UploadedToSites .= "Rumble," Gosub, RumbleUpload } if(Brighteon){ UploadedToSites .= "Brighteon," Gosub, BrighteonUpload } if(DailyMotion){ UploadedToSites .= "DailyMotion," Gosub, DailyMotionUpload } ; grab the LBRY Video/Audio URLs if(OdyseeVideo){ LBRYUploadType := "Video" Gosub, LBRYGetURL } if(OdyseeAudio){ LBRYUploadType := "Audio" Gosub, LBRYGetURL } /* if(OdyseeVideoThumb){ OdyseeUploadType := "Video" Gosub, OdyseeVideoThumbUpload } */ /* if(OdyseeAudioThumb){ OdyseeUploadType := "Audio" Gosub, OdyseeAudioThumbUpload } */ if(LocalsGrabURL OR LocalsURL = "LocalsUploadStartedNeedToGrabURL"){ Gosub, LocalsGrabURL } if(URLOfLastErrorPage != ""){ Message = Activating Tab of last failed post. SaveOrPostProgress(Message:=Message,PostType:="Tooltip") ; @todo: replaceme with working funciton to activate tab ; FindAndActivateTab(URLOfLastErrorPage) } CurrentSite := "" ; if(StreamanityURL AND StreamanityCheckStatus) ; this feels soooooooooooooo ineficient, but i'm not sure how else to do this ; if(StreamanityCheckStatus AND !InStr(StreamanityURL, "streamanity")) ; if checked and URL is blank, report error ; Status := "Failures" /* if(URLOfLastErrorPage){ Status := "Failures" } else, { Status := "Success" } if(OdyseeVideoCheckStatus and !InStr(OdyseeVideoURL, "odysee")) Status := "Failures" else if(OdyseeAudioCheckStatus AND !InStr(OdyseeAudioURL, "odysee")) Status := "Failures" else if(BitChuteCheckStatus AND !InStr(BitChuteURL, "bitchute")) Status := "Failures" else if(RumbleCheckStatus AND !InStr(RumbleURL, "rumble")) Status := "Failures" else if(DailyMotionCheckStatus AND !InStr(DailyMotionURL, "dailymotion")) Status := "Failures" else if(BrighteonCheckStatus AND !InStr(BrighteonURL, "brighteon")) Status := "Failures" */ ; DevModeMsgBox(status) ; Msgbox % "status: " status if(URLOfLastErrorPage) Message = Video Uploading Finished WITH Some Failures else, Message = All Videos Uploaded Successfully /* if(StreamanityURL != "" AND OdyseeVideoURL != "" AND OdyseeAudioURL != "" and BitChuteURL != "" AND RumbleURL != "" and DailyMotionURL != "" and BrighteonURL != "") Message = All Videos Uploaded Successfully else, Message = Video Uploading Finished WITH Some Failures */ if(PingOnCompletion) Message = <@%DiscordUsernameID%>: %Message% else, Message = %Message% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") DisplayResults: Gui, Destroy ; @todo: Add a way to check if uploads finished with or without errors Tooltip ; Remove all tooltips IniRead, TotalVideosUploaded, %SettingsIniFilepath%, General, TotalVideosUploaded, %A_Space% ; IniRead, StreamanityURL, %VideoLinksIniFile%, URLs, StreamanityURL, %A_Space% IniRead, BitChuteURL, %VideoLinksIniFile%, URLs, BitChuteURL, %A_Space% IniRead, OdyseeVideoURL, %VideoLinksIniFile%, URLs, OdyseeVideoURL, %A_Space% IniRead, OdyseeVideoThumb, %VideoLinksIniFile%, Misc, OdyseeVideoThumb, %A_Space% OdyseeVideoThumb := StrReplace(OdyseeVideoThumb, "Thumb:", "") IniRead, OdyseeAudioURL, %VideoLinksIniFile%, URLs, OdyseeAudioURL, %A_Space% IniRead, OdyseeAudioThumb, %VideoLinksIniFile%, Misc, OdyseeAudioThumb, %A_Space% OdyseeAudioThumb := StrReplace(OdyseeAudioThumb, "Thumb:", "") IniRead, LocalsURL, %VideoLinksIniFile%, URLs, LocalsURL, %A_Space% IniRead, RumbleURL, %VideoLinksIniFile%, URLs, RumbleURL, %A_Space% IniRead, FacebookURL, %VideoLinksIniFile%, URLs, FacebookURL, %A_Space% IniRead, BrighteonURL, %VideoLinksIniFile%, URLs, BrighteonURL, %A_Space% IniRead, DailyMotionURL, %VideoLinksIniFile%, URLs, DailyMotionURL, %A_Space% IniRead, PodcastNumber, %VideoLinksIniFile%, Misc, PodcastNumber, %A_Space% if(PodcastNumber = "") { SplitPath, VideoFilepath,,,, VideoNameNoExt ; Remove the FDR_#### from video title for LBRY URL if(InStr(VideoNameNoExt, "FDR_")){ FoundPos := InStr(VideoNameNoExt, "_",,,2) ; get position of second instance of an "_" if(FoundPos < 11){ ; FoundPos += 1 ; Msgbox % "FoundPos: " FoundPos PodcastNumber := SubStr(VideoNameNoExt,1, FoundPos) PodcastNumber := StrReplace(PodcastNumber, "FDR", "") PodcastNumber := StrReplace(PodcastNumber, "_", "") ; Msgbox % "PodcastNumber: " PodcastNumber } } } Gui, Font, s%GuiFontSize% Gui, Font, Bold ; Gui, Add, Text,x10 y+10, Podcast #: Gui, Add, Button, x10 y+%Marginspace% h%ButtonHeights% w%CopyButtonWidths% gCopyPodcastNumber, Podcast # Gui, Font, Normal Gui, Add, Edit, x+5 yp+0 h%ButtonHeights% w%ResultEditBoxWidths% gUpdateVars vPodcastNumber, %PodcastNumber% ; Gui, Add, Edit, x+5 h200 w200, This is some text that goes here! ; Gui, Add, Text,x10 y+20, Title: ; Gui, Font, Bold ; Gui, Add, Button, x10 y+%Marginspace% h%ButtonHeights% w%CopyButtonWidths% gCopyVideoTitle, Title ; Gui, Font, Normal ; Gui, Add, Edit, x+5 yp+0 h%ButtonHeights% w%ResultEditBoxWidths% gUpdateVars vVideoTitle, %VideoTitle% ; Gui, Add, Button, x+1 w20, Copy Title ; Gui, Add, Text,x10 y+20, Bitchute: Gui, Font, Bold Gui, Add, Button, x10 y+%Marginspace% h%ButtonHeights% w%CopyButtonWidths% gCopyBitChuteURL, Bitchute Gui, Font, Normal Gui, Add, Edit, x+5 yp+0 h%ButtonHeights% vBitChuteURL w%ResultEditBoxWidths% gUpdateVars , %BitChuteURL% ; Gui, Add, Edit, x+5 yp+0 w%ResultLBRYThumbEditBoxWidth% gUpdateVars, Facebook: %FacebookURL% ; Gui, Add, Button, x+1 w20, Copy BitChute ; Gui, Add, Text,x10 y+20, Brighteon: Gui, Font, Bold Gui, Add, Button, x10 y+%Marginspace% h%ButtonHeights% w%CopyButtonWidths% gCopyBrighteonURL, Brighteon Gui, Font, Normal Gui, Add, Edit, x+5 yp+0 h%ButtonHeights% vBrighteonURL w%ResultEditBoxWidths% gUpdateVars , %BrighteonURL% ; Gui, Add, Text,x10 y+20, DailyMotion: Gui, Font, Bold Gui, Add, Button, x10 y+10 h%ButtonHeights% w%CopyButtonWidths% gCopyDailyMotionURL, DailyMotion Gui, Font, Normal Gui, Add, Edit, x+5 yp+0 h%ButtonHeights% vDailyMotionURL w%ResultEditBoxWidths% gUpdateVars , %DailyMotionURL% ; Gui, Add, Text,x10 y+20, Odysee: Gui, Font, Bold Gui, Add, Button, x10 y+10 h%ButtonHeights% w%CopyButtonWidths% gCopyOdyseeVideoURL, Odysee Video Gui, Font, Normal Gui, Add, Edit, x+5 yp+0 h%ButtonHeights% vOdyseeVideoURL w%ResultEditBoxWidths% gUpdateVars, %OdyseeVideoURL% ; Gui, Add, Button, x+5 yp+0, Thumb ; Gui, Add, Edit, x+5 yp+0 h%ButtonHeights% vOdyseeVideoThumb w%ResultLBRYThumbEditBoxWidth% gUpdateVars, Thumb: %OdyseeVideoThumb% Gui, Font, Bold Gui, Add, Button, x10 y+10 h%ButtonHeights% w%CopyButtonWidths% gCopyOdyseeAudioURL, Odysee Audio Gui, Font, Normal Gui, Add, Edit, x+5 yp+0 h%ButtonHeights% vOdyseeAudioURL w%ResultEditBoxWidths% gUpdateVars , %OdyseeAudioURL% ; Gui, Add, Button, x+5 yp+0, Thumb ; Gui, Add, Edit, x+5 yp+0 vOdyseeAudioThumb w%ResultLBRYThumbEditBoxWidth% gUpdateVars, Thumb: %OdyseeAudioThumb% Gui, Font, Bold Gui, Add, Button, x10 y+10 h%ButtonHeights% w%CopyButtonWidths% gCopyRumbleURL, Rumble Gui, Font, Normal Gui, Add, Edit, x+5 yp+0 h%ButtonHeights% vRumbleURL w%ResultEditBoxWidths% gUpdateVars , %RumbleURL% /*Gui, Font, Bold Gui, Add, Button, x10 y+10 h%ButtonHeights% w%CopyButtonWidths% gCopyStreamanityURL, Streamanity Gui, Font, Normal Gui, Add, Edit, x+5 yp+0 h%ButtonHeights% vStreamanityURL w%ResultEditBoxWidths% gUpdateVars , %StreamanityURL% */ Gui, Font, Bold Gui, Add, Button, x10 y+10 h%ButtonHeights% w%CopyButtonWidths%, Locals Gui, Font, Normal Gui, Add, Edit, x+5 yp+0 h%ButtonHeights% vLocalsURL w%ResultEditBoxWidths% gUpdateVars, %LocalsURL% Gui, Font, Bold Gui, Add, Button, x10 y+10 h%ButtonHeights% w%CopyButtonWidths% gCopyVideoTags, Video Tags Gui, Font, Normal Gui, Add, Edit, x+5 yp+0 h%ButtonHeights% vVideoTags w%ResultEditBoxWidths% gUpdateVars , %VideoTags% Gui, Font, Bold Gui, Add, Button, x10 y+10 h%ButtonHeights% w%CopyButtonWidths% gCopyPodcastTags, Podcast Tags Gui, Font, Normal Gui, Add, Edit, x+5 yp+0 h%ButtonHeights% vPodcasttags w%ResultEditBoxWidths% gUpdateVars , %Podcasttags% Gui, Font, Bold Gui, Add, Button, x%Marginspace% y+10 h%ButtonHeights% w%CopyButtonWidths% gCopyVideoDescription, Description Gui, Font, Normal Gui, Add, Edit, x+5 yp+0 h50 vVideoDescription w%ResultEditBoxWidths% gUpdateVars , %VideoDescription% Gui, Font, s%GuiFontSize% Gui, Font, Bold Gui, Add, Button, y+%MarginSpace% w%ResultEditBoxHalfWidths%gSendErrorLoggingThroughTelegram, Send Errorlog Through Telegram Gui, Add, Button, x+%MarginSpace% w%ResultEditBoxHalfWidths% gRetryUpload, Try Failed Again Gui, Add, Button, x%ResultEditBoxXPos% w%ResultEditBoxHalfWidths% gUpdateINI, Update Project Files with Changes Gui, Add, Button, x+%MarginSpace% w%ResultEditBoxHalfWidths% gUploadPodcast, Upload Podcast Gui, Add, Button, x%ResultEditBoxXPos% y+%MarginSpace% w%ResultEditBoxThirdsWidths% gPostToDiscord vPostToDiscordButton, Post to Discord Gui, Add, Button, x+5 w%ResultEditBoxThirdsWidths% gPostToTelegram vPostToTelegramButton, Post to Telegram Gui, Add, Button, x+5 w%ResultEditBoxThirdsWidths% gStartSocialMediaPoster, Start Social Media Poster Gui, Add, Button, x%ResultEditBoxXPos% w%ResultEditBoxHalfWidths% gOpenLBRYBlobFilesFolder %ButtonWidths% , Open LBRY Blob Files Folder Gui, Add, Button, x+%MarginSpace% w%ResultEditBoxHalfWidths% gCancelPost %ButtonWidths% , Close ; Gui, Add, Button, x+%MarginSpace% w%ResultEditBoxHalfWidths% gKillScript %ButtonWidths% , Close ; gui, Add, Text, y+10 Gui, Font, s%GuiFontSize% Gui, Add, Button, x%ErrorLogEditBoxXPos% w%ErrorLogEditBoxWidth% y%MarginSpace% h%ButtonHeights%, Error Log Gui, Add, Edit,x%ErrorLogEditBoxXPos% h%ErrorLogEditBoxHeight% w%ErrorLogEditBoxWidth% y+10, %ErrorLogVar% gui, font, Normal gui, font, s7 Gui, Add, StatusBar,, Total Videos Uploaded: %TotalVideosUploaded% Gui, +Resize +MaximizeBox OriginalVideoDescription := VideoDescription OriginalPodcastTags := PodcastTags Gui, Show,,%FullScriptName% - Upload Results SaveCurrentChromeVersionToIniFile() Return OpenLBRYBlobFilesFolder: run, C:\Users\%A_UserName%\AppData\Local\lbry\lbrynet\blobfiles Return StartSocialMediaPoster: ; IniRead, SocialMediaPosterFilepath, %SettingsIniFilepath%, General, FDRRadioUN, %A_Space% IniRead, SocialMediaPosterFilepath, %SettingsIniFilepath%, SocialMediaPoster, SocialMediaPosterFilepath, %A_Space% if(SocialMediaPosterFilepath = "" or !FileExist(SocialMediaPosterFilepath)){ OnMessage(0x44, "OnMsgBoxSocialMediaPoster") MsgBox 0x21, No Filepath Found, Unable to find filepath for Social Media Poster`nWould you like to add it? OnMessage(0x44, "") IfMsgBox OK, { FileSelectFile, SocialMediaPosterFilepath,,, Please Select Social Media Poster if(ErrorLevel) Return ; Msgbox % "SocialMediaPosterFilepath: " SocialMediaPosterFilepath ; if(!InStr(SocialMediaPosterFilepath, ".ahk") OR !InStr(SocialMediaPosterFilepath, ".exe")) ; Return } Else IfMsgBox Cancel, { Return } ; IniRead, SocialMediaPosterFilepath, %SettingsIniFilepath%, SocialMediaPoster, SocialMediaPosterFilepath, %A_Space% IniWrite, SocialMediaPosterFilepath, %SettingsIniFilepath%, SocialMediaPoster, SocialMediaPosterFilepath ; Return } ; msgbox %SocialMediaPosterFilepath% run, %SocialMediaPosterFilepath% "%VideoLinksIniFile%" Return /* */ ; -------------------------------Podcast------------------------------- UploadPodcast: CurrentSite := "Podcast" PodcastTags := StrReplace(PodcastTags, " ,", ",") PodcastTags := StrReplace(PodcastTags, ", ", ",") PodcastTags := StrReplace(PodcastTags, " ", "-") PodcastTags := StrReplace(PodcastTags, "--", "-") PodcastTags := StrReplace(PodcastTags, "--", "-") ; Msgbox % "PodcastTags: " PodcastTags Message = Starting Upload SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") IniRead, FDRRadioURL, %SettingsIniFilepath%, General, FDRRadioURL, %A_Space% if(FDRRadioURL = ""){ Message = FDRRadioURL is blank.`nPlease add URL to Settings.ini file under:`n`n[General]`nFDRRadioURL= SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") MsgBox 0x10,, %Message% Return } IniRead, Username, %SettingsIniFilepath%, General, FDRRadioUN, %A_Space% IniRead, Password, %SettingsIniFilepath%, General, FDRRadioPW, %A_Space% if(Username = "" or Password = ""){ Message = Username and/or Password are blank.`nPlease add Login to Settings.ini file under:`n`n[General]`nFDRRadioUN=`nFDRRadioPW= SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") } if(MP3AudioFilepath = ""){ MsgBox 0x33, Unable to Upload Podcast, No MP3 File Was Found/Selected. `nWould you like to select one now? IfMsgBox Yes, { FileSelectFile, MP3AudioFilepath,, %RootDirToStartIn%, Please Select MP3 File if(ErrorLevel) Return } Else IfMsgBox No, { Return } Else IfMsgBox Cancel, { Return } } /* Sublime Indentation Reset */ if(!InStr(MP3AudioFilepath, ".mp3")){ Message = Unable to upload podcast, no mp3 file was selected. MsgBox 0x40, Error, %Message% Return } ; Message = Grabbing MP3 file data ; SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") ; https://www.autohotkey.com/boards/viewtopic.php?t=59882 Message = Calculating MP3 File Size and Length SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile, DiscordErrorLogging") Obj := Filexpro(MP3AudioFilepath,, , "Length" , "Size" ) MP3AudioFilesize := obj["Size"] MP3AudioLength := obj["Length"] ; MsgBox % obj["Size"] AudioLengthArray := StrSplit(MP3AudioLength,":") Message = MP3 Audio Length: %MP3AudioLength% SaveOrPostProgress(Message:=Message,PostType:="ErrorLoggingTextFile,DiscordErrorLogging") ; AudioLength_Seconds := ((AudioLengthArray[1] * 60 ) * 60) + (AudioLengthArray[2] * 60) + AudioLengthArray[3] ; Message = MP3 Audio Length in Seconds: %AudioLength_Seconds% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") AudioLength_Hours := AudioLengthArray[1] AudioLength_Minutes := AudioLengthArray[2] AudioLength_Seconds := AudioLengthArray[3] Message = AudioLength_Hours: %AudioLength_Hours%`nAudioLength_Minutes: %AudioLength_Minutes%`nAudioLength_Seconds: %AudioLength_Seconds% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") ; AudioLength_SecondsOriginal := AudioLength_Seconds ; AudioLength_Seconds := (AudioLength_Minutes * 60) + ((AudioLength_Hours * 60) * 60) + AudioLength_Seconds ; Msgbox % "AudioLength_Hours: " AudioLength_Hours ; Msgbox % "AudioLength_Minutes: " AudioLength_Minutes ; Msgbox % "AudioLength_Seconds: " AudioLength_Seconds ; Msgbox % "AudioLength_SecondsOriginal: " AudioLength_SecondsOriginal FileGetSize, OutputVar, %MP3AudioFilepath%, K ; Retrieve the size in Kbytes. FIlesizeInBytes := OutputVar * 1024 Message = Inputting Podcast Information SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") Status := NavigateFromBaseURLTo(FDRRadioURL) if(Status) Return Status := CheckForAlerts() if(Status){ } Message = Logging in SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") Xpath = //input[@id='email'] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=Username) if(!Status){ ; if inputting email did NOT fail, then we are on the login page, input the password and then click login. Xpath = //input[@id='password'] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=Password) Xpath = //a[@id='loginButton'] Status := Selenium_LoopToClickXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000) driver.executeScript("return document.readyState").equals("complete") ; wait until page loads completely before proceeding sleep, 2000 try driver.Get(FDRRadioURL) ;Open selected URL catch e { Message = Upload Failed (E#7295)`nUnable to Navigate to Upload Page`nChrome was closed or Internet down possibly? SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") } } Message = Waiting for Page to Load SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") Xpath = //input[@id='num'] Status := Selenium_LoopToClickXpath(Xpath:=Xpath,NumOfLoops:=60,SleepLength:=1000) if(Status){ Message = New Podcast Page did not load after 60 seconds. Check Login Status SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") Return } Message = Inputting Podcast Info SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") ; Click the "Is Active?" Checkbox Xpath = //input[@id='isActive'] Status := Selenium_LoopToClickXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000) ; Input Podcast Number Xpath = //input[@id='num'] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=PodcastNumber) ; Input Podcast Title Xpath = //input[@id='title'] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=VideoTitle) ; INput Audio URL Xpath = //input[@id='url-audio'] SplitPath, MP3AudioFilepath, MP3AudioNameWithExt Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=MP3AudioNameWithExt) ; INput thumbnail URL Xpath = //input[@id='url-thumbnail'] SplitPath, VideoThumbFilepath, VideoThumbnailFilenameWithExt ThumbnailURL = https://cdn.freedomainradio.com/%VideoThumbnailFilenameWithExt% Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=ThumbnailURL) ; Input BitChute URL Xpath = //input[@id='url-bitchute'] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=BitChuteURL) ; Input Brighteon URL Xpath = //input[@id='url-brighteon'] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=BrighteonURL) ; Input DailyMotion URL Xpath = //input[@id='url-dailymotion'] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=DailyMotionURL) ; Input LBRY URL Xpath = //input[@id='url-lbry'] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=OdyseeVideoURL) ; Input LBRY URL Xpath = //input[@id='url-locals'] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=LocalsURL) ; Input Rumble URL Xpath = //input[@id='url-rumble'] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=RumbleURL) ; Soundcloud but actually LBRY Audio URL Xpath = //input[@id='url-lbry-audio'] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=OdyseeAudioURL) ; INput filesize Xpath = //input[@id='fileSize'] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=FIlesizeInBytes) Xpath = //input[@id='lengthHours'] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=AudioLength_Hours) Xpath = //input[@id='lengthMinutes'] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=AudioLength_Minutes) Xpath = //input[@id='lengthSeconds'] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=AudioLength_Seconds) ; Message = Audio Length in Seconds that got input: %AudioLength_Seconds% ; SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") Message = Inputting Description SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") Xpath = //textarea[@id='description'] Status := Selenium_LoopToClickXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000) ; Input Description JSVideoDescription := FormatTextToJSText(VideoDescription) js = document.getElementById('description').value = "%JSVideoDescription%"; try driver.executeScript(js) ;Executes a Javascript on the webpage, mostly used for buttons. Message = Inputting Tags SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") Podcasttags := StrReplace(Podcasttags, " , ", ",") Podcasttags := StrReplace(Podcasttags, " ,", ",") Podcasttags := StrReplace(Podcasttags, ", ", ",") ArrayOfPodcastTags := StrSplit(Podcasttags,",") LengthOfArrayOfPodcastTags := ArrayOfPodcastTags.Length() ; Save total number of items in the array try pagehtml := driver.pagesource ; Msgbox % "pagehtml: " pagehtml Loop, %LengthOfArrayOfPodcastTags% { Tag := ArrayOfPodcastTags[A_Index] ; find value from position in array SpanID = title">%Tag%
  • 2000 AND VideoDescriptionForVideosChannel = ""){ goto, CreateDescriptionForVideosPosting } */ /* if(SocialMediaDescription = ""){ CreateDescriptionForSocialMedia() } if(SocialMediaDescription > 1000){ ; Telegram has a 1024 char media caption capacity SocialMediaDescription := SubStr(SocialMediaDescription, 1, 500) } */ ; @todo: split telegram message into multiple posts SubmitDescriptionForTelegramVideosChannel: TelegramVideoTitle := ASCIISTRReplace(VideoTitle) TelegramVideoTitle := "*" . TelegramVideoTitle . "*" TelegramBodymessage := ASCIISTRReplace(VideoDescription) LineBreakChar = `%0A ; Used for API if(BitChuteURL != "") VideoLinks .= "[BitChute](" . BitChuteURL . ") \| " if(BrighteonURL != "") VideoLinks .= "[Brighteon](" . BrighteonURL . ") \| " if(OdyseeVideoURL != "") VideoLinks .= "[Odysee](" . OdyseeVideoURL . ") \| " if(OdyseeAudioURL != "") VideoLinks .= "[Odysee \(Audio\)](" . OdyseeAudioURL . ") \| " /* if(OdyseeVideoURL != "") VideoLinks .= "[Odysee](" . OdyseeVideoURL . ") \| " if(OdyseeAudioURL != "") VideoLinks .= "[Odysee Audio](" . OdyseeAudioURL . ") \| " */ if(RumbleURL != "") VideoLinks .= "[Rumble](" . RumbleURL . ") \| " /* if(InStr(StreamanityURL, "https://streamanity.com/video/")) VideoLinks .= "[Streamanity](" . StreamanityURL . ") \| " */ if(DailyMotionURL != "") VideoLinks .= "[DailyMotion](" . DailyMotionURL . ") \| " TelegramMessage := TelegramVideoTitle . "`n" . TelegramBodymessage . "`n" . VideoLinks StrLenOfMessageAndVideoLinks := StrLen(TelegramVideoTitle) + StrLen(TelegramBodymessage) + StrLen(VideoLinks) ; DevModeMsgBox(StrLenOfMessageAndVideoLinks) if(StrLenOfMessageAndVideoLinks > 1024){ ; Telegram SendMessage is limited to 4096 characters if(StrLenOfMessageAndVideoLinks < 4096){ ; split into sendphoto and 1 sendmessage ; DevModeMsgBox("Less than 4096 chars") ; Photo and Video Title go into SendPhoto TelegramVideoTitle := TelegramVideoTitle . "`n" . VideoLinks Status := SendTelegramPhoto(TelegramBotToken, TelegramBotChatID, VideoThumbFilepath, caption := TelegramVideoTitle ) ; you could add more options; compare the Telegram API docs ; Video Description goes into TelegramMessage Status2 := SendTelegramMessage(TelegramBotToken, TelegramBotChatID, text := TelegramBodymessage) } ; split into 2 SendMessages else if (StrLenOfMessageAndVideoLinks > 4096 AND StrLenOfMessageAndVideoLinks < 8192){ ; Split into 2 parts TelegramVideoTitle := TelegramVideoTitle . "`n" . VideoLinks Status := SendTelegramPhoto(TelegramBotToken, TelegramBotChatID, VideoThumbFilepath, caption := TelegramVideoTitle ) ; you could add more options; compare the Telegram API docs TelegramBodymessagePiece := SubStr(TelegramBodymessage, 1, 4096) Status2 := SendTelegramMessage(TelegramBotToken, TelegramBotChatID, text := TelegramBodymessagePiece) TelegramBodymessagePiece := SubStr(TelegramBodymessage, 4097, 8192) Status3 := SendTelegramMessage(TelegramBotToken, TelegramBotChatID, text := TelegramBodymessagePiece) } ; split into 3 sendMessages else if (StrLenOfMessageAndVideoLinks > 8192 AND StrLenOfMessageAndVideoLinks < 12288){ ; Split into 3 parts TelegramVideoTitle := TelegramVideoTitle . "`n" . VideoLinks Status := SendTelegramPhoto(TelegramBotToken, TelegramBotChatID, VideoThumbFilepath, caption := TelegramVideoTitle ) ; you could add more options; compare the Telegram API docs TelegramBodymessagePiece := SubStr(TelegramBodymessage, 1, 4096) msgbox % StrLen(TelegramBodymessagePiece) Status2 := SendTelegramMessage(TelegramBotToken, TelegramBotChatID, text := TelegramBodymessagePiece) TelegramBodymessagePiece := SubStr(TelegramBodymessage, 4097, 8192) msgbox % StrLen(TelegramBodymessagePiece) DevModeMsgBox(TelegramBodymessagePiece) Status3 := SendTelegramMessage(TelegramBotToken, TelegramBotChatID, text := TelegramBodymessagePiece) ; TelegramBodymessagePiece := SubStr(TelegramBodymessage, 8193, 12288) ; Status3 := SendTelegramMessage(TelegramBotToken, TelegramBotChatID, text := TelegramBodymessagePiece) } } else, { ; if less than 1024 characters, send normally Status := SendTelegramPhoto(TelegramBotToken, TelegramBotChatID, VideoThumbFilepath, caption := TelegramMessage ) ; you could add more options; compare the Telegram API docs if(InStr(Status, "error_code")){ Message = Telegram Post Failed due to an API Issue. Error was saved to ErrorLogging file. Please send it to Yuriy. SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") ; SaveOrPostProgress(Message:=Status,PostType:=",ErrorLoggingTextFile") Message = Telegram Error: %Status% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") ToolTip Return } } ; Msgbox % "SizeOfCaption: " SizeOfCaption ; SizeOfCaption := SizeOfCaption + ; Message .= VideoLinks ; msgbox % StrLen(VideoLinks) ; Message := StrReplace(Message, "`n", LineBreakChar) ; replace all new line characters with the global charater ; msgbox % StrLen(Message) ; SaveOrPostProgress(Message:=Message,PostType:="ErrorLoggingTextFile,DiscordVideos") ; SaveOrPostProgress(Message:="Video Links posted to #Videos Successfully.",PostType:="Tooltip,ErrorLoggingTextFile") Message = Video Links Posted to Telegram Successfully SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") GuiControl,, PostToTelegramButton, Telegram - Posted Successfully ; sleep, 2000 ToolTip CurrentSite := Return ; -------------------------------/Telegram------------------------------- ; -------------------------------Discord------------------------------- PostToDiscord: CurrentSocialMediaPosting := "Discord" Message = Posting Video Links to Discord SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") IniRead, DiscordVideosWebhookURL, %SettingsIniFilepath%, General, DiscordVideosWebhookURL, %A_Space% if(DiscordVideosWebhookURL = ""){ Message = Unable to Grab DiscordVideosWebhookURL from %SettingsIniFilepath%.`nPlease input the URL and then try again. SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") Msgbox, Unable to Grab DiscordVideosWebhookURL from %SettingsIniFilepath%.`nPlease input the URL and then try again. Return } /* ; If description is longer than 2k chars, then API will error out. goto section that will allow user to edit video description to shorten it for posting if(StrLen(SocialMediaDescription) > 2000 AND VideoDescriptionForVideosChannel = ""){ Goto, CreateDescriptionForVideosPosting } */ if(SocialMediaDescription = ""){ CreateDescriptionForSocialMedia() } ; Msgbox % "SocialMediaDescription: " SocialMediaDescription SubmitDescriptionForDiscordVideosChannel: Message := "**" . VideoTitle . "**" . "`n" . SocialMediaDescription . "`n" ; https://stackoverflow.com/questions/63160401/how-to-create-hyperlink-in-discord-in-an-embed-in-general ; Do this with an array!! ; if(BitChuteURL != "") Message .= "[BitChute](<" . BitChuteURL . ">) \| " if(BrighteonURL != "") Message .= "[Brighteon](<" . BrighteonURL . ">) \| " if(OdyseeVideoURL != "") Message .= "[Odysee](<" . OdyseeVideoURL . ">) \| " if(OdyseeAudioURL != "") Message .= "[Odysee (Audio)](<" . OdyseeAudioURL . ">) \| " /* if(OdyseeVideoURL != "") Message .= "[Odysee](<" . OdyseeVideoURL . ") \| " if(OdyseeAudioURL != "") Message .= "[Odysee Audio](<" . OdyseeAudioURL . ") \| " */ if(RumbleURL != "") Message .= "[Rumble](<" . RumbleURL . ">) \| " /*if(StreamanityURL != "" AND InStr(StreamanityURL, "streamanity.com")) Message .= "[Streamanity](<" . StreamanityURL . ">) \| " */ if(DailyMotionURL != "") Message .= "[DailyMotion](<" . DailyMotionURL . ">)" UploadImageToDiscord(DiscordVideosWebhookURL, Message, VideoThumbFilepath) SaveOrPostProgress(Message:="Video Links posted to #Videos Successfully.",PostType:="Tooltip,ErrorLoggingTextFile") GuiControl,, PostToDiscordButton, Discord - Posted Successfully sleep, 2000 ToolTip ; Msgbox,,Success,Video Links posted to #Videos Successfully. ; ToolTip Return ; -------------------------------/Discord------------------------------- ; -------------------------------CopyThis------------------------------- CopyPodcastNumber: Clipboard := PodcastNumber SaveOrPostProgress(Message:=PodcastNumber "`nCopied to Clipboard",PostType:="Tooltip,ErrorLoggingTextFile") sleep, 1000 ToolTip Return CopyVideoTitle: Clipboard := VideoTitle SaveOrPostProgress(Message:=VideoTitle "`nCopied to Clipboard",PostType:="Tooltip,ErrorLoggingTextFile") sleep, 1000 ToolTip Return CopyBitChuteURL: Clipboard := BitChuteURL SaveOrPostProgress(Message:=BitChuteURL "`nCopied to Clipboard",PostType:="Tooltip,ErrorLoggingTextFile") sleep, 1000 ToolTip Return CopyBrighteonURL: Clipboard := BrighteonURL SaveOrPostProgress(Message:=BrighteonURL "`nCopied to Clipboard",PostType:="Tooltip,ErrorLoggingTextFile") sleep, 1000 ToolTip Return CopyDailyMotionURL: Clipboard := DailyMotionURL SaveOrPostProgress(Message:=DailyMotionURL "`nCopied to Clipboard",PostType:="Tooltip,ErrorLoggingTextFile") sleep, 1000 ToolTip Return CopyOdyseeVideoURL: Clipboard := OdyseeVideoURL SaveOrPostProgress(Message:=OdyseeVideoURL "`nCopied to Clipboard",PostType:="Tooltip,ErrorLoggingTextFile") sleep, 1000 ToolTip Return CopyOdyseeAudioURL: Clipboard := OdyseeAudioURL SaveOrPostProgress(Message:=OdyseeAudioURL "`nCopied to Clipboard",PostType:="Tooltip,ErrorLoggingTextFile") sleep, 1000 ToolTip Return CopyRumbleURL: Clipboard := RumbleURL SaveOrPostProgress(Message:=RumbleURL "`nCopied to Clipboard",PostType:="Tooltip,ErrorLoggingTextFile") sleep, 1000 ToolTip Return /*CopyStreamanityURL: Clipboard := StreamanityURL SaveOrPostProgress(Message:=StreamanityURL "`nCopied to Clipboard",PostType:="Tooltip,ErrorLoggingTextFile") sleep, 1000 ToolTip Return */ CopyVideoTags: Clipboard := VideoTags SaveOrPostProgress(Message:=VideoTags "`nCopied to Clipboard",PostType:="Tooltip,ErrorLoggingTextFile") sleep, 1000 ToolTip Return CopyPodcastTags: Clipboard := PodcastTags SaveOrPostProgress(Message:=PodcastTags "`nCopied to Clipboard",PostType:="Tooltip,ErrorLoggingTextFile") sleep, 1000 ToolTip Return CopyVideoDescription: Clipboard := VideoDescription SaveOrPostProgress(Message:="Video Description`nCopied to Clipboard",PostType:="Tooltip,ErrorLoggingTextFile") sleep, 1000 ToolTip Return ; @todo: Add thumbnail status to this ; @todo: add podcast tags to this UpdateINI: IniWrite, %PodcastNumber%, %VideoLinksIniFile%, URLs, PodcastNumber IniWrite, %VideoTitle%, %VideoLinksIniFile%, Misc, VideoTitle IniWrite, %LBRYVideoURL%, %VideoLinksIniFile%, URLs, LBRYVideoURL IniWrite, %LBRYAudioURL%, %VideoLinksIniFile%, URLs, LBRYAudioURL IniWrite, %OdyseeVideoURL%, %VideoLinksIniFile%, URLs, OdyseeVideoURL OdyseeVideoThumb := StrReplace(OdyseeVideoThumb, "Thumb:", "") IniWrite, %OdyseeVideoThumb%, %VideoLinksIniFile%, Misc, OdyseeVideoThumb IniWrite, %OdyseeAudioURL%, %VideoLinksIniFile%, URLs, OdyseeAudioURL OdyseeAudioThumb := StrReplace(OdyseeAudioThumb, "Thumb:", "") IniWrite, %OdyseeAudioThumb%, %VideoLinksIniFile%, Misc, OdyseeAudioThumb IniWrite, %LocalsURL%, %VideoLinksIniFile%, URLs, LocalsURL IniWrite, %RumbleURL%, %VideoLinksIniFile%, URLs, RumbleURL ; IniWrite, %StreamanityURL%, %VideoLinksIniFile%, URLs, StreamanityURL IniWrite, %DailyMotionURL%, %VideoLinksIniFile%, URLs, DailyMotionURL IniWrite, %BrighteonURL%, %VideoLinksIniFile%, URLs, BrighteonURL IniWrite, %BitChuteURL%, %VideoLinksIniFile%, URLs, BitChuteURL if(VideoDescription != OriginalVideoDescription){ VideoBodyFilepath = %VideoFolderDir%\body.txt FileDelete, %VideoBodyFilepath% FileAppend, %VideoDescription%, %VideoBodyFilepath% } if(PodcastTags != OriginalPodcastTags){ PodcastTagsFilepath = %VideoFolderDir%\keywords_podcast.txt FileDelete, %PodcastTagsFilepath% FileAppend, %PodcastTags%, %PodcastTagsFilepath% } msgbox,4096, Updated!, VideoLinks.ini file updated with any edits that you've made.`n`n%VideoLinksIniFile% Return RetryUpload: run, "%A_ScriptFullPath%" "LastPost" ExitApp ReloadToResults: run, "%A_ScriptFullPath%" "ShowResults" ExitApp SendErrorLoggingThroughTelegram: Message = Uploading Errorlog to FDRBotTesting Telegram Server. SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") ; Credentials to FDRBotTesting Channel IniRead, TelegramErrorLogBotToken, %SettingsIniFilepath%, General, TelegramErrorLogBotToken, %A_Space% IniRead, TelegramErrorLogBotChatID, %SettingsIniFilepath%, General, TelegramErrorLogBotChatID, %A_Space% if(TelegramErrorLogBotToken = "" or TelegramErrorLogBotChatID = ""){ Message = TelegramErrorLogBotToken and/or TelegramErrorLogBotChatID are blank. Please add them to Settings.ini under: `n`n[General]`nTelegramErrorLogBotToken=`nTelegramErrorLogBotChatID= } Status := SendTelegramFile(TelegramErrorLogBotToken, TelegramErrorLogBotChatID, ErrorLoggingFilePath, caption := "" ) if(InStr(Status, "error_code")){ Message = Telegram Post Failed due to an API Issue. Error was saved to ErrorLogging file. Please send it manually. SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") ; SaveOrPostProgress(Message:=Status,PostType:=",ErrorLoggingTextFile") Message = Telegram Error: %Status% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") ; msgbox, 4096, Error!, %Message% ToolTip Return } ToolTip Message = ErrorLog was successfully uploaded to the FDRBotTesting Telegram Server.`nThank You! SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") sleep, 5000 ToolTip ; msgbox, 4096, Success!, %Message% ; Clipboard := ErrorLoggingFilePath ; Message = %ErrorLoggingFilePath% `n`nwas copied to the clipboard for easy attachment ; SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") ; msgbox, 4096, Filepath Copied to Clipboard, %ErrorLoggingFilePath%`n`nwas copied to the clipboard for easy attachment. Return ;--------------Locals---------------------------------- LocalsUpload: CurrentSite := "Locals" SaveOrPostProgress(Message:="Navigating to Post Creation Page",PostType:="Tooltip,ErrorLoggingTextFile") ; SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") IniRead, LocalsPostPageURL, %SettingsIniFilepath%, General, LocalsPostPageURL, %A_Space% if(LocalsPostPageURL = ""){ Message = LocalsURL is blank.`nPlease add Locals URL to Settings.ini file under:`n`n[General]`nLocalsPostPageURL= SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") Return } if(!InStr(LocalsPostPageURL, "/share/post")){ LocalsPostPageURL .= "/share/post" } ; replace any double slashes that migth have come from the combining ; LocalsPostPageURL := StrReplace(LocalsPostPageURL, "//", "/") Status := NavigateFromBaseURLTo(LocalsPostPageURL) if(Status) Return /* if(DevMode){ MsgBox 0x4, DevMode Skip, Skip uploading section and skip straight to grab URL? IfMsgBox Yes, { goto, Devmodeskip } Else IfMsgBox No, { } } */ Message = Waiting for Page to fully load SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") Xpath = //textarea[@id='body'] Status := Selenium_LoopToClickXpath(Xpath:=Xpath,NumOfLoops:=10,SleepLength:=1000) if(Status){ Message = Page did not load after 10 seconds. Force stopping refresh and trying to continue SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") send, {Escape} ; Temporary workaround, as Page seems to endlessly load for Stef Xpath = //textarea[@id='body'] Status := Selenium_LoopToClickXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000) if(Status){ SaveOrPostProgress(Message:="Post Failed: Check Login Status, or Website is Down",PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") ; TakeScreenshotOfPage(ScreenShotSavePath) Return } } Message = Inputting Title SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") Xpath = //input[@id='title'] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=5,SleepLength:=1000,StringTextContent:=VideoTitle) if(Status){ Message = Failed to input Title SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") } sleep, 1000 /*Xpath = //textarea[@id='body'] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=5,SleepLength:=1000,StringTextContent:=VideoDescription) if(Status){ Message = Failed to input Body SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") } */ ; Input Description TooltipThis("Inputting Description") Loop, 5 { ; Attempt to input video description a couple of times if(A_index = 5){ Clipboard := VideoDescription Message = Unable to Input Video Description`nDescription copied to clipboard, please paste it in at your earliest convenience. SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") Return } js = document.getElementsByName('body')[0].value = "%JSVideoDescription%"; ; Send content through javascript (Great for getting around emoji chrome limitaitons) try driver.executeScript(js) ;Executes a Javascript on the webpage, mostly used for buttons. ; msgbox try driver.findElementsByName("body").item[1].SendKeys(driver.Keys.SPACE) ; driver.findElementsByID("ELEMENTID").item[1].SendKeys(driver.Keys.ENTER) ; msgbox jsCheck = return document.getElementsByName('body')[0].value; ; Send content through javascript (Great for getting around emoji chrome limitaitons) try Description := driver.executeScript(jsCheck) ;Executes a Javascript on the webpage, mostly used for buttons. ; try Description := driver.findElementsByName("body").item[1].Attribute("value") ;XPath: ID=site-title & span tag if(Description != "") Break sleep, 2000 } SaveOrPostProgress(Message:="Waiting Video to finish uploading",PostType:="Tooltip,ErrorLoggingTextFile") Message = Uploading Video File SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") Xpath = //div[@class='uploadvideo-wrapper']//input[@name='Filedata'] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=VideoFilepath) if(Status){ Message = Failed to Upload Video SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") Return } ; check if the "Auto Submit Post" checkbox is checked, and if not check it js = return document.querySelector("#autosubmit_enabled").checked; try AutoSubmitstatus := driver.executeScript(js) ; DevModeMsgBox(status) ; message = AutoSubmitstatus: %AutoSubmitstatus% ; DevModeMsgBox(message) if(AutoSubmitstatus = "0"){ js = document.querySelector("li[id='autosubmit_container'] small").click() ; ; CHECK YES try driver.executeScript(js) ; DevModeMsgBox(status) ; double check that it got selected js = return document.querySelector("#autosubmit_enabled").checked; try AutoSubmitstatus := driver.executeScript(js) Message = AutoSubmitstatus after clicking checkbox: %AutoSubmitstatus% DevModeMsgBox(message) if(AutoSubmitstatus != "-1"){ Message = Failed to check Auto-Submit Post checkbox SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return ; SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") } } DevModeMsgBox("autosubmit status -1 string here") ; msgbox % AutoSubmitstatus = "-1" if(AutoSubmitstatus = "-1"){ ; if checked YES ; check that there are no error messages js = return document.querySelector("div[class='form-error']").textContent; try status := driver.executeScript(js) ; DevModeMsgBox(status) if(status){ ;if element contains error text Message = Auto Publish failed: %status% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } if(VideoThumbFilepath){ Message = Uploading Thumbnail SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") Xpath = //div[contains(@class,'post-video-attachments post-video-attachments_upd')]//div[contains(@class,'uploadfile-wrapper')]//input[contains(@name,'Filedata')] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=VideoThumbFilepath) if(Status){ Message = Failed to Attach Thumbnail SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") Return } } ; otherwise everything is good and we can move on to the next site and come back to grab the URL later ; LocalsURL := "UploadedButNeedToGrabLink" ; Return Message = Upload Started Successfully SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") LocalsURL := "LocalsUploadStartedNeedToGrabURL" ; Msgbox % "LocalsURL: " LocalsURL IniWrite, %LocalsURL%, %VideoLinksIniFile%, URLs, LocalsURL AddToTotalVideosUploadedCount() ; Msgbox % "LocalsURL: " LocalsURL ; Msgbox % "VideoLinksIniFile: " VideoLinksIniFile ; ; FileRead, inicontents, %VideoLinksIniFile% ; , Filename ; Msgbox % "inicontents: " inicontents ; IniWrite, Value, Filename, Section, Key ; LocalsTabURL := SaveDriverURL() Return } Return ;--------------\Locals---------------------------------- ;--------------LocalsGrabURL---------------------------------- LocalsGrabURL: CurrentSite := Locals SaveOrPostProgress(Message:="Navigating to Locals Feed to grab URL",PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") ; SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") IniRead, LocalsPostPageURL, %SettingsIniFilepath%, General, LocalsPostPageURL, %A_Space% if(LocalsPostPageURL = ""){ Message = LocalsURL is blank.`nPlease add Locals URL to Settings.ini file under:`n`n[General]`nLocalsPostPageURL= SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") Return } if(InStr(LocalsPostPageURL, "/share/post")){ LocalsFeedPageURL := StrReplace(LocalsPostPageURL, "/share/post", "") } Status := ActivateChromeTab(LocalsPostPageURL) if(Status = "Failed"){ Message = Failed to Activate Locals Tab. Please grab URL manually SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") Return } ; Msgbox % "Status: " Status try currentpageURL := driver.url if(InStr(currentpageURL,"share/post")){ ; we're still on create new post page Message = Locals is still on the Create New Post page. Please double check if post was published successfully. SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } ; otherwise we should be on locals.com home feed page ; check for "Retrieve Draft button" js = return document.querySelector("a[class='btn']").innerText; try, status := driver.executeScript(js) if(status){ Message = Video was uploaded but Locals saved it as a draft instead of instantly publishing it. Please go to the Locals Page and Retrieve Draft and manually Publish it. SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } ; Get word that's longer than 4 characters in video title VideoTitleArray := StrSplit(VideoTitle, " ") ; Iterate from 1 to the end of the array: Loop % VideoTitleArray.Length(){ VideoTitleFirstWord := VideoTitleArray[A_Index] VideoTitleFirstWord := StrReplace(VideoTitleFirstWord, "_","-") if(StrLen(VideoTitleFirstWord) > 4) Break ; MsgBox % VideoTitleArray[A_Index] } loop, 7 { ElementIndexNum := A_index - 1 Message = ElementIndexNum: %ElementIndexNum% DevModeMsgBox(Message) ; Msgbox % "ElementIndexNum: " ElementIndexNum jscheck = return document.getElementsByClassName('post-bottom')[%ElementIndexNum%].outerHTML; try outerHTML := driver.executeScript(jsCheck) if(DevMode){ Message = Looking for VideoTitleFirstWord: %VideoTitleFirstWord% `nwithin outerHTML DevModeMsgBox(message) Clipboard := outerHTML DevModeMsgBox(outerHTML) } ; msgbox % "outerHTML: " . outerHTML if(InStr(OuterHTML,VideoTitleFirstWord)){ ; @todo replace with regex Message = %VideoTitleFirstWord% is in`n`n %OuterHTML% DevModeMsgBox(Message) Message = Found at at index: %A_index% DevModeMsgBox(message) ; MsgBox, found match at %A_index% DevModeMsgBox("Pulling out url from outerhtml") ShareLink := StrSplit(OuterHTML, "data-url=") ShareLink := ShareLink[2] DevModeMsgBox(ShareLink) ; Msgbox % "ShareLink: " ShareLink URLEndString = "> ShareLink := StrSplit(ShareLink, URLEndString) ShareLink := ShareLink[1] DevModeMsgBox(ShareLink) QuotationMark = " ShareLink := StrReplace(ShareLink,QuotationMark, "") DevModeMsgBox(ShareLink) Break } ShareLink := } DevModeMsgBox(ShareLink) ; ShareLink := "Successful" Message = Upload Complete: %ShareLink% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") IniWrite, %ShareLink%, %VideoLinksIniFile%, URLs, LocalsURL AddToTotalVideosUploadedCount() SaveDriverURL() ; TakeScreenshotOfPage(ScreenShotSavePath) Return ;--------------/LocalsGrabURL---------------------------------- ; GetLocals ; Xpath = //div[@class='uppy-StatusBar-statusPrimary'] ; sleep, 30000 ; wait 30 seconds ; sleep, 2000 /*; Attach Custom Thumbnail if(VideoThumbFilepath != ""){ Message = Attaching Custom Thumbnail SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") Xpath = //div[@class='custom-thumb-uploader']//input[@name='Filedata'] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=VideoThumbFilepath) if(Status){ Message = Failed to Attach Custom Thumbnail SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") } } */ sleep, 10000 Loop, %Number_of_loops_to_Check_Upload_status% { sleep, %Time_Between_Loops_Upload_Status% jscheck = return document.getElementsByClassName('uppy-StatusBar-statusPrimary')[0].textContent; try UploadStatus := driver.executeScript(jsCheck) ; UploadStatus := StrSplit(UploadStatus, ": ") ; UploadStatus := UploadStatus[2] ; message = Waiting for Video To Finish Uploading. `nCurrent Status: %UploadStatus% ; SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") ; Clipboard := jsCheck ; msgbox % "textContent: " . textContent /* try UploadStatus := driver.findelementbyxpath(Xpath).Attribute("innerText") ; Grabb innertext catch e { if(A_index = 1){ Message = Unable to find Progress Upload Percentage. Upload Most Likely Failed. SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") } else, Break } */ if(InStr(UploadStatus, "100%")){ Message = Video Upload Complete. Waiting 20 seconds for Video to finalize before submitting. sleep, 20000 break } ; if(UploadStatus != ""){ ; Message = ; sleep, 30000 ; 30 seconds ; Continue ; } if(UploadStatus = "" and A_index = 1){ Message = Upload Failed. Unable to Grab Upload Status SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } ; if(UploadStatus = ""){ ; Break ; } Status := Check_For_Stuck_Video_Upload(A_index, UploadStatus) if(Status = "Failed") Return } /*; attach custom thumbnail xpath = //label[normalize-space()='Upload Custom Video Thumbnail'] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=VideoThumbFilepath) if(Status){ Message = Failed to Attach Thumbnail SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") ; SaveDriverURLOFErrorPage() ; Return } Status := InputFilePathIntoOpenWindow(VideoThumbFilepath) */ ; DevModeMsgBox("pause") ; Click the publish button js = document.getElementsByName('submitPost')[0].click(); try driver.executeScript(js) Message = Waiting 5 seconds for Video to Get Processed SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") sleep, 5000 try currentpage := driver.url if(CUrrentpage = LocalsPostPageURL){ Message = Final page is same as post page. Please double check if post was published successfully. SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") Return } ; sleep, 500 ; ToolTip ; AddToTotalPostsPostedCount() Devmodeskip: Message = Trying to Grab Share Link SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") ; refresh page try driver.executeScript("history.go(0)") try driver.executeScript("return document.readyState").equals("complete") ; wait until page loads completely before proceeding ; check for "Retrieve Draft button" js = return document.querySelector("a[class='btn']").innerText; try, status := driver.executeScript(js) if(status = "Retrieve Draft"){ Message = Video was uploaded but Locals saved it as a draft instead of instantly publishing it. Please go to the Locals Page and Retrieve Draft and manually Publish it. SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } ; Get word that's longer than 4 characters in video title VideoTitleArray := StrSplit(VideoTitle, " ") ; Iterate from 1 to the end of the array: Loop % VideoTitleArray.Length(){ VideoTitleFirstWord := VideoTitleArray[A_Index] VideoTitleFirstWord := StrReplace(VideoTitleFirstWord, "_","-") if(StrLen(VideoTitleFirstWord) > 4) Break ; MsgBox % VideoTitleArray[A_Index] } ; DevModeMsgBox(VideoTitleFirstWord) ; Message = VideoTitleFirstWord: %VideoTitleFirstWord% ; SaveOrPostProgress(Message:=Message,PostType:=",ErrorLoggingTextFile") ; VideoTitleFirstWord := VideoTitleFirstWord[1] ; Msgbox % "VideoTitleFirstWord: " VideoTitleFirstWord /* ; Format the post title to remove all spaces and special characters to match with Locals Post ShareLinkFormatted := StrReplace(VideoTitle, " ", "-") ShareLinkFormatted := StrReplace(ShareLinkFormatted, "?", "") ShareLinkFormatted := StrReplace(ShareLinkFormatted, "!", "") ShareLinkFormatted := StrReplace(ShareLinkFormatted, ".", "") ShareLinkFormatted := StrReplace(ShareLinkFormatted, "", "") ShareLinkFormattedFirst5Chars := SubStr(ShareLinkFormatted, 1, 5) */ LocalsBaseURL := StrReplace(LocalsURL, "/share/post", "") ; Msgbox % "LocalsPostPageURL: " LocalsPostPageURL ; Msgbox % "LocalsURL: " LocalsURL ; Msgbox % "LocalsBaseURL: " LocalsBaseURL loop, 5 { ElementIndexNum := A_index - 1 DevModeMsgBox(ElementIndexNum) ; Msgbox % "ElementIndexNum: " ElementIndexNum jscheck = return document.getElementsByClassName('post-bottom')[%ElementIndexNum%].outerHTML; try outerHTML := driver.executeScript(jsCheck) ; Clipboard := outerHTML ; DevModeMsgBox(outerHTML) ; msgbox % "outerHTML: " . outerHTML if(InStr(OuterHTML,VideoTitleFirstWord)){ Message = %VideoTitleFirstWord% is in %OuterHTML% ; DevModeMsgBox(Message) ; MsgBox, found match at %A_index% ShareLink := StrSplit(OuterHTML, "data-url=") ShareLink := ShareLink[2] ; DevModeMsgBox(ShareLink) ; Msgbox % "ShareLink: " ShareLink URLEndString = "> ShareLink := StrSplit(ShareLink, URLEndString) ; ShareLink := ShareLink[1] QuotationMark = " ShareLink := StrReplace(ShareLink,QuotationMark, "") Break } ShareLink := } DevModeMsgBox(ShareLink) ; ShareLink := "Successful" Message = Upload Complete: %ShareLink% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") IniWrite, %ShareLink%, %VideoLinksIniFile%, URLs, LocalsURL AddToTotalVideosUploadedCount() SaveDriverURL() ; TakeScreenshotOfPage(ScreenShotSavePath) Return ; ;------------------/Locals------------------------------ /* */ ; ;--------------------Telegram---------------------------- TelegramVideoUpload: if(VideoFileSizeInMB > 50){ Message = Telegram Upload Skipped. Video is larger than 50MB SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") Return } CurrentSocialMediaPosting := "Telegram Video" Message = Uploading Video to Telegram SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") IniRead, TelegramBotToken, %SettingsIniFilepath%, SocialMediaPoster, TelegramBotToken, %A_Space% IniRead, TelegramBotChatID, %SettingsIniFilepath%, SocialMediaPoster, TelegramBotChatID, %A_Space% LineBreakChar = `%0A ; Used for Telegram API SaveOrPostProgress(Message:="Posting to Telegram",PostType:="Tooltip,ErrorLoggingTextFile") if(TelegramBotToken = "" Or TelegramBotChatID =""){ Message = TelegramBotToken or TelegramBotChatID is missing from %SettingsIniFilepath%. `nPlease input them and click the button again. msgbox, 4096, Error!, %Message% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") ; Msgbox, 4096, Error!, TelegramBotToken or TelegramBotChatID is missing from %SettingsIniFilepath%. `nPlease input them and rerun the script. Return } ; If description is longer than 2k chars, then API will error out. goto section that will allow user to edit video description to shorten it for posting if(StrLen(SocialMediaDescription) > 2000){ TelegramVideoUploadDescription := SubStr(SocialMediaDescription, 1, 990) TelegramVideoUploadDescription .= "...." ; msgbox, here goes ; Goto, CreateDescriptionForVideosPosting } SubmitDescriptionForTelegramVideoUpload: TelegramVideoTitle := ASCIISTRReplace(VideoTitle) TelegramBodymessage := ASCIISTRReplace(TelegramVideoUploadDescription) LineBreakChar = `%0A ; Used for API Message := "*" . TelegramVideoTitle . "*" . LineBreakChar . TelegramBodymessage . LineBreakChar Message := StrReplace(Message, "`n", LineBreakChar) ; replace all new line characters with the global charater ; Msgbox % "Message: " Message Status := SendTelegramVideo(TelegramBotToken, TelegramBotChatID, VideoFilepath, caption := Message ) ; you could add more options; compare the Telegram API docs if(InStr(Status, "error_code")){ Message = Telegram Post Failed due to an API Issue. Error was saved to ErrorLogging file. Please send it to Yuriy. SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") ; SaveOrPostProgress(Message:=Status,PostType:=",ErrorLoggingTextFile") Message = Telegram Error: %Status% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") ToolTip Return } ; msgbox Message = Upload Complete to Telegram SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") IniWrite, Successful, %VideoLinksIniFile%, Misc, Telegram ; SaveDriverURL() AddToTotalVideosUploadedCount() Return ; -------------------------------BitChute------------------------------- BitChuteUpload: CurrentSite := "Bitchute" Message = Starting Upload SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") Status := NavigateFromBaseURLTo("https://www.bitchute.com/myupload", "BitChute Video Uploader") if(Status) Return Message = Checking Login Status SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") try TabUrl := driver.url if(InStr(TabUrl, "/accounts/login/")){ if(AutoLogin){ Xpath = (//button[normalize-space()='Submit'])[1] Status := Selenium_LoopToClickXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000) if(Status){ Message = Failed to click Login Button. Please Log Back In SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } } else, { Message = Login Expired. Please Log Back In SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } } CheckForAlerts() Message = Inputting Title SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") ; Try to input video title and if fail try to login again loop, 5 { if(A_index = 5){ try CurrentURL := driver.url ; CurrentURL := ExtractBaseURL(URL) ; currentTabURL := SubStr(currentTabURL, 1, 40) Message = Failed to input Video Title after %A_index% attempts.`nCurrent Tab URL: %currentTabURL% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } status := js_SendAndCheckWithQuerySelector(Selector:="#title",ValueToCheck:="value",SleepLength:=1000,JSStringText:=VideoTitle) ; Msgbox % "status: " status if(!Status) break } Message = Inputting Description SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") ; trim description if it's too long BitchuteDescription := VideoDescription if(StrLen(BitchuteDescription) > 2995){ BitchuteDescription := SubStr(BitchuteDescription, 1, 2995) JSBitchuteDescription := FormatTextToJSText(BitchuteDescription) } else, JSBitchuteDescription := FormatTextToJSText(BitchuteDescription) Loop, 10 { ; Attempt to input video description a couple of times Message = Inputting Description. Attempt #%A_index% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") if(A_index = 10){ try currentTabURL := GetCurrentTabURlBase() ; currentTabURL := SubStr(currentTabURL, 1, 40) Message = Failed to input Video Description after %A_index% attempts`nCurrent Tab URL: %currentTabURL% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } status := js_SendAndCheckWithQuerySelector("#description",ValueToCheck:="value",SleepLength:=1000,JSStringText:=JSBitchuteDescription) if(status){ Message = %status% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") } else, Break sleep, 1000 } Message = Inputting Tags SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") ; Convert tags into #hasthtags Loop, 3 { Value := KeywordsArray[A_Index] Value := StrReplace(Value, " ", "") ; Remove spaces if hashtag has two words ; HashTag := "#" . Value BitchuteHashtags .= Value . " " } ; input hashtags Xpath = //input[@placeholder='Search Terms'] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=BitchuteHashtags) ; Upload Thumbnail Message = Attaching Thumbnail SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") if(VideoThumbFilepath != ""){ ; Upload Cover Image Button Message = Uploading Thumbnail SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") Xpath = //input[@name='thumbnailInput'] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=VideoThumbFilepath) if(Status){ Message = Failed to Attach Thumbnail SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } ; sleep, 5000 } ; Upload Video button Message = Uploading Video File SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") Xpath = //input[@name='videoInput'] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=VideoFilepath) if(Status){ Message = Failed to Upload Video SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } Message = Waiting for Video to Finish Uploading`nChecking Progress Every 5 seconds SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") Xpath = //div[@role='progressbar'] ; Xpath to progress % Loop, %Number_of_loops_to_Check_Upload_status% { sleep, %Time_Between_Loops_Upload_Status% if(A_index = 5){ ; while waiting for bitchute video to finish uploading, start up lbry if(OdyseeVideo OR OdyseeAudio){ SaveOrPostProgress(Message:="Starting up LBRY while waiting for Bitchute Video to finish uploading",PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") CheckLBRYProcess() } } ; Selenium ; try BitChuteUploadProgress := driver.findelementbyxpath(Xpath).Attribute("innerText") ;GREAT FOR GRABBING INNER CONTENTS/Values try BitChuteUploadProgress := driver.executeScript("return document.querySelector('.filepond--file-status').innerHTML;") ;navigate using javascript ; Msgbox % "BitChuteUploadProgress: " BitChuteUploadProgress if(BitChuteUploadProgress = ""){ Message = Unable to Grab Upload Progress, Upload Possibly Failed SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } if(InStr(BitChuteUploadProgress, "Upload complete")){ Message = Waiting 10 Seconds before clicking "Proceed" button SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") sleep, 10000 Break ; Break out of the loop when 100% upload status } ; split_text = "> ; Pull out upload percentage BitChuteUploadProgress := StrSplit(BitChuteUploadProgress, ">") BitChuteUploadProgress := BitChuteUploadProgress[2] BitChuteUploadProgress := StrSplit(BitChuteUploadProgress, "= 5000){ BrighteonVideoDescription := SubStr(VideoDescription, 1, 4800) BrighteonVideoDescription .= "...." JSBrighteonVideoDescription := FormatTextToJSText(BrighteonVideoDescription) if(StrLen(JSBrighteonVideoDescription) > 5000){ BrighteonVideoDescription := SubStr(VideoDescription, 1, 4500) BrighteonVideoDescription .= "...." JSBrighteonVideoDescription := FormatTextToJSText(BrighteonVideoDescription) } } Message = Checking Login Status SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") try CurrentTab := driver.url if(InStr(CurrentTab, "login")) ; we're logged out { Message = Currently Logged Out`nClosing out of any popups that might appear before clicking Login button SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") Xpath = //body/div[@id='__next']/div[@id='modal-root']/div[2]/div[1]/div[1]//*[local-name()='svg'] Status := Selenium_LoopToClickXpath(Xpath:=Xpath,NumOfLoops:=1,SleepLength:=100) Xpath = //body/div[@id='__next']/div[@id='modal-root']/div/div/div[1] ; get our free newsletter Status := Selenium_LoopToClickXpath(Xpath:=Xpath,NumOfLoops:=1,SleepLength:=100) ; If newsletter pop up exists then close it. Xpath = //div[@class='overlay__close inside'] Status := Selenium_LoopToClickXpath(Xpath:=Xpath,NumOfLoops:=1,SleepLength:=100) ; Try clicking the login button, sometimes this will auto log you back in without having to input credentials xpath = //a[normalize-space()='Log In'] Status := Selenium_LoopToClickXpath(Xpath:=Xpath,NumOfLoops:=1,SleepLength:=100) ; DevModeMsgBox(Status) Message = Checking Login Status SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") try PageURL := driver.url if(InStr(PageURL, "auth.brighteon.com/login?state")){ ; we're logged out and need to manually log back in if(AutoLogin){ Message = Trying to Log Back In SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile, DiscordErrorLogging") ; js = return document.querySelector("input[placeholder='username/email']").value; ; status := try driver.executeScript(JS) ;Execute Javascript ; sleep, 5000 ; Msgbox % "status: " status ; if(StrLen(Status) > 0){ ; msgbox, clicking login button Xpath = //a[normalize-space()='Log In'] ; click login button at top right of page Status := Selenium_LoopToClickXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000) ; sleep, 2000 Xpath = //button[@type='submit'] ; click login button on login page Status := Selenium_LoopToClickXpath(Xpath:=Xpath,NumOfLoops:=6,SleepLength:=1000) try driver.executeScript("return document.readyState").equals("complete") sleep, 2000 ; } } else, { SaveOrPostProgress(Message:="Login Expired. Please log back in",PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } } } Message = Navigating to Upload Page SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") ; Navigate to Upload Page try driver.executeScript("window.location = 'https://www.brighteon.com/dashboard/video-upload'") ;navigate using javascript try driver.executeScript("return document.readyState").equals("complete") TabURl := GetCurrentTabURlBase() Message = Current Tab URL: %TabURL% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") ; Click out of the "Support free speech" pop-up if it pops up Xpath = //body/div[@id='__next']/div[@id='modal-root']/div/div/div[1]//*[local-name()='svg'] try driver.FindElementByXPath(Xpath).click() CheckForAlerts() Message = Uploading Video SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") ; Upload Video Xpath = //input[@type='file'] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=VideoFilepath) if(Status){ Message = Failed to Upload Video, Please check Login Status SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } loop, 3 { if(A_index = 3){ Message = Failed to input Video Title SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") Return } ; Input Title of the Video Xpath = //input[@id='name'] try driver.FindElementByXPath(Xpath).SendKeys(VideoTitle) ;Sends Variable to an Xpath Item ; click into keyword box to get focus away from title element and see if the video title registers with website xpath = //input[@id='keywords'] try driver.FindElementByXPath(Xpath).click() sleep, 500 ; check if title got input js = return document.querySelector("#name").value; try, status := driver.executeScript(js) if(status = "") continue js = return document.querySelector("#name").value; try, status := driver.executeScript(js) Message = Title that got input: %status% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") break } TooltipThis("Inputting Video Description") ; Attempt to input video description a couple of times Loop, 10 { if(A_index = 10){ Message = Failed to input Video Description after 10 attempts. SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } Message = Inputting Description. Attempt Number: %A_index% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") ; SaveOrPostProgress(Message:=Message,PostType:="DiscordErrorLogging") ; SaveOrPostProgress(Message:="Inputting Video Description",PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar") ; TooltipThis("Inputting Description) Xpath = //div[@class='e-content e-lib e-keyboard'] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=VideoDescription) if(Status){ SaveOrPostProgress(Message:="Failed to input Video Description",PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") ; SaveDriverURLOFErrorPage() ; Return } ; DevModeMsgBox("pause") ; driver.FindElementByXPath(Xpath).SendKeys(VideoDescription) ; js = document.getElementById('description').value = "%JSBrighteonVideoDescription%"; ; try driver.executeScript(js) ; sleep, 1000 ; TooltipThis("checking description input") ; try driver.findElementsByID("description").item[1].SendKeys(driver.Keys.ENTER) ; sleep, 1000 sleep, 5000 js = return document.querySelector("div[class='e-content e-lib e-keyboard'] p").innerText; try Input_Description := driver.executeScript(JS) ;Execute Javascript Input_DescriptionStrLen := StrLen(Input_Description) Message = Length of Description that got input: %Input_DescriptionStrLen% SaveOrPostProgress(Message:=Message,PostType:="ErrorLoggingTextFile,DiscordErrorLogging") ; if text in description box is longer than x chars, then description input worked if(StrLen(Input_Description) > 15){ Input_Description := SubStr(Input_Description, 1, 20) Message = Description that got input: %Input_Description% ... SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") Break } } ; Thumbnail if(VideoThumbFilepath != "") { TooltipThis("Uploading Thumbnail") Xpath = //input[@type='file'] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=VideoThumbFilepath) if(Status){ Message = Failed to Upload Thumbnail SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") } } ; DevModeMsgBox(VideoTags) TooltipThis("Inputting Keywords") Loop, 5 { XPath = //input[@id='keywords'] try driver.FindElementByXPath(Xpath).SendKeys(VideoTags) ;Sends Variable to an Xpath Item catch e { Message = Error (E#2312)`nVideo Uploaded but Unable to Input Video Tags SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") } ; click into video title to get focus away from inputbox Xpath = /html/body/div/section[2]/div[2]/div/form/div[1]/div[1]/div[2]/div[1]/div/input try, driver.FindElementByXPath(Xpath).click() ;Sends Variable to an Xpath Item ; check that the tags got input js = return document.querySelector("#keywords").value; try, status := driver.executeScript(js) if(!status){ Message = Failed to input tags. SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") } else, { Message = Tags that got input: %status% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") break } ; Msgbox % "status: " status } ; double check on video description after inputting tags js = return document.querySelector("div[class='e-content e-lib e-keyboard'] p").innerText; try Input_Description := driver.executeScript(JS) ;Execute Javascript ; if text in description box is longer than x chars, then description input worked if(StrLen(Input_Description) > 5){ SaveOrPostProgress(Message:="Video Description second double check was successful",PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") } else, { SaveOrPostProgress(Message:="Secondary video description check failed",PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") Return } TooltipThis("Waiting for Video to Finish Uploading") Loop, %Number_of_loops_to_Check_Upload_status% { sleep, %Time_Between_Loops_Upload_Status% ; Get progress status through javascript jsCheck = return document.getElementsByClassName('video-upload--details')[0].textContent; try ProgressStatus := driver.executeScript(jsCheck) if(ProgressStatus = ""){ Message = Failed to Grab Video Upload Status. Upload Most Likely Failed SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } if(InStr(ProgressStatus, "Upload complete.")){ Break } ; Pull out progress Percentage from full string UploadPercent := StrSplit(ProgressStatus, "(") UploadPercent := UploadPercent[2] UploadPercent := StrSplit(UploadPercent, ")") UploadPercent := UploadPercent[1] ; Message = Waiting for Video to Finish Uploading`nCurrent Upload Status: %UploadPercent% ; SaveOrPostProgress(Message:=Message,PostType:="Tooltip") Status := Check_For_Stuck_Video_Upload(A_index, UploadPercent) if(Status = "Failed") Return } ; "Save Now" button js = return document.querySelector("button[class='mr-2 btn btn-primary btn-sm']").textContent; try, status := driver.executeScript(js) if(!InStr(status, "Save Video")){ Message = Save Video Button is not clickable. Please check page for errors. SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } ; Save Video button TooltipThis("Clicking Save Video Button to finalize Upload") try BrighteonUploadPageURL := driver.url try driver.executeScript("return document.readyState").equals("complete") ; wait until page loads completely before proceeding TooltipThis("Waiting for Result page to finish loading") Loop, 10 { ; 5 loops of 1 minute each if(A_index = 10){ Message = Upload Failed: Clicking "Save Video" did not Finalize the Upload SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return ; Break out of gosub } js = document.getElementsByClassName('mr-2 btn btn-primary btn-sm')[0].click(); ; Save Video Button try driver.executeScript(js) driver.executeScript("return document.readyState").equals("complete") ; wait until page loads completely before proceeding sleep, 5000 ; 30 seconds try CurrentURL := driver.url if(BrighteonUploadPageURL != CurrentURL) Break } Message = Trying to Grab Newest Video's URL SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") sleep, 2000 ; Navigate to Videos page to make sure it's refreshed with latest video try driver.Get("https://www.brighteon.com/dashboard/videos") ;Open selected URL try driver.executeScript("return document.readyState").equals("complete") ; wait until page loads completely before proceeding sleep, 2000 ; Get First word in video title to use in grabbing video URL VideoTitleArray := StrSplit(VideoTitle, " ") ; Iterate from 1 to the end of the array: Loop % VideoTitleArray.Length(){ VideoTitleLongWord := VideoTitleArray[A_Index] ; VideoTitleFirstWord := StrReplace(VideoTitleFirstWord, "_","-") if(StrLen(VideoTitleLongWord) > 4) Break ; MsgBox % VideoTitleArray[A_Index] } Message = VideoTitleLongWord: %VideoTitleLongWord% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") ; SaveOrPostProgress(Message:=Message,PostType:=",ErrorLoggingTextFile") try, CurrentURL := driver.url Message = Trying to Grab URL of latest upload containing keyword: %VideoTitleLongWord%. Tab's current URL: %CurrentURL% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") ; DevModeMsgBox(Message) Loop, 4 { ElementIndexNumber := A_index - 1 jsCheck = return document.getElementsByClassName('col')[%ElementIndexNumber%].outerHTML; try BrighteonURL := driver.executeScript(jsCheck) jsCheck = return document.getElementsByClassName('col')[%ElementIndexNumber%].textContent; try InnerText := driver.executeScript(jsCheck) ; Message = Loop Number: %ElementIndexNumber% element's Text Content: %innerText%`nBrighteonURL: %BrighteonURL% ; SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") ; Message = InnerText: %InnerText% ; SaveOrPostProgress(Message:=Message,PostType:=",ErrorLoggingTextFile") ; DevModeMsgBox(InnerText) ; Message = BrighteonURL: %BrighteonURL% ; SaveOrPostProgress(Message:=Message,PostType:=",ErrorLoggingTextFile") ; Msgbox % "VideoTitleLongWord: " VideoTitleLongWord "`nInnerText: " InnerText ; clipboard := Message ; msgbox % Message ; Msgbox % "InnerText: " InnerText . "`n" . "BrighteonURL: " . BrighteonURL if(InStr(InnerText, VideoTitleLongWord)){ Message = Title Keyword was found on %A_index% loop, within element: %innerText%`nTrying to pull out BrighteonURL from element's outerHTML SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") BrighteonURL := StrSplit(BrighteonURL, "/dashboard/videos/") BrighteonURL := BrighteonURL[2] BrighteonURL := StrSplit(BrighteonURL, "> 2900){ DailyMotionDescription := SubStr(VideoDescription, 1, 2900) . "..." } else, DailyMotionDescription := VideoDescription DailyMotionJSDescription := FormatTextToJSText(DailyMotionDescription) Message := "DailyMotionJSDescription String Length: " . StrLen(DailyMotionJSDescription) SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") Message = Inputting Video Description SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") Loop, 5 { ; make a couple attempts to input description if(A_index = 5){ Message = Failed to input Description after %A_index% attempts. SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } ; click into element Xpath = //textarea[@placeholder='Enter a description'] try driver.FindElementByXPath(Xpath).click() ; send a space and then backspace so element registers the input Xpath = //textarea[@placeholder='Enter a description'] try driver.FindElementByXPath(Xpath).SendKeys(driver.Keys.SPACE) try driver.FindElementByXPath(Xpath).SendKeys(driver.Keys.BackSpace) ; inut description with javascript js = document.querySelector("textarea[placeholder='Enter a description']").value = "%JSVideoDescription%"; try driver.executeScript(js) ; send a space and then backspace so element registers the input Xpath = //textarea[@placeholder='Enter a description'] try driver.FindElementByXPath(Xpath).SendKeys(driver.Keys.SPACE) try driver.FindElementByXPath(Xpath).SendKeys(driver.Keys.BackSpace) sleep, 1000 js = return document.querySelector("textarea[placeholder='Enter a description']").textContent; try, InputDescription := driver.executeScript(js) message = InputDescription: %InputDescription% DevModeMsgBox(InputDescription) ; if input description is less than 15 chars, try again if(StrLen(InputDescription) < 15) Continue else, Break } ; Make a couple attempts to Click on Drop down menu and select the "Education" Category Message = Selecting Education Category SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") Loop, 3 { if(A_index = 3){ Message = Failed to Select Education Category after %A_index% attempts SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } Xpath = //div[@name='channel'] Status := Selenium_LoopToClickXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000) js = document.querySelector("div[title='Education'] div[class='ant-select-item-option-content']").click() try status := driver.executeScript(js) js = return document.querySelector("div[name='channel']").textContent; try, status := driver.executeScript(js) if(instr(status, "Education")) break } Message = Inputting Tags SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") ; Append comma to end of tags ; DailyMotion page automtically splits the tags into their little boxes when they're seperated by commas DailyMotionVideoTags := VideoTags . "," Message = Video Tags: %DailyMotionVideoTags% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") Xpath = //div[@class='ant-select-selection-search']//input[@role='combobox'] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=DailyMotionVideoTags) ; double check the input js = return document.querySelector("div[name='tags']").textContent; try, inputTags := driver.executeScript(js) Message = Tags that got input: %inputTags% (Will be doubled b/c of js) SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") ; msgbox Message = Clicking Next Button to Move on to next input screen SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") Xpath = //button[@type='button']//span[contains(text(),'Next')] Status := Selenium_LoopToClickXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000) ; msgbox, click work? Message = Selecting "Not For Kids" checkbox SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") try driver.findElementsByName("is_created_for_kids").item[2].click() catch e { sleep, 2000 try driver.findElementsByName("is_created_for_kids").item[2].click() catch e { Message = Failed to Click on the "Not Made For Kids" checkbox. Please switch to tab and finalize upload. SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } } /* ; Disable monitization for video SaveOrPostProgress(Message:="Unchecking monetizaton checkbox",PostType:="Tooltip,ErrorLoggingTextFile") Xpath = //button[normalize-space()='Advanced'] ; advanced tab button Status := Selenium_LoopToClickXpath(Xpath:=Xpath,NumOfLoops:=5,SleepLength:=1000) if(Status = "Failed"){ Message = Unable to Navigate to Advanced Settings Page to turn off monetization SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") } */ ; SaveOrPostProgress(Message:="Unchecking monetizaton checkbox",PostType:="Tooltip,ErrorLoggingTextFile") ; switch over to advanced tab ; js = document.getElementsByName('advanced')[0].click(); ; try driver.executeScript(js) /* sleep, 1000 Loop, 5 { ; Loop to uncheck the "monetization button" if(A_index = 5){ Message = Failed to uncheck "monetization enabled" checkbox SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") } Xpath = //input[@name='advertising_instream_blocked'] ; monetization checkbox try Status := driver.FindElementByXPath(Xpath).isSelected() if(Status = 0) ; -1 is checked, 0 is unchecked Break ; Click to uncheck the "allow monetization" checkbox Selenium_LoopToClickXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000) } */ /* ; Switch back to Basic tab js = document.getElementsByName('basic')[0].click(); try driver.executeScript(js) */ Message = Clicking Next Button to Move on to third video settings screen SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") Xpath = //button[@type='button']//span[contains(text(),'Next')] Status := Selenium_LoopToClickXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000) Message = Clicking Save Button to Finalize Upload SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") Xpath = //span[normalize-space()='Save'] Status := Selenium_LoopToClickXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000) if(Status){ Message = Upload was ALMOST successfuly. Failed to Click Final Save button SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") } ; Grab the Share URL and pull out the Video Link from it and save it to the Video links ini file, so double uploads are not tried if fialure occurs Message = Waiting 30 seconds before grabbing Video URL SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") sleep, 30000 Xpath = //ul[@data-test-id='videos-media-list']//li//div//div//div//div//h3//a try, DailyMotionInternalURL := driver.findelementbyxpath(Xpath).Attribute("href") if(DailyMotionInternalURL = ""){ Message = Failed to Grab Video URL. Upload Most likely Failed. SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } ; Pull out URL slug from internal video URL and create dailymotion share URL from it DailyMotionURL := StrSplit(DailyMotionInternalURL, "/video/details/")[2] DailyMotionURL := "https://www.dailymotion.com/video/" . DailyMotionURL Message = Upload Complete: %DailyMotionURL% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") IniWrite, %DailyMotionURL%, %VideoLinksIniFile%, URLs, DailyMotionURL SaveDriverURL() AddToTotalVideosUploadedCount() ; TakeScreenshotOfPage(ScreenShotSavePath) Return ; -------------------------------/DailyMotion------------------------------- ; -------------------------------LBRY------------------------------- LBRYVideoUpload: LBRYAudioUpload: if(LBRYUploadType = "Video"){ CurrentSite := "LBRY Video" IniRead, LBRYPermanentURL, %VideoLinksIniFile%, Misc, LBRYVideoPermanentURL, %A_Space% } if(LBRYUploadType = "Audio"){ CurrentSite := "LBRY Audio" IniRead, LBRYPermanentURL, %VideoLinksIniFile%, Misc, LBRYAudioPermanentURL, %A_Space% } ; if LBRY permanent URL was already grabbed before, exit if(LBRYPermanentURL != "") Return CheckLBRYProcess() ; double check lbry process SaveOrPostProgress(Message:="Starting Upload",PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") ; If LBRY Killer not found, then download it ; @todo: Add LBRY kill download functionality from gitea LBRYKillerPath := LibFolder . "\LBRY Process Killer.exe" if(!FileExist(LBRYKillerPath)){ ; Msgbox % "LBRYKillerPath: " LBRYKillerPath ; Msgbox % "LBRYProcessKillerURL: " LBRYProcessKillerURL LBRYKillerPath = %A_ScriptDir%\Lib\LBRY Process Killer.exe LBRYKillerUpdateURL = https://git.freedomainplaylists.com/attachments/7865dc8d-5aad-4f9f-8a30-94bab0192b1d UrlDownloadToFile, %LBRYKillerUpdateURL%, %LBRYKillerPath% ; msgbox, work? ; UrlDownloadToFile, URL, Filename Message = LBRY Process Killer Not Found. Automatically Downloading. SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") } TooltipThis("Uploading Video through API") ; Variables of items that need to be replaced before argument is passed to API Apostrophe = ' LBRYTags = ; Create empty variable SingleQuotationmark = " EscapedQuotationMark = \" ; Replace all items to make text passable to API LBRYVideoTitle := StrReplace(VideoTitle, SingleQuotationmark, EscapedQuotationMark) ; replace all spaces with dashes LBRYVideoDescription := StrReplace(VideoDescription, SingleQuotationmark, EscapedQuotationMark) if(StrLen(LBRYVideoDescription) >= 5000){ LBRYVideoDescription := SubStr(LBRYVideoDescription, 1, 4990) LBRYVideoDescription .= "...." } if(LBRYUploadType = "Video"){ Message = Uploading through API with URL Slug: %LBRYURLSlug% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") FilePathForLBRYAPI := VideoFilepath } if(LBRYUploadType = "Audio"){ ; Replace all items to make text passable to API LBRYVideoTitle .= " (Audio)" LBRYURLSlug .= "_Audio" Message = Uploading through API with URL Slug: %LBRYURLSlug% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") FilePathForLBRYAPI := WavAudioFilepath } ; if no lbry slug, then error out if(LBRYURLSlug = "" OR LBRYURLSlug = "_Audio"){ Message = Upload Failed because no URL Slug was provided. SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") Return } ; loops through array and creates a string of: --tags="tag1" --tags="tag2" --tags="tag3" so that it can be passed to lbrynet Loop % KeywordsArray.Length(){ LBRYTags .= "--tags=" . SingleQuotationmark KeywordsArray[A_Index] . SingleQuotationmark . " " } ; Msgbox % "FilePathForLBRYAPI: " FilePathForLBRYAPI SplitPath, VideoThumbFilepath, ThumbnailFileNameWExt, OutDir, OutExtension, OutNameNoExt, OutDrive FDRThumbnailURL = https://cdn.freedomainradio.com/%ThumbnailFileNameWExt% message = FDRThumbnailURL: %FDRThumbnailURL% SaveOrPostProgress(Message:=Message,PostType:="ErrorLoggingTextFile,DiscordErrorLogging") ; Msgbox % "FDRThumbnailURL: " FDRThumbnailURL ; Create API Command and save it to variable LBRYAPICommand = "%LBRYNetFilepath%" publish --name="%LBRYURLSlug%" --bid="%LBRYNewVideoStakeAmount%" --file_path="%FilePathForLBRYAPI%" --title="%LBRYVideoTitle%" --description="%LBRYVideoDescription%" %LBRYTags% --thumbnail_url="%FDRThumbnailURL%" --channel_id="%LBRYChannelID%" ; LogErrorToTextFile(LBRYAPICommand) ; Log to file LogErrorToTextFile("LBRYAPICommand: " LBRYAPICommand) ; Parse returned API json for success status UploadResult := StdOutToVar(LBRYAPICommand) if(InStr(UploadResult, "Could not connect")){ Message = Upload Failed. Reason: %UploadResult% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") Return } if(UploadResult = ""){ Message = LBRYNet did not return anything. LBRY not running? SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") Return } ; Msgbox % "UploadResult: " UploadResult try parsed := JSON.Load(UploadResult) try UploadStatus := parsed.height ; Msgbox % "UploadStatus: " UploadStatus ; -2 is returned if upload was successful if(UploadStatus != "-2"){ ; msgbox, error ErrorCode := parsed.message ErrorCode := parsed.message ErrorCode := StrSplit(ErrorCode, "code") ErrorCode := ErrorCode[1] Message = LBRY Upload Failed`nReason: %ErrorCode% ; Msgbox % "Message: " Message SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") Return } ; Clipboard := UploadResult ; Msgbox % "UploadResult: " UploadResult LogErrorToTextFile("UploadResult: " UploadResult) if(InStr(UploadResult, "Could not connect to daemon")){ if(LBRYAttemptNumber = 2){ Message = Upload Error (E#4081)`nVideo Upload Failed due to daemon not running.`nPlease start it manually and re-run the upload. SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") try run, %LBRYKillerPath% "Kill" catch e { ; Message = Unable to Kill LBRYKiller.ahk ; SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") } Return } else, { ; if attempt number 1 Process, Close, LBRY.exe ; terminate LBRY if it's running LBRYAttemptNumber := 2 Message = Upload Failed (E#1980)`nDue to daemon not running.`nTrying to restart LBRY.exe and try the upload again. SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") Goto, LBRYVideoUpload } } ; Clipboard := UploadResult ; Msgbox % "UploadResult: " UploadResult /*if(DevMode){ Clipboard := UploadResult Msgbox % "UploadResult: " UploadResult } */ ; Create an object out of the API Return LBRYJSONResult := JSON.Load(UploadResult) if(!InStr(UploadResult, "permanent_url")){ ; if no permanent_url is generated then API issue LBRYAPIError := LBRYJSONResult.message ; LBRYAPIError := GetLBRYAPIErrorFromString(UploadResult) ; if the returned string does not have "permanent_url" in it, then upload failed Message = Upload Error (E#6930)`nVideo Upload Failed due to API Issue. Please send errorlog to Yuriy. SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") Return } if(KillLBRYAfterUpload){ try run, %LBRYKillerPath% catch e { Message = LBRYKiller not found. Unable to find File. SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") } } ; Transform the Upload Result json into the LBRY.tv link ; PermanentURL := GetPermanentLBRYURL(UploadResult) ; get permanentURL from the upload result json LBRYPermanentURL := LBRYJSONResult.outputs[1].permanent_url if(LBRYPermanentURL = ""){ Message = Failed to grab permanent_url with json.ahk. Please send errorlog to Yuriy. SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") Return } Message = Claim Was Successfully Submitted to lbrynet with: %LBRYPermanentURL% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") ; Message = LBRYPermanentURL: %LBRYPermanentURL% ; SaveOrPostProgress(Message:=Message,PostType:=",ErrorLoggingTextFile") if(CurrentSite = "LBRY Video"){ IniWrite, %LBRYPermanentURL%, %VideoLinksIniFile%, Misc, LBRYVideoPermanentURL } if(CurrentSite = "LBRY Audio"){ IniWrite, %LBRYPermanentURL%, %VideoLinksIniFile%, Misc, LBRYAudioPermanentURL } Return ; -------------------------------LBRY URL------------------------------- LBRYGetURL: if(LBRYUploadType = "Video"){ CurrentSite := "LBRY Video" ; IniWrite, %PermanentURL%, %VideoLinksIniFile%, URLs, LBRYVideoPermanentURL IniRead, LBRYPermanentURL, %VideoLinksIniFile%, Misc, LBRYVideoPermanentURL, %A_Space% } if(LBRYUploadType = "Audio"){ CurrentSite := "LBRY Audio" IniRead, LBRYPermanentURL, %VideoLinksIniFile%, Misc, LBRYAudioPermanentURL, %A_Space% } if(LBRYPermanentURL = ""){ Message = Upload Skipped. LBRYPermanentURL is blank (Upload Failed due to some API issue) SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") Return } ; Message := "Waiting a couple of minutes for lbrynet blockchain to generate blockchain metadata for newest video" Message = Waiting for LBRYNet to Generate LBRY URL SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") ; sleep, 60000 ; 1 minute ; sleep, 300000 ; sleep for 5 minutes so LBRYNet blockchain has a chance to register the new video ; as recomended by LBRY Devs ; sleep, 360000 ; sleep for 6 minutes so LBRYNet blockchain has a chance to register the new video ; LBRY devs recommend 5 mins LBRYResolveAPICommand = "%LBRYNetFilepath%" resolve %LBRYPermanentURL% ; create variable with the text that's needed for the API command Message := "LBRYResolveAPICommand: " . LBRYResolveAPICommand ; Save the result to the errorlogging file SaveOrPostProgress(Message:=Message,PostType:=",ErrorLoggingTextFile") ; msgbox loop, 15 { LBRYResolveResult := StdOutToVar(LBRYResolveAPICommand) ; Save API call to a variable if(A_index = 1 OR a_index = 10){ Message := "LBRYResolveResult: " . LBRYResolveResult ; Save result to the errorlogging file SaveOrPostProgress(Message:=Message,PostType:="ErrorLoggingTextFile") } if(InStr(LBRYResolveResult, "could not find claim") AND A_Index < 10) ; try 4 times to get the resolveURL, sometimes the blockchain is quite slow { ; @todo: Make it check every 2 minutes? ; TooltipThis("Not Able to Grab URL from API. `nWaiting another 5 for blockchain to sync claim before trying again") ; MessageNumber := A_index + 5 if(A_index < 5) Message = Waiting for LBRYNet to Generate LBRY URL`nChecking Every 2 Minutes if(A_index > 5) Message = Still Waiting for LBRYNet to Generate LBRY URL`nLBRY Network is most likely congested.`nChecking Every 2 Minutes SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") ; sleep, 300000 ; 5 minutes sleep, 120000 ; 2 minute Continue } if(InStr(LBRYResolveResult, "could not find claim") AND A_index = 15){ Message = Failed to Grab URL from LBRY after 30 minutes. Either LBRY IS REALLY congested or there is a bug and the API commands were passed incorrectly. SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") Return } if(InStr(LBRYResolveResult, "canonical_url")) Break } if(LBRYUploadType = "Video"){ LBRYVideoURL := GetLBRYCanonicalURL(LBRYResolveResult) ; Transform the API resulting json into the LBRY.tv link if(LBRYVideoURL = ""){ Message = Failed to Grab LBRY URL from LBRYNet SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") Return } ; DevModeMsgBox(LBRYVideoURL) Message = LBRYVideoURL from GetLBRYCanonicalURL: %LBRYVideoURL% SaveOrPostProgress(Message, PostType:=",ErrorLoggingTextFile") OpenLBRYVideoURL := StrReplace(LBRYVideoURL, "https://lbry.tv", "https://open.lbry.com") OpenLBRYVideoURL := StrReplace(OpenLBRYVideoURL, "#", ":") OdyseeVideoURL := StrReplace(LBRYVideoURL, "https://lbry.tv", "https://odysee.com") OdyseeVideoURL := StrReplace(OdyseeVideoURL, "#", ":") Message = Upload Complete: <%OpenLBRYVideoURL%> + <%OdyseeVideoURL%> SaveOrPostProgress(Message:=Message,PostType:="ErrorLoggingTextFile,DiscordErrorLogging") IniWrite, %OpenLBRYVideoURL%, %VideoLinksIniFile%, URLs, LBRYVideoURL IniWrite, %OdyseeVideoURL%, %VideoLinksIniFile%, URLs, OdyseeVideoURL } if(LBRYUploadType = "Audio"){ LBRYAudioURL := GetLBRYCanonicalURL(LBRYResolveResult) ; Transform the API resulting json into the LBRY.tv link if(LBRYAudioURL = ""){ Message = Failed to Grab LBRY URL from LBRYNet SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") Return } Message = LBRYAudioURL from GetLBRYCanonicalURL: %LBRYAudioURL% SaveOrPostProgress(Message, PostType:=",ErrorLoggingTextFile") OpenLBRYAudioURL := StrReplace(LBRYAudioURL, "https://lbry.tv", "https://open.lbry.com") OpenLBRYAudioURL := StrReplace(OpenLBRYAudioURL, "#", ":") OdyseeAudioURL := StrReplace(LBRYAudioURL, "https://lbry.tv", "https://odysee.com") OdyseeAudioURL := StrReplace(OdyseeAudioURL, "#", ":") Message = Upload Complete: <%OpenLBRYAudioURL%> + <%OdyseeAudioURL%> SaveOrPostProgress(Message:=Message,PostType:="ErrorLoggingTextFile,DiscordErrorLogging") IniWrite, %OpenLBRYAudioURL%, %VideoLinksIniFile%, URLs, LBRYAudioURL IniWrite, %OdyseeAudioURL%, %VideoLinksIniFile%, URLs, OdyseeAudioURL } ; SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") ; SaveDriverURL() AddToTotalVideosUploadedCount() Return ; -------------------------------/LBRY Video------------------------------- ; -------------------------------Rumble------------------------------- RumbleUpload: CurrentSite := "Rumble" SaveOrPostProgress(Message:="Starting Upload",PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") Status := NavigateFromBaseURLTo("https://rumble.com/upload.php") if(Status) Return try driver.executeScript("return document.readyState").equals("complete") ; wait until page loads completely before proceeding CheckForAlerts() Message = Checking Login Status SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") try CurrentURL := driver.URL if(InStr(CurrentURL, "/login.php")){ if(AutoLogin){ Message = Logging in Automatically by clicking into the UN+PW fields for info to register SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") ; have to click into username and password field for page to register that there's input ; clicking with JS doesn't make it register, but with xpath selenium it does Xpath = //input[@id='login-username'] driver.FindElementByXPath(Xpath).click() Xpath = //input[@id='login-password'] driver.FindElementByXPath(Xpath).click() js = document.querySelector("button[type='submit']").click(); driver.executeScript(js) ; Do a double check to make sure that login worked Message = Checking Login Status SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") try CurrentURL := driver.URL if(!InStr(CurrentURL, "/upload")){ Message = Failed to log back in. Please Log Back In Manually SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } } else, { ; notify user and return Message = Login Expired. Please Log Back in SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } Message = Waiting 5 seconds for page to fully load SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") sleep, 5000 } ; CheckForAlerts() Message = Uploading Video File SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") ; SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") Xpath = //input[@id='Filedata'] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=VideoFilepath) if(Status){ try, CurrentURL := GetCurrentTabURlBase() Message = Failed to Upload Video File`nCurrent Tab URL: %CurrentURL% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } ; Input Title try driver.findElementsByName("title").item[1].SendKeys(VideoTitle) ;selects element based on Name and sends variable to it. catch e { Message = Video Upload Failed, Please Check Login Status SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } ; Input Description Loop, 5 { ; Attempt to input video description a couple of times TooltipThis("Inputting Description `nAttempt Number: " A_index) status := js_SendAndCheckWithID(Element:="description",ValueToCheck:="value",SleepLength:=3000,JSStringText:=JSVideoDescription) if(!Status) Break /* if(A_index = 5){ Clipboard := VideoDescription Message = Unable to Input Video Description`nDescription copied to clipboard, please paste it in at your earliest convenience. SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") Return } js = document.getElementsByName('description')[1].value = "%JSVideoDescription%"; ; Send content through javascript (Great for getting around emoji chrome limitaitons) try driver.executeScript(js) ;Executes a Javascript on the webpage, mostly used for buttons. try Description := driver.findElementsByName("description").item[2].Attribute("value") ;XPath: ID=site-title & span tag if(Description != "") Break sleep, 2000 */ } ; sleep, 5000 Message = Selecting Channel SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") ; try driver.findElementsByID("channelId").item[1].click() ; @todo replace with regex js = return document.querySelector("#channelId").innerHTML; try, ChannelIDNumber := driver.executeScript(js) ; Msgbox % "ChannelIDNumber: " ChannelIDNumber ChannelIDNumber := StrSplit(ChannelIDNumber, "option value=") ; Msgbox % "ChannelIDNumber: " ChannelIDNumber ChannelIDNumber := ChannelIDNumber[3] ; Msgbox % "ChannelIDNumber: " ChannelIDNumber SingleQuote = " ChannelIDNumber := StrSplit(ChannelIDNumber, "data-private") ChannelIDNumber := ChannelIDNumber[1] ChannelIDNumber := StrReplace(ChannelIDNumber, SingleQuote, "") ChannelIDNumber := StrReplace(ChannelIDNumber, " ", "") ; Msgbox % "ChannelIDNumber: " ChannelIDNumber ; js = return document.querySelector("#channelId").value; ; try, ChannelIDNumber := driver.executeScript(js) ; Msgbox % "ChannelIDNumber: " ChannelIDNumber if(ChannelIDNumber = ""){ Message = ChannelIDNumber is blank. Unable to select Upload Channel SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } ; //option[@value='762377'] ; freedomain Xpath = //option[@value='%ChannelIDNumber%'] try driver.FindElementByXPath(Xpath).click() catch e { Message = Failed to click on Channel using %ChannelIDNumber%. SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return ; SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") ; SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") } ; Input Tags Message = Inputting Tags SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") try driver.findElementsByName("tags").item[1].SendKeys(VideoTags) ;selects element based on Name and sends variable to it. ; Custom Thumbnail if(VideoThumbFilepath != "") { TooltipThis("Uploading Thumbnail") Xpath = //input[@name='customThumb'] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=VideoThumbFilepath) if(Status){ Message = Failed to Upload Thumbanil SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") } ; @todo: Add a check to see if progress gets stuck ; Check Upload Percentage TooltipThis("Waiting for Video to Finish Uploading") Loop, %Number_of_loops_to_Check_Upload_status% { sleep, %Time_Between_Loops_Upload_Status% jscheck = return document.getElementsByClassName('num_percent')[0].textContent; try RumbleUploadPercent := driver.executeScript(jsCheck) ; try RumbleUploadPercent := driver.findelementbyxpath(Xpath).Attribute("textContent") RumbleUploadPercent := StrSplit(RumbleUploadPercent, " ") RumbleUploadPercent := RumbleUploadPercent[1] if(InStr(RumbleUploadPercent, "100%")) ; once variable contains 100%, then we can break out of loop and continue Break Status := Check_For_Stuck_Video_Upload(A_index, RumbleUploadPercent) if(Status = "Failed") Return ; if(HasVal(Array_Index_Num_of_Upload_StatusChecks, A_index)) { ; 30 minutes and 60 minutes - send a notification message ; Message = Upload Progress: %RumbleUploadPercent% ; SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") ; } } ; Msgbox % "RumbleUploadPercent: " RumbleUploadPercent ; Click on one of the video thumbnail options first ; Seems to be a bug on rumble, in order to be able to select a custom thumb through js, gotta select on of the generated ones first. ; Xpath = /html/body/main/div/div/div/section/form[1]/div/div[2]/div[3]/a[2] ; thumbnail option #3 ; try driver.FindElementByXPath(Xpath).click() ;Clicks on Xpath based on variable. /* js = document.getElementById('customThumb').click(); driver.executeScript(js) ;Executes a Javascript on the webpage, mostly used for buttons. Status := InputFilePathIntoOpenWindow(VideoThumbFilepath) if(Status) { Message = Upload Failed:`nUnable to Find "Open File" window to input filepath into SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") Return } */ } try UploadPageURL := driver.URL ; Submit Button js = document.getElementById('submitForm').click(); try driver.executeScript(js) ; try driver.executeScript("return document.readyState").equals("complete") ; wait until page loads completely before proceeding ; Select Rumble Only Licensing js = document.getElementsByClassName('greenLink mRight last')[0].click(); ; Send content through javascript (Great for getting around emoji chrome limitaitons) try driver.executeScript(js) ;Executes a Javascript on the webpage, mostly used for buttons. ; Check off condition 1 js = document.getElementById("crights").click() try driver.executeScript(js) ; Check off condition 2 js = document.getElementById("cterms").click() try driver.executeScript(js) ; Click the Submit Button js = document.getElementById("submitForm2").click() try driver.executeScript(js) ; Loop until able to grab the direct link from the result page. Loop, 24 { TooltipThis("Waiting for Result Page to load to grab Video URL") Sleep, 5000 js = return document.getElementById("error_files_2").textContent; RumbleError := driver.executeScript(js) ;Executes a Javascript on the webpage, mostly used for buttons. if(RumbleError != "") { Message = Rumble Upload Failed due to:`n%RumbleError% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } js = return document.getElementById('direct').value; try RumbleURL := driver.executeScript(js) ;Executes a Javascript on the webpage, mostly used for buttons. /* try RumbleURL := driver.findElementsByID("direct").item[1].Attribute("value") ;grab Direct Link from the result page catch e { ; if not able to grab it, then sleep for 5 seconds and then loop again Continue } */ if(RumbleURL != ""){ ; If URL is grabbed from result page, then kick out of loop Break } if(A_Index = 10) ; if looped for 5 minutes and still no URL grabbed { ; @todo: add error check if submit button clicked and error appears Xpath = /html/body/main/div/div/div/section/form[2]/div/div[9] ; grab inner content of where error usually appears. try RumbleUploadError := driver.findelementbyxpath(Xpath).Attribute("innerText") ; Grabb innertext ; Msgbox % "UseThumbUploadToolTextExist: " UseThumbUploadToolTextExist Message = Upload Error (E#1341)`nVideo Uploaded but not able to be finalized.`nPlease fix the issue and click the final submit button. `nError: %RumbleUploadError% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } } IniWrite, %RumbleURL%, %VideoLinksIniFile%, URLs, RumbleURL Message = Upload Complete: %RumbleURL% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") SaveDriverURL() AddToTotalVideosUploadedCount() ; TakeScreenshotOfPage(ScreenShotSavePath) Return ; -------------------------------/Rumble------------------------------- ;---Facebook--- ;------------------------------------------------ FacebookUpload: CurrentSite := "Facebook" SaveOrPostProgress(Message:="Starting Upload",PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") Status := NavigateFromBaseURLTo("https://www.facebook.com/") if(Status) Return try driver.executeScript("return document.readyState").equals("complete") ; wait until page loads completely before proceeding ; Create a description for Facebook SplitText = Free Documentaries: FacebookDescription := StrSplit(VideoDescription, SplitText) FacebookDescription := FacebookDescription[1] FacebookTitleAndDescription := VideoTitle . "`n`n" . FacebookDescription JSFacebookTitleAndDescription := FormatTextToJSText(FacebookTitleAndDescription) Message = Calculating Video Length SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") try Obj := Filexpro(VideoFilepath,, , "Length" , "Size" ) VideoFilesize := obj["Size"] VideoLength := obj["Length"] ; Msgbox % "VideoLength: " VideoLength VideoLengthArray := StrSplit(VideoLength, ":") VideoLengthInMinutes := (VideoLengthArray[1] * 60) + VideoLengthArray[2] ; Msgbox % "VideoLengthInMinutes: " VideoLengthInMinutes if(VideoLengthInMinutes >= 240){ Message = Skipped: Longer than 240 Minutes IniWrite, %Message%, %VideoLinksIniFile%, URLs, FacebookURL SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } ; Upload Video Xpath = //div[@aria-label='Create a post']//div//input[@type='file'] Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000,StringTextContent:=VideoFilepath) if(Status){ Message =Post Failed: Check Login Status SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } ; Message = Waiting 15 Seconds for Video Preview to Load SaveOrPostProgress(Message:=Message,PostType:="Tooltip") sleep, 15000 Xpath = //div[@data-block='true']//div Status := Selenium_LoopToSendValueToXpath(Xpath:=Xpath,NumOfLoops:=3,SleepLength:=2000,StringTextContent:=FacebookTitleAndDescription) if(Status){ Message = Failed to Input Video Description SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } ; msgbox ; Click submit button xpath = //div[@aria-label='Post']//div//div//div//span[contains(text(),'Post')] Status := Selenium_LoopToClickXpath(Xpath:=Xpath,NumOfLoops:=2,SleepLength:=1000) if(Status){ Message = Failed to click "Post" button SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return } IniWrite, Submitted, %VideoLinksIniFile%, URLs, FacebookURL Message = Upload Started Successfully SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") SaveDriverURL() AddToTotalVideosUploadedCount() Return ;---\Facebook--- ;------------------------------------------------ ; -------------------------------Functions------------------------------- CheckLBRYProcess(){ ; Check if LBRY Process exists Process, Exist,LBRY.exe if(ErrorLevel = 0) ; if doesn't exist { Message = Not Running. Starting up LBRY.exe SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile") LBRYExeFilepath = C:\Program Files\LBRY\LBRY.exe if(!FileExist(LBRYExeFilepath)){ Message = Failed to Find LBRY.exe executable. LBRY not installed? SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") Return } Message = Checking LBRY daemon_settings.yml file for Odysee Wallet Servers SaveOrPostProgress(Message:=Message,PostType:=",ErrorLoggingTextFile,DiscordErrorLogging") FileRead, daemon_settingsFileContent, C:\Users\%A_UserName%\AppData\Local\lbry\lbrynet\daemon_settings.yml if(!InStr(daemon_settingsFileContent, "a-hub1.odysee.com")){ Message = Odysee wallet server is not in daemon_settings.yml. Replacing File with required settings. SaveOrPostProgress(Message:=Message,PostType:=",DiscordErrorLogging") LBRYDaemonSettingsFP = C:\Users\%A_UserName%\AppData\Local\lbry\lbrynet\daemon_settings.yml LBRYDaemonSettingsBackupFP = C:\Users\%A_UserName%\AppData\Local\lbry\lbrynet\daemon_settings_BU.yml ; Msgbox % "daemon_settingsText: " daemon_settingsText FileMove, %LBRYDaemonSettingsFP%, %LBRYDaemonSettingsBackupFP%, 1 ; Dest [, Flag (1 = overwrite)] UrlDownloadToFile, https://git.freedomainplaylists.com/yuriy/Freedomain-Video-Uploader/raw/branch/main/Assets/daemon_settings.yml , %LBRYDaemonSettingsFP% sleep, 1000 if(!FileExist(LBRYDaemonSettingsFP)){ Message = Failed to download the custom daemon_settings.yml file from git. Restoring Original File SaveOrPostProgress(Message:=Message,PostType:=",ErrorLoggingTextFile,DiscordErrorLogging") FileMove,%LBRYDaemonSettingsBackupFP%,%LBRYDaemonSettingsFP%, 1 } } try run, "%LBRYExeFilepath%" Message = Waiting 1 Minute for LBRY to start up SaveOrPostProgress(Message:=Message,PostType:="Tooltip") Sleep, 60000 ; 1 minute Process, Exist,LBRY.exe if(ErrorLevel = 0) ; if doesn't exist { Message = Failed to Start LBRY.exe after 60 seconds of waiting SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") Return } WinMinimize, LBRY } Return } GetPermanentLBRYURL(UploadResult){ SingleQuotationmark = " UploadResult := StrSplit(UploadResult, "`n") ; split results by new line ; Iterate through the array of the results Loop % UploadResult.Length() { PermanentURL := UploadResult[A_Index] if(InStr(PermanentURL, "permanent_url")) Break } ; Starting Result: "permanent_url": "lbry://Test-Video-161-Numbered#c9ad9afe54c7178d6f870b59bbe129aef8efc3ff", PermanentURL := StrSplit(PermanentURL, "lbry:") PermanentURL := "lbry:" . PermanentURL[2] PermanentURL := StrReplace(PermanentURL, ",", "") PermanentURL := StrReplace(PermanentURL, SingleQuotationmark, "") PermanentURL := StrReplace(PermanentURL, "`n", "") PermanentURL := StrReplace(PermanentURL, "`r", "") ; End Result lbry://Test-Video-161-Numbered#c9ad9afe54c7178d6f870b59bbe129aef8efc3ff Return PermanentURL } GetLBRYCanonicalURL(LBRYJSONObject){ ; input json string ; ResolveURL := StrSplit(LBRYResolveAPICommand, "lbry://") ; ResolveURL := "lbry://" . ResolveURL[2] ; StrReplace(Haystack, SearchText [, ReplaceText, OutputVarCount, Limit := -1]) LBRYPermanentURLJsonOBJ := StrReplace(LBRYJSONObject, LBRYPermanentURL, "LBRYPermanentURL") ; clipboard := LBRYPermanentURLJsonOBJ ; DevModeMsgBox(LBRYPermanentURLJsonOBJ) try parsed := JSON.Load(LBRYPermanentURLJsonOBJ) try LBRYCanonicalURL := parsed.LBRYPermanentURL.canonical_url ; DevModeMsgBox(LBRYCanonicalURL) if(LBRYCanonicalURL = ""){ Return "" ; return blank } ; otherwise return the LBRY url LBRYCanonicalURL := StrReplace(LBRYCanonicalURL, "lbry://", "https://lbry.tv/") Return LBRYCanonicalURL } LBRYCMDTextReplacement(LBRYURLSlug){ SingleQUote = " LBRYURLSlug := StrReplace(LBRYURLSlug, " ", "_") ; replace all spaces with dashes LBRYURLSlug := StrReplace(LBRYURLSlug, ":", "_") ; replace all colons with dashes LBRYURLSlug := StrReplace(LBRYURLSlug, ",", "_") ; replace all colons with dashes LBRYURLSlug := StrReplace(LBRYURLSlug, "?", "") ; replace all colons with dashes LBRYURLSlug := StrReplace(LBRYURLSlug, "!", "") ; replace all colons with dashes LBRYURLSlug := StrReplace(LBRYURLSlug, "`;", "_") ; replace all colons with dashes LBRYURLSlug := StrReplace(LBRYURLSlug, "/", "_") ; replace all colons with dashes ; LBRYURLSlug := StrReplace(LBRYURLSlug, "?", "") ; replace all colons with dashes LBRYURLSlug := StrReplace(LBRYURLSlug, "<", "_") ; replace all colons with dashes LBRYURLSlug := StrReplace(LBRYURLSlug, ">", "_") ; replace all colons with dashes LBRYURLSlug := StrReplace(LBRYURLSlug, SingleQUote, "") ; replace all colons with dashes LBRYURLSlug := StrReplace(LBRYURLSlug, "'", "") ; replace all colons with dashes LBRYURLSlug := StrReplace(LBRYURLSlug, "=", "") ; replace all colons with dashes LBRYURLSlug := StrReplace(LBRYURLSlug, ";", "") ; replace all colons with dashes LBRYURLSlug := StrReplace(LBRYURLSlug, ")", "") ; replace all colons with dashes LBRYURLSlug := StrReplace(LBRYURLSlug, "(", "") ; replace all colons with dashes LBRYURLSlug := StrReplace(LBRYURLSlug, "___", "_") ; replace all colons with dashes LBRYURLSlug := StrReplace(LBRYURLSlug, "__", "_") ; replace all colons with dashes LBRYURLSlug := StrReplace(LBRYURLSlug, "__", "_") ; replace all colons with dashes Return LBRYURLSlug } GetLBRYAPIErrorFromString(UploadResult){ UploadResultArray := StrSplit(UploadResult, "message") LBRYAPIError := UploadResultArray[2] ; LBRYAPIErrorStrLen := StrLen(LBRYAPIError) ; LBRYAPIErrorStrToTrim := LBRYAPIErrorStrLen - 3 ; Msgbox % "LBRYAPIErrorStrToTrim: " LBRYAPIErrorStrToTrim LBRYAPIError := SubStr(LBRYAPIError, 4) LBRYAPIError := StrReplace(LBRYAPIError, "}", "") ; Msgbox % "LBRYAPIError: " LBRYAPIError Return LBRYAPIError } LogErrorToTextFile(Error){ /* if(LogErrorsToTextFile != 1) Return */ ErrorLoggingFile := VideoFolderDir . "\" . "ErrorLogging.txt" FormatTime, TodayDate , YYYYMMDDHH24MISS, yyyyMMdd_hhmmss text = ( ---------------%TodayDate%--------------- %CurrentSite%: %Error% ) if(LogErrorsToMsgbox) Msgbox % "Text: " Text FileAppend, %Text%, %ErrorLoggingFile% } ; End of Function SaveDriverURL() AddToTotalVideosUploadedCount(){ IniRead, TotalVideosUploaded, %SettingsIniFilepath%, General, TotalVideosUploaded, %A_Space% TotalVideosUploaded += 1 IniWrite, %TotalVideosUploaded%, %SettingsIniFilepath%, General, TotalVideosUploaded } OnMsgBoxPodcastFinish() { DetectHiddenWindows, On Process, Exist If (WinExist("ahk_class #32770 ahk_pid " . ErrorLevel)) { WinMove,, 0 } } OnMsgBoxSocialMediaPoster() { DetectHiddenWindows, On Process, Exist If (WinExist("ahk_class #32770 ahk_pid " . ErrorLevel)) { ControlSetText Button1, Yes ControlSetText Button2, Not Now } } Check_For_Stuck_Video_Upload(Index_Number, Upload_Status){ if(A_index = 1){ ; Create a blank array ProgressStatusArray := [] Return } Message = Upload Status: %Upload_Status% SaveOrPostProgress(Message:=Message,PostType:="Tooltip") ; if we reached the last loop number: if(A_index = %Number_of_loops_to_Check_Upload_status%){ Message = Upload Most Likely Failed: Video Hasn't Finished Uploading after 1 hour. SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return "Failed" } ; If progress is still the same after a ten minute interval then error out if(HasVal(Array_Index_Num_of_Upload_StatusChecks, A_index)){ ; if current index is in Array of index numbers to check status during ; Send a notification message of upload status Message = Upload Status: %Upload_Status% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,DiscordErrorLogging") ; if current upload_status is in the array of values that are updated every 10 mins if(HasVal(ProgressStatusArray, Upload_Status)){ Message = Upload Failed (E#4508)`nUpload Stuck at same point for 10 minutes. Stuck Status: %ProgressStatus% SaveOrPostProgress(Message:=Message,PostType:="Tooltip,ErrorLoggingTextFile,ErrorSummaryVar,DiscordErrorLogging") SaveDriverURLOFErrorPage() Return "Failed" } ProgressStatusArray.Push(Upload_Status) ; append current status to array } } ; end of func