| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
 | /*
FTP File YM plugin
Copyright (C) 2007-2010 Jan Holub
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 version 2
of the License.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include "common.h"
#include "job_delete.h"
Event DeleteJob::jobDone;
Mutex DeleteJob::mutexJobCount;
int DeleteJob::iRunningJobCount = 0;
extern ServerList &ftpList;
extern Manager *manDlg;
extern LibCurl &curl; 
DeleteJob::DeleteJob(DBEntry *_entry, Manager::TreeItem *_item)
:entry(_entry),treeItem(_item),ftp(ftpList[entry->iFtpNum])
{ }
DeleteJob::~DeleteJob()
{
	delete this->entry;
}
void DeleteJob::waitingThread(void *arg) 
{
	DeleteJob *job = (DeleteJob *)arg;
	while(!Miranda_Terminated())
	{
		Lock *lock = new Lock(mutexJobCount);
		if (iRunningJobCount < MAX_RUNNING_JOBS)
		{
			iRunningJobCount++;
			delete lock;
			job->run();
			delete job;
			Lock *lock = new Lock(mutexJobCount);
			iRunningJobCount--;
			delete lock;
			jobDone.release();
			return;
		}
		delete lock;
		jobDone.wait();
	}
	delete job;
}
void DeleteJob::start()
{
	mir_forkthread(&DeleteJob::waitingThread, this);
}
void DeleteJob::run()
{
	char szError[1024];
	CURL *hCurl = curl.easy_init();
	if (hCurl)
	{
		struct curl_slist *headerList = NULL;
		headerList = curl.slist_append(headerList, getDelFileString());
		Utils::curlSetOpt(hCurl, this->ftp, getDelUrlString(), headerList, szError);
		int result = curl.easy_perform(hCurl);
		if (result == CURLE_OK)
		{
			if (manDlg != NULL && this->treeItem)
				this->treeItem->remove();
			else
				DBEntry::remove(entry->fileID);
		}
		else if (manDlg != NULL && this->treeItem)
		{
			TCHAR *error = mir_a2t(szError);
			_tcscpy(this->treeItem->stzToolTip, error);
			this->treeItem->setState(Manager::TreeItem::_ERROR());
			FREE(error);
		}				
		curl.slist_free_all(headerList);
		curl.easy_cleanup(hCurl);
	}
}
char *DeleteJob::getDelFileString()
{
	if (ftp->ftpProto == ServerList::FTP::FT_SSH)
		mir_snprintf(buff, sizeof(buff), "rm \"%s/%s\"", ftp->szDir, entry->szFileName);
	else
		mir_snprintf(buff, sizeof(buff), "DELE %s", entry->szFileName);
	return buff;
}
char *DeleteJob::getDelUrlString()
{	
	if (ftp->szDir[0] && ftp->ftpProto != ServerList::FTP::FT_SSH)
		mir_snprintf(buff, sizeof(buff), "%s%s/%s/", ftp->getProtoString(), ftp->szServer, ftp->szDir);
	else
		mir_snprintf(buff, sizeof(buff), "%s%s/", ftp->getProtoString(), ftp->szServer);
	return buff;
}
 |