mirror of
https://github.com/AAndyProgram/SCrawler.git
synced 2026-03-14 15:52:18 +00:00
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
154 lines
7.8 KiB
VB.net
154 lines
7.8 KiB
VB.net
' Copyright (C) 2023 Andy https://github.com/AAndyProgram
|
|
' This program is free software: you can redistribute it and/or modify
|
|
' it under the terms of the GNU General Public License as published by
|
|
' the Free Software Foundation, either version 3 of the License, or
|
|
' (at your option) any later version.
|
|
'
|
|
' This program is distributed in the hope that it will be useful,
|
|
' but WITHOUT ANY WARRANTY
|
|
Imports PersonalUtilities.Forms
|
|
Imports PersonalUtilities.Forms.Controls.Base
|
|
Namespace API.Mastodon
|
|
Friend Class SettingsForm
|
|
Private WithEvents MyDefs As DefaultFormOptions
|
|
Friend ReadOnly Property MyCredentials As List(Of Credentials)
|
|
Friend ReadOnly Property MyDomains As List(Of String)
|
|
Friend Sub New(ByVal s As SiteSettings)
|
|
InitializeComponent()
|
|
MyCredentials = New List(Of Credentials)
|
|
If s.Domains.Credentials.Count > 0 Then MyCredentials.AddRange(s.Domains.Credentials)
|
|
MyDomains = New List(Of String)
|
|
MyDomains.ListAddList(s.Domains)
|
|
MyDefs = New DefaultFormOptions(Me, Settings.Design)
|
|
End Sub
|
|
Private Sub MyForm_Load(sender As Object, e As EventArgs) Handles Me.Load
|
|
With MyDefs
|
|
.MyView = New FormView(Me, Settings.Design, "MastodonSettingsForm")
|
|
.MyView.Import()
|
|
.MyView.SetFormSize()
|
|
.AddOkCancelToolbar()
|
|
RefillList()
|
|
.EndLoaderOperations()
|
|
End With
|
|
End Sub
|
|
Private Sub SettingsForm_Disposed(sender As Object, e As EventArgs) Handles Me.Disposed
|
|
MyCredentials.Clear()
|
|
MyDomains.Clear()
|
|
End Sub
|
|
Private Sub RefillList()
|
|
CMB_DOMAINS.Items.Clear()
|
|
If MyDomains.Count > 0 Then
|
|
MyDomains.Sort()
|
|
CMB_DOMAINS.BeginUpdate()
|
|
CMB_DOMAINS.Items.AddRange(MyDomains.Select(Function(d) New ListItem(d)))
|
|
CMB_DOMAINS.EndUpdate(True)
|
|
End If
|
|
End Sub
|
|
Private Sub MyDefs_ButtonOkClick(ByVal Sender As Object, ByVal e As KeyHandleEventArgs) Handles MyDefs.ButtonOkClick
|
|
ApplyCredentials()
|
|
If MyCredentials.Count > 0 Then MyCredentials.RemoveAll(Function(c) c.Domain.IsEmptyString Or c.Bearer.IsEmptyString Or c.Csrf.IsEmptyString)
|
|
If MyDomains.Count > 0 Then
|
|
If MyCredentials.Count > 0 Then
|
|
MyCredentials.RemoveAll(Function(c) Not MyDomains.Contains(c.Domain))
|
|
Else
|
|
MyCredentials.Clear()
|
|
End If
|
|
End If
|
|
MyDefs.CloseForm()
|
|
End Sub
|
|
Private Sub CMB_DOMAINS_ActionOnButtonClick(ByVal Sender As ActionButton, ByVal e As ActionButtonEventArgs) Handles CMB_DOMAINS.ActionOnButtonClick
|
|
Try
|
|
Dim d$
|
|
Dim i% = -1
|
|
Select Case e.DefaultButton
|
|
Case ActionButton.DefaultButtons.Add
|
|
d = InputBoxE("Enter a new domain using the pattern [mastodon.social]:", "New domain")
|
|
If Not d.IsEmptyString Then
|
|
If MyDomains.Count > 0 Then i = MyDomains.IndexOf(d)
|
|
If i >= 0 Then
|
|
MsgBoxE({$"Domain '{d}' already exists", "Add domain"}, vbExclamation)
|
|
If i <= CMB_DOMAINS.Count - 1 Then CMB_DOMAINS.SelectedIndex = i
|
|
Else
|
|
ApplyCredentials()
|
|
ClearCredentials()
|
|
MyDomains.Add(d)
|
|
_Suspended = True
|
|
RefillList()
|
|
_Suspended = False
|
|
i = MyDomains.IndexOf(d)
|
|
If i.ValueBetween(0, CMB_DOMAINS.Count - 1) Then
|
|
CMB_DOMAINS.SelectedIndex = i
|
|
Else
|
|
_LatestSelected = -1
|
|
_CurrentCredentialsIndex = -1
|
|
_CurrentDomain = String.Empty
|
|
End If
|
|
End If
|
|
End If
|
|
Case ActionButton.DefaultButtons.Delete
|
|
If _LatestSelected >= 0 Then
|
|
d = CMB_DOMAINS.Items(_LatestSelected).Value(0)
|
|
If Not d.IsEmptyString AndAlso MsgBoxE({$"Are you sure you want to delete the [{d}] domain?",
|
|
"Removing domains"}, vbYesNo) = vbYes Then
|
|
i = MyDomains.IndexOf(d)
|
|
Dim l% = _LatestSelected
|
|
If i >= 0 Then
|
|
ClearCredentials()
|
|
MyDomains.RemoveAt(i)
|
|
_Suspended = True
|
|
RefillList()
|
|
_Suspended = False
|
|
If (l - 1).ValueBetween(0, CMB_DOMAINS.Count - 1) Then
|
|
CMB_DOMAINS.SelectedIndex = l - 1
|
|
Else
|
|
_LatestSelected = -1
|
|
_CurrentCredentialsIndex = -1
|
|
_CurrentDomain = String.Empty
|
|
End If
|
|
End If
|
|
End If
|
|
End If
|
|
End Select
|
|
Catch ex As Exception
|
|
ErrorsDescriber.Execute(EDP.LogMessageValue, ex, "API.Mastodon.SettingsForm.ActionButtonClick")
|
|
End Try
|
|
End Sub
|
|
Private _LatestSelected As Integer = -1
|
|
Private _CurrentCredentialsIndex As Integer = -1
|
|
Private _CurrentDomain As String = String.Empty
|
|
Private _Suspended As Boolean = False
|
|
Private Sub CMB_DOMAINS_ActionSelectedItemChanged(ByVal Sender As Object, ByVal e As EventArgs, ByVal Item As ListViewItem) Handles CMB_DOMAINS.ActionSelectedItemChanged
|
|
If Not MyDefs.Initializing And Not _Suspended Then
|
|
Dim DropCredentials As Boolean = True
|
|
If Not Item Is Nothing Then
|
|
ApplyCredentials()
|
|
_LatestSelected = Item.Index
|
|
_CurrentDomain = Item.Text
|
|
If MyCredentials.Count > 0 And Not _CurrentDomain.IsEmptyString Then
|
|
_CurrentCredentialsIndex = MyCredentials.IndexOf(_CurrentDomain)
|
|
If _CurrentCredentialsIndex >= 0 Then
|
|
With MyCredentials(_CurrentCredentialsIndex) : TXT_AUTH.Text = .Bearer : TXT_TOKEN.Text = .Csrf : End With
|
|
DropCredentials = False
|
|
End If
|
|
Else
|
|
_CurrentCredentialsIndex = -1
|
|
End If
|
|
End If
|
|
If DropCredentials Then ClearCredentials()
|
|
End If
|
|
End Sub
|
|
Private Sub ClearCredentials()
|
|
TXT_AUTH.Clear()
|
|
TXT_TOKEN.Clear()
|
|
End Sub
|
|
Private Sub ApplyCredentials()
|
|
Try
|
|
If _LatestSelected >= 0 And Not _CurrentDomain.IsEmptyString Then
|
|
Dim c As New Credentials With {.Domain = _CurrentDomain, .Bearer = TXT_AUTH.Text, .Csrf = TXT_TOKEN.Text}
|
|
If _CurrentCredentialsIndex.ValueBetween(0, MyCredentials.Count - 1) Then MyCredentials(_CurrentCredentialsIndex) = c Else MyCredentials.Add(c)
|
|
End If
|
|
Catch ex As Exception
|
|
End Try
|
|
End Sub
|
|
End Class
|
|
End Namespace |