2023.4.28.0

Plugins
IPluginContentProvider: added DownloadSingleObject function; added tokens to GetMedia and Download functions; removed GetSpecialData function
Add IDownloadableMedia interface
Removed 'Channel' option from all functions and enums
ISiteSettings: added GetSingleMediaInstance function
ExchangeOptions: removed 'IsChannel'
UserMediaTypes: added Audio and AudioPre enums
IUserMedia, PluginUserMedia: changed ContentType and DownloadState from integers to their enums

SCrawler
Add YouTube standalone downloader
Add gallery-dl & yt-dlp support
Remove 'UserInfo' requirement from 'ProfilesSaved'
Update 'SiteSettingsBase' to use domains and Netscape cookies
UserDataBase: remove channels; remove old 'Merge' const; standardize SavedPosts file naming; move 'ValidateMD5' function from Twitter to UserDataBase to use it in other UserData classes; add 'DownloadSingleObject' environment for single posts; add validating file extension for m3u8 during download; add reindex of video file during download

Rewritten DomainsContainer
Create a universal settings form and PSettingsArttribute
Gfycat, Imgur: turn these classes into IUserData to download a single object

All plugins: update 'GetInstance' function for saved posts; update domains where implemented; remove 'OptionForm' where it exists; update options where they exist; update unix date providers; reconfigure channels where they exist

LPSG: fix attachments; update converters and regex
Add sites: ThisVid, Mastodon, Pinterest, YouTube, YouTube music
Reddit: standardize container parsing for all data types; new channel environment; fix 'ReparseMissing' function; redirect data downloading to the base download function, saved crossposts support
Twitter: fixed gif path bug; fixed downloading saved posts
PornHub: hide unnecessary errors; photo galleries bug
RedGifs: add 'UserAgent' option

Added icons to download progress

Rename some objects
Completely redesigned standalone downloader form and rewritten its environment
WebClient2: update to use tokens

Labels: update label form (save labels to file only when OK button is clicked); change removing labels.txt from recycle bin to permanent; disable storing label 'NoParsedUser'

UserCreatorForm: remove the 'Channel' checkbox and related functions; ability to extract the user's URL from the buffer and apply parameters if found
Remove temporary 'EncryptCookies' module

MainFrame: added simplified way to create new users (Ctrl+Insert to create a new user with default parameters from clipboard URL); removed SCrawler command line argument "-v" (remove the ability to run SCrawler as video downloader)
PropertyValueHost: update for option forms compatibility
SettingsHost: removed 'GetSpecialData' fork; added 'GetSingleMediaInstance' fork
UserDataHost: update functions with tokens; update events; add 'DownloadSingleObject' function
Settings: add the ability to get environment from 4 destinations; add the ability to set the program environment manually; add CMDEncoding; add cache; remove the old function 'RemoveUnusedPlugins'; add 'STDownloader' properties; add YT compatibility; add new notification options; add deleting user settings file when 'SettingsCLS.Dispose()' if where are no users in SCrawler
UserFinder: remove old 'Merge' const; remove channel option
UserInfo: remove channel option
This commit is contained in:
Andy
2023-04-28 10:13:46 +03:00
parent db9e2cfb88
commit b2a9b22478
270 changed files with 18120 additions and 3332 deletions

View File

@@ -213,7 +213,7 @@ Namespace DownloadObjects
End If
If fList.ListExists Then fList.Clear()
Catch ex As Exception
ErrorsDescriber.Execute(EDP.SendInLog, ex, $"[DownloadObjects.DownloadFeedForm.SessionChooser({GetLast})]")
ErrorsDescriber.Execute(EDP.SendToLog, ex, $"[DownloadObjects.DownloadFeedForm.SessionChooser({GetLast})]")
End Try
End Sub
#End Region
@@ -242,7 +242,7 @@ Namespace DownloadObjects
If d > 0 Then
.AutoScroll = False
.AutoScroll = True
If LatestScrollValue.HasValue Then TP_DATA.VerticalScroll.Value = LatestScrollValue.Value
SetScrollValue(False)
.PerformLayout()
LatestScrollValueDisabled = False
End If
@@ -302,7 +302,7 @@ Namespace DownloadObjects
If HeightChanged Then
TP_DATA.AutoScroll = False
TP_DATA.AutoScroll = True
If LatestScrollValue.HasValue Then TP_DATA.VerticalScroll.Value = LatestScrollValue.Value
SetScrollValue(False)
TP_DATA.PerformLayout()
LatestScrollValueDisabled = False
End If
@@ -331,10 +331,7 @@ Namespace DownloadObjects
DirectCast(MyRange.Switcher, RangeSwitcher(Of UserMediaD)).PerformIndexChanged()
If Not indxChanged Then
LatestScrollValueDisabled = False
If LatestScrollValue.HasValue Then
TP_DATA.VerticalScroll.Value = LatestScrollValue.Value
TP_DATA.PerformLayout()
End If
SetScrollValue(True)
End If
End If
.HandlersSuspended = False
@@ -415,7 +412,7 @@ Namespace DownloadObjects
RefillInProgress = False
End If
Catch ex As Exception
ErrorsDescriber.Execute(EDP.SendInLog, ex, $"[DownloadObjects.DownloadFeedForm.Range.IndexChanged({Sender.CurrentIndex})]")
ErrorsDescriber.Execute(EDP.SendToLog, ex, $"[DownloadObjects.DownloadFeedForm.Range.IndexChanged({Sender.CurrentIndex})]")
RefillInProgress = False
Finally
If Not RefillInProgress AndAlso Sender.CurrentIndex >= 0 Then
@@ -495,8 +492,7 @@ Namespace DownloadObjects
If LatestScrollValue.HasValue Then ControlInvoke(TP_DATA, Sub()
Dim b As Boolean = ScrollSuspended
If Not b Then ScrollSuspended = True
TP_DATA.VerticalScroll.Value = LatestScrollValue.Value
TP_DATA.PerformLayout()
SetScrollValue(True)
If Not b Then ScrollSuspended = False
End Sub)
End Sub
@@ -515,6 +511,26 @@ Namespace DownloadObjects
End Sub)
End If
End Sub
Private Sub TP_DATA_StyleChanged(sender As Object, e As EventArgs) Handles TP_DATA.StyleChanged
ControlInvokeFast(TP_DATA, Sub()
With TP_DATA
.Padding = New Padding(0, 0, .VerticalScroll.Visible.BoolToInteger * 3, 0)
.HorizontalScroll.Visible = False
.HorizontalScroll.Enabled = False
.PerformLayout()
End With
End Sub, EDP.None)
End Sub
Private Sub SetScrollValue(ByVal Perform As Boolean)
With TP_DATA
If LatestScrollValue.HasValue Then
If LatestScrollValue.Value < 0 Then LatestScrollValue = 0
If LatestScrollValue.Value > .VerticalScroll.Maximum Then LatestScrollValue = .VerticalScroll.Maximum
.VerticalScroll.Value = LatestScrollValue.Value
If Perform Then .PerformLayout()
End If
End With
End Sub
#End Region
Private Sub ClearTable()
ControlInvoke(TP_DATA, Sub()