git-svn-id: svn://db.shs.com.ru/pip@236 12ceb7fc-bf1f-11e4-8940-5bc7170c53b5

This commit is contained in:
2016-08-23 13:24:12 +00:00
parent 7b227f15ac
commit fb25f8dbfe
16 changed files with 136 additions and 57 deletions

View File

@@ -188,7 +188,7 @@ public:
llong logSize() const {return file.size();} llong logSize() const {return file.size();}
//! Return true, if position at the end of BinLog file //! Return true, if position at the end of BinLog file
bool isEnd() const {if (!opened_) return true; return file.isEnd();} bool isEnd() const {if (isClosed()) return true; return file.isEnd();}
//! Returns if BinLog file is empty //! Returns if BinLog file is empty
bool isEmpty() const {return (file.size() <= PIBINARYLOG_SIGNATURE_SIZE + 1);} bool isEmpty() const {return (file.size() <= PIBINARYLOG_SIGNATURE_SIZE + 1);}

View File

@@ -123,7 +123,8 @@ PIEthernet::PIEthernet(int sock_, PIString ip_port): PIIODevice("", ReadWrite) {
construct(); construct();
parseAddress(ip_port, &ip_s, &port_s); parseAddress(ip_port, &ip_s, &port_s);
sock = sock_; sock = sock_;
init_ = opened_ = connected_ = true; opened_ = connected_ = true;
init();
setParameters(PIEthernet::ReuseAddress | PIEthernet::MulticastLoop); setParameters(PIEthernet::ReuseAddress | PIEthernet::MulticastLoop);
setType(TCP_Client, false); setType(TCP_Client, false);
setPath(ip_port); setPath(ip_port);
@@ -157,6 +158,7 @@ void PIEthernet::construct() {
bool PIEthernet::init() { bool PIEthernet::init() {
if (isOpened()) return true;
//cout << "init " << type_ << endl; //cout << "init " << type_ << endl;
if (sock_s == sock) if (sock_s == sock)
sock_s = -1; sock_s = -1;
@@ -348,7 +350,7 @@ bool PIEthernet::joinMulticastGroup(const PIString & group) {
piCoutObj << "Only UDP sockets can join multicast groups"; piCoutObj << "Only UDP sockets can join multicast groups";
return false; return false;
} }
if (!opened_) { if (isClosed()) {
if (mcast_queue.contains(group)) if (mcast_queue.contains(group))
return false; return false;
mcast_queue.enqueue(group); mcast_queue.enqueue(group);

View File

@@ -155,22 +155,23 @@ bool PIFile::openDevice() {
} }
} }
fd = _fopen_call_(p.data(), strType(mode_).data()); fd = _fopen_call_(p.data(), strType(mode_).data());
opened_ = (fd != 0); bool opened = (fd != 0);
if (opened_) { if (opened) {
fdi = fileno(fd); fdi = fileno(fd);
#ifndef WINDOWS #ifndef WINDOWS
fcntl(fdi, F_SETFL, O_NONBLOCK); fcntl(fdi, F_SETFL, O_NONBLOCK);
#endif #endif
seekToBegin(); _fseek_call_(fd, 0, SEEK_SET);
clearerr(fd);
} }
//piCout << "open file" << fd << opened_; //piCout << "open file" << fd << opened_;
return opened_; return opened;
} }
bool PIFile::closeDevice() { bool PIFile::closeDevice() {
//piCout << "close file" << fd << opened_; //piCout << "close file" << fd << opened_;
if (!opened_ || fd == 0) return true; if (isClosed() || fd == 0) return true;
bool cs = (fclose(fd) == 0); bool cs = (fclose(fd) == 0);
if (cs) fd = 0; if (cs) fd = 0;
fdi = -1; fdi = -1;
@@ -181,7 +182,7 @@ bool PIFile::closeDevice() {
PIString PIFile::readLine() { PIString PIFile::readLine() {
PIByteArray str; PIByteArray str;
if (!opened_) return str; if (isClosed()) return str;
int cc; int cc;
while (!isEnd()) { while (!isEnd()) {
cc = fgetc(fd); cc = fgetc(fd);
@@ -231,7 +232,7 @@ PIByteArray PIFile::readAll(bool forceRead) {
llong PIFile::size() const { llong PIFile::size() const {
if (!opened_) return -1; if (isClosed()) return -1;
llong s, cp = pos(); llong s, cp = pos();
_fseek_call_(fd, 0, SEEK_END); clearerr(fd); _fseek_call_(fd, 0, SEEK_END); clearerr(fd);
s = pos(); s = pos();
@@ -298,33 +299,33 @@ PIString PIFile::strType(const PIIODevice::DeviceMode type) {
void PIFile::flush() { void PIFile::flush() {
if (opened_) fflush(fd); if (isOpened()) fflush(fd);
} }
void PIFile::seek(llong position) { void PIFile::seek(llong position) {
if (!opened_) return; if (isClosed()) return;
_fseek_call_(fd, position, SEEK_SET); _fseek_call_(fd, position, SEEK_SET);
clearerr(fd); clearerr(fd);
} }
void PIFile::seekToBegin() { void PIFile::seekToBegin() {
if (!opened_) return; if (isClosed()) return;
_fseek_call_(fd, 0, SEEK_SET); _fseek_call_(fd, 0, SEEK_SET);
clearerr(fd); clearerr(fd);
} }
void PIFile::seekToEnd() { void PIFile::seekToEnd() {
if (!opened_) return; if (isClosed()) return;
_fseek_call_(fd, 0, SEEK_END); _fseek_call_(fd, 0, SEEK_END);
clearerr(fd); clearerr(fd);
} }
void PIFile::seekToLine(llong line) { void PIFile::seekToLine(llong line) {
if (!opened_) return; if (isClosed()) return;
seekToBegin(); seekToBegin();
piForTimes(line) readLine(); piForTimes(line) readLine();
clearerr(fd); clearerr(fd);
@@ -338,18 +339,18 @@ char PIFile::readChar() {
void PIFile::setPath(const PIString & path) { void PIFile::setPath(const PIString & path) {
PIIODevice::setPath(path); PIIODevice::setPath(path);
if (opened_) openDevice(); if (isOpened()) openDevice();
} }
llong PIFile::pos() const { llong PIFile::pos() const {
if (!opened_) return -1; if (isClosed()) return -1;
return _ftell_call_(fd); return _ftell_call_(fd);
} }
bool PIFile::isEnd() const { bool PIFile::isEnd() const {
if (!opened_) return true; if (isClosed()) return true;
return (feof(fd) || ferror(fd)); return (feof(fd) || ferror(fd));
} }

View File

@@ -183,7 +183,7 @@ void PIIODevice::write_func() {
void PIIODevice::terminate() { void PIIODevice::terminate() {
timer.stop(); timer.stop();
thread_started_ = false; thread_started_ = false;
if (!isInitialized()) return; if (!init_) return;
if (isRunning()) { if (isRunning()) {
stop(); stop();
PIThread::terminate(); PIThread::terminate();

View File

@@ -82,8 +82,6 @@ public:
//! Return \b true if mode is WriteOnly or ReadWrite //! Return \b true if mode is WriteOnly or ReadWrite
bool isWriteable() const {return (mode_ & WriteOnly);} bool isWriteable() const {return (mode_ & WriteOnly);}
bool isInitialized() const {return init_;}
//! Return \b true if device is successfully opened //! Return \b true if device is successfully opened
bool isOpened() const {return opened_;} bool isOpened() const {return opened_;}
@@ -215,7 +213,6 @@ public:
EVENT_HANDLER1(bool, open, const DeviceMode &, _mode) {mode_ = _mode; if (!init_) init(); opened_ = openDevice(); if (opened_) opened(); return opened_;} EVENT_HANDLER1(bool, open, const DeviceMode &, _mode) {mode_ = _mode; if (!init_) init(); opened_ = openDevice(); if (opened_) opened(); return opened_;}
EVENT_HANDLER2(bool, open, const PIString &, _path, const DeviceMode &, _mode) {setPath(_path); mode_ = _mode; if (!init_) init(); opened_ = openDevice(); if (opened_) opened(); return opened_;} EVENT_HANDLER2(bool, open, const PIString &, _path, const DeviceMode &, _mode) {setPath(_path); mode_ = _mode; if (!init_) init(); opened_ = openDevice(); if (opened_) opened(); return opened_;}
EVENT_HANDLER(bool, close) {opened_ = !closeDevice(); if (!opened_) closed(); return !opened_;} EVENT_HANDLER(bool, close) {opened_ = !closeDevice(); if (!opened_) closed(); return !opened_;}
EVENT_HANDLER(bool, initialize) {init_ = init(); return init_;}
EVENT_VHANDLER(void, flush) {;} EVENT_VHANDLER(void, flush) {;}
@@ -242,9 +239,6 @@ public:
//! \fn bool close() //! \fn bool close()
//! \brief Close device //! \brief Close device
//! \fn bool initialize()
//! \brief Initialize device
//! \} //! \}
//! \vhandlers //! \vhandlers
//! \{ //! \{
@@ -310,7 +304,7 @@ protected:
DeviceMode mode_; DeviceMode mode_;
ReadRetFunc ret_func_; ReadRetFunc ret_func_;
bool init_, opened_, thread_started_, raise_threaded_read_; bool opened_;
void * ret_data_; void * ret_data_;
private: private:
@@ -330,6 +324,7 @@ private:
PIQueue<PIPair<PIByteArray, ullong> > write_queue; PIQueue<PIPair<PIByteArray, ullong> > write_queue;
ullong tri; ullong tri;
int readed_; int readed_;
bool init_, thread_started_, raise_threaded_read_;
}; };

View File

@@ -84,13 +84,13 @@ REGISTER_DEVICE(PIPacketExtractor);
PIPacketExtractor::PIPacketExtractor(PIIODevice * device_, PIPacketExtractor::SplitMode mode) { PIPacketExtractor::PIPacketExtractor(PIIODevice * device_, PIPacketExtractor::SplitMode mode) {
init_(); construct();
setDevice(device_); setDevice(device_);
setSplitMode(mode); setSplitMode(mode);
} }
void PIPacketExtractor::init_() { void PIPacketExtractor::construct() {
ret_func_header = ret_func_footer = 0; ret_func_header = ret_func_footer = 0;
setPayloadSize(0); setPayloadSize(0);
setTimeout(100); setTimeout(100);

View File

@@ -165,7 +165,7 @@ protected:
virtual bool validatePayload(uchar * rec, int size) {if (ret_func_ != 0) return ret_func_(ret_data_, rec, size); return true;} virtual bool validatePayload(uchar * rec, int size) {if (ret_func_ != 0) return ret_func_(ret_data_, rec, size); return true;}
private: private:
void init_(); void construct();
void propertyChanged(const PIString & ); void propertyChanged(const PIString & );
bool threadedRead(uchar * readed, int size); bool threadedRead(uchar * readed, int size);
PIString fullPathPrefix() const {return "pckext";} PIString fullPathPrefix() const {return "pckext";}

View File

@@ -140,12 +140,12 @@ PRIVATE_DEFINITION_END(PISerial)
PISerial::PISerial(): PIIODevice("", ReadWrite) { PISerial::PISerial(): PIIODevice("", ReadWrite) {
_init(); construct();
} }
PISerial::PISerial(const PIString & device_, PISerial::Speed speed_, PIFlags<PISerial::Parameters> params_): PIIODevice(device_, ReadWrite) { PISerial::PISerial(const PIString & device_, PISerial::Speed speed_, PIFlags<PISerial::Parameters> params_): PIIODevice(device_, ReadWrite) {
_init(); construct();
setPath(device_); setPath(device_);
setSpeed(speed_); setSpeed(speed_);
setParameters(params_); setParameters(params_);
@@ -157,7 +157,7 @@ PISerial::~PISerial() {
} }
void PISerial::_init() { void PISerial::construct() {
#ifdef WINDOWS #ifdef WINDOWS
PRIVATE->hCom = 0; PRIVATE->hCom = 0;
#endif #endif
@@ -169,7 +169,6 @@ void PISerial::_init() {
setParameters(0); setParameters(0);
setSpeed(S115200); setSpeed(S115200);
setDataBitsCount(8); setDataBitsCount(8);
//init();
} }
@@ -289,7 +288,6 @@ void PISerial::flush() {
bool PISerial::closeDevice() { bool PISerial::closeDevice() {
if (!isInitialized()) return true;
if (isRunning()) { if (isRunning()) {
stop(); stop();
PIThread::terminate(); PIThread::terminate();
@@ -298,7 +296,7 @@ bool PISerial::closeDevice() {
#ifdef WINDOWS #ifdef WINDOWS
SetCommState(PRIVATE->hCom, &PRIVATE->sdesc); SetCommState(PRIVATE->hCom, &PRIVATE->sdesc);
SetCommMask(PRIVATE->hCom, PRIVATE->mask); SetCommMask(PRIVATE->hCom, PRIVATE->mask);
CloseHandle(PRIVATE->hCom); // piCoutObj << "close" << CloseHandle(PRIVATE->hCom);
PRIVATE->hCom = 0; PRIVATE->hCom = 0;
#else #else
tcsetattr(fd, TCSANOW, &PRIVATE->sdesc); tcsetattr(fd, TCSANOW, &PRIVATE->sdesc);

View File

@@ -223,7 +223,7 @@ protected:
//! Executes when any read function was successful. Default implementation does nothing //! Executes when any read function was successful. Default implementation does nothing
virtual void received(const void * data, int size) {;} virtual void received(const void * data, int size) {;}
void _init(); void construct();
void applySettings(); void applySettings();
int convertSpeed(PISerial::Speed speed); int convertSpeed(PISerial::Speed speed);
bool setBit(int bit, bool on, const PIString & bname); bool setBit(int bit, bool on, const PIString & bname);

View File

@@ -298,7 +298,7 @@ bool PIUSB::closeDevice() {
int PIUSB::read(void * read_to, int max_size) { int PIUSB::read(void * read_to, int max_size) {
#ifdef PIP_USB #ifdef PIP_USB
if (!opened_ || ep_read.isNull()) return -1; if (isClosed() || ep_read.isNull()) return -1;
switch (ep_read.transfer_type) { switch (ep_read.transfer_type) {
case Endpoint::Bulk: /*piCoutObj << "bulk read" << max_size;*/ return usb_bulk_read(hdev, ep_read.address, (char * )read_to, max_size, timeout_r); break; case Endpoint::Bulk: /*piCoutObj << "bulk read" << max_size;*/ return usb_bulk_read(hdev, ep_read.address, (char * )read_to, max_size, timeout_r); break;
case Endpoint::Interrupt: return usb_interrupt_read(hdev, ep_read.address, (char * )read_to, max_size, timeout_r); break; case Endpoint::Interrupt: return usb_interrupt_read(hdev, ep_read.address, (char * )read_to, max_size, timeout_r); break;
@@ -313,7 +313,7 @@ int PIUSB::read(void * read_to, int max_size) {
int PIUSB::write(const void * data, int max_size) { int PIUSB::write(const void * data, int max_size) {
#ifdef PIP_USB #ifdef PIP_USB
if (!opened_ || ep_write.isNull()) return -1; if (isClosed() || ep_write.isNull()) return -1;
switch (ep_read.transfer_type) { switch (ep_read.transfer_type) {
case Endpoint::Bulk: /*piCoutObj << "bulk write" << max_size;*/ return usb_bulk_write(hdev, ep_write.address, (char * )const_cast<void * >(data), max_size, timeout_w); break; case Endpoint::Bulk: /*piCoutObj << "bulk write" << max_size;*/ return usb_bulk_write(hdev, ep_write.address, (char * )const_cast<void * >(data), max_size, timeout_w); break;
case Endpoint::Interrupt: return usb_interrupt_write(hdev, ep_read.address, (char * )data, max_size, timeout_w); break; case Endpoint::Interrupt: return usb_interrupt_write(hdev, ep_read.address, (char * )data, max_size, timeout_w); break;
@@ -328,7 +328,7 @@ int PIUSB::write(const void * data, int max_size) {
int PIUSB::controlWrite(const void * data, int max_size) { int PIUSB::controlWrite(const void * data, int max_size) {
#ifdef PIP_USB #ifdef PIP_USB
if (!opened_) return -1; if (isClosed()) return -1;
//return usb_control_msg(hdev, ); //return usb_control_msg(hdev, );
return -1; return -1;
#else #else
@@ -339,7 +339,7 @@ int PIUSB::controlWrite(const void * data, int max_size) {
void PIUSB::flush() { void PIUSB::flush() {
#ifdef PIP_USB #ifdef PIP_USB
if (!opened_) return; if (isClosed()) return;
if (!ep_read.isNull()) usb_resetep(hdev, ep_read.address); if (!ep_read.isNull()) usb_resetep(hdev, ep_read.address);
if (!ep_write.isNull()) usb_resetep(hdev, ep_write.address); if (!ep_write.isNull()) usb_resetep(hdev, ep_write.address);
#endif #endif

View File

@@ -1,6 +1,7 @@
#include "daemon.h" #include "daemon.h"
#include "shared.h" #include "shared.h"
#include "pisysteminfo.h" #include "pisysteminfo.h"
#include "picrypt.h"
const char self_name[] = "__self__"; const char self_name[] = "__self__";
extern PIScreen screen; extern PIScreen screen;
@@ -43,7 +44,7 @@ void Daemon::Remote::run() {
case RemoveFiles: case RemoveFiles:
::removeFiles(d, _fl); ::removeFiles(d, _fl);
updateDirEntries(); updateDirEntries();
removeFinished(name(), d.absolutePath()); changeDirFinished(name(), d.absolutePath());
break; break;
case RequestChangeDir: case RequestChangeDir:
updateDirEntries(); updateDirEntries();
@@ -54,6 +55,15 @@ void Daemon::Remote::run() {
updateDirEntries(); updateDirEntries();
changeDirFinished(name(), d.absolutePath()); changeDirFinished(name(), d.absolutePath());
break; break;
case CryptFiles:
piCoutObj << "CryptFiles";
if (!_fl.isEmpty()) {
PIString p = askUserInput("Password:");
::cryptFiles(d, _fl, PICrypt::hash(p));
}
updateDirEntries();
changeDirFinished(name(), d.absolutePath());
break;
default: break; default: break;
}; };
} }
@@ -208,6 +218,7 @@ Daemon::Daemon(): inited__(false), PIPeer(pisd_prefix + PISystemInfo::instance()
CONNECTU(_self, sendRequest, this, localSend) CONNECTU(_self, sendRequest, this, localSend)
CONNECTU(_self, receiveFinished, this, closeFileDialog) CONNECTU(_self, receiveFinished, this, closeFileDialog)
CONNECTU(_self, sendFinished, this, closeFileDialog) CONNECTU(_self, sendFinished, this, closeFileDialog)
CONNECTU(_self, changeDirFinished, this, dirChanged)
localft.setName(self_name); localft.setName(self_name);
CONNECTU(&localft, sendRequest, _self, received) CONNECTU(&localft, sendRequest, _self, received)
dtimer.addDelimiter(5); dtimer.addDelimiter(5);
@@ -393,7 +404,7 @@ void Daemon::fmKeyEvent(PIKbdListener::KeyEvent key) {
void Daemon::fmActionRequest(bool remote_tile, FileManager::Action type, PIVariant data) { void Daemon::fmActionRequest(bool remote_tile, FileManager::Action type, PIVariant data) {
Remote * r = 0; Remote * r = 0;
r = remotes.value(conn_name, 0); r = remotes.value(conn_name, 0);
if (!r && type != FileManager::LocalCopy) return; if (!r && type != FileManager::LocalCopy && type != FileManager::LocalCrypt) return;
switch (type) { switch (type) {
case FileManager::Copy: case FileManager::Copy:
if (remote_tile) { if (remote_tile) {
@@ -435,6 +446,25 @@ void Daemon::fmActionRequest(bool remote_tile, FileManager::Action type, PIVaria
} }
tile_file_progress->rec = false; tile_file_progress->rec = false;
tile_file_progress->show(&(_self->ft)); tile_file_progress->show(&(_self->ft));
case FileManager::Crypt:
if (remote_tile) {
PIByteArray ba;
ba << int(CryptFiles) << fm.selectedRemote();
send(conn_name, ba);
} else {
_self->dir_my.setDir(fm.localDir());
_self->cryptFiles(data.toStringList());
}
break;
case FileManager::LocalCrypt:
piCoutObj << "LocalCrypt";
if (remote_tile) {
_self->dir_my.setDir(fm.remoteDir());
} else {
_self->dir_my.setDir(fm.localDir());
}
_self->cryptFiles(data.toStringList());
break;
default: break; default: break;
}; };
//piCout << remote_tile << type << data; //piCout << remote_tile << type << data;
@@ -502,7 +532,6 @@ void Daemon::peerConnected(const PIString & p_name) {
CONNECTU(r, receiveFinished, this, filesReceived) CONNECTU(r, receiveFinished, this, filesReceived)
CONNECTU(r, receiveFinished, this, closeFileDialog) CONNECTU(r, receiveFinished, this, closeFileDialog)
CONNECTU(r, sendFinished, this, closeFileDialog) CONNECTU(r, sendFinished, this, closeFileDialog)
CONNECTU(r, removeFinished, this, filesRemoved)
CONNECTU(r, changeDirFinished, this, dirChanged) CONNECTU(r, changeDirFinished, this, dirChanged)
PIMutexLocker ml2(remote_mutex); PIMutexLocker ml2(remote_mutex);
remotes.insert(p_name, r); remotes.insert(p_name, r);
@@ -535,15 +564,13 @@ void Daemon::filesReceived(const PIString & p_name, bool ok) {
void Daemon::dirChanged(const PIString & p_name, const PIString & dir) { void Daemon::dirChanged(const PIString & p_name, const PIString & dir) {
PIMutexLocker ml(remote_mutex); if (p_name == self_name) {
Remote * r = remotes.value(p_name, 0); fm.clearSelectionLocal();
if (!r) return; fm.clearSelectionRemote();
if (r->dir_my.absolutePath() != dir) return; fm.updateLocalDir();
sendDirToRemote(r); fm.updateRemoteDir();
} return;
}
void Daemon::filesRemoved(const PIString & p_name, const PIString & dir) {
PIMutexLocker ml(remote_mutex); PIMutexLocker ml(remote_mutex);
Remote * r = remotes.value(p_name, 0); Remote * r = remotes.value(p_name, 0);
if (!r) return; if (!r) return;
@@ -652,6 +679,15 @@ void Daemon::dataReceived(const PIString & from, const PIByteArray & data) {
case FileTransfer: case FileTransfer:
if (r) r->received(ba); if (r) r->received(ba);
break; break;
case CryptFiles:
if (!r) return;
if (r->isRunning()) return;
{
PIStringList files;
ba >> files;
r->cryptFiles(files);
}
break;
}; };
if (!rba.isEmpty()) send(from, rba); if (!rba.isEmpty()) send(from, rba);
} }

View File

@@ -71,6 +71,7 @@ private:
CopyFiles, CopyFiles,
RemoveFiles, RemoveFiles,
MkDir, MkDir,
CryptFiles,
FileTransfer = 30 FileTransfer = 30
@@ -85,6 +86,7 @@ private:
void removeFiles(const PIStringList & fl) {startAction(Daemon::RemoveFiles, PIString(), fl);} void removeFiles(const PIStringList & fl) {startAction(Daemon::RemoveFiles, PIString(), fl);}
void updateDir() {startAction(Daemon::RequestChangeDir, PIString(), PIStringList());} void updateDir() {startAction(Daemon::RequestChangeDir, PIString(), PIStringList());}
void makeDir(const PIString & dir) {startAction(Daemon::MkDir, dir, PIStringList() << "");} void makeDir(const PIString & dir) {startAction(Daemon::MkDir, dir, PIStringList() << "");}
void cryptFiles(const PIStringList & fl) {startAction(Daemon::CryptFiles, PIString(), fl);}
EVENT_HANDLER1(void, ftSendRequest, PIByteArray &, data) {PIByteArray h; h << int(FileTransfer); data.insert(0, h); sendRequest(name(), data);} EVENT_HANDLER1(void, ftSendRequest, PIByteArray &, data) {PIByteArray h; h << int(FileTransfer); data.insert(0, h); sendRequest(name(), data);}
EVENT_HANDLER1(void, ftReceived, bool, ok) {receiveFinished(name(), ok);} EVENT_HANDLER1(void, ftReceived, bool, ok) {receiveFinished(name(), ok);}
EVENT_HANDLER1(void, ftSended, bool, ok) {sendFinished(name(), ok);} EVENT_HANDLER1(void, ftSended, bool, ok) {sendFinished(name(), ok);}
@@ -92,7 +94,6 @@ private:
EVENT2(sendRequest, const PIString &, p_name, const PIByteArray &, data) EVENT2(sendRequest, const PIString &, p_name, const PIByteArray &, data)
EVENT2(receiveFinished, const PIString & , p_name, bool, ok) EVENT2(receiveFinished, const PIString & , p_name, bool, ok)
EVENT2(sendFinished, const PIString & , p_name, bool, ok) EVENT2(sendFinished, const PIString & , p_name, bool, ok)
EVENT2(removeFinished, const PIString & , p_name, const PIString & , dir)
EVENT2(changeDirFinished, const PIString & , p_name, const PIString & , dir) EVENT2(changeDirFinished, const PIString & , p_name, const PIString & , dir)
EVENT_HANDLER1(void, received, PIByteArray & , data) {ft.received(data);} EVENT_HANDLER1(void, received, PIByteArray & , data) {ft.received(data);}
@@ -135,7 +136,6 @@ private:
EVENT_HANDLER3(void, fmActionRequest, bool, remote_tile, FileManager::Action, type, PIVariant, data); EVENT_HANDLER3(void, fmActionRequest, bool, remote_tile, FileManager::Action, type, PIVariant, data);
EVENT_HANDLER2(void, timerEvent, void * , _d, int, delim); EVENT_HANDLER2(void, timerEvent, void * , _d, int, delim);
EVENT_HANDLER2(void, filesReceived, const PIString & , p_name, bool, ok); EVENT_HANDLER2(void, filesReceived, const PIString & , p_name, bool, ok);
EVENT_HANDLER2(void, filesRemoved, const PIString & , p_name, const PIString & , dir);
EVENT_HANDLER2(void, dirChanged, const PIString & , p_name, const PIString & , dir); EVENT_HANDLER2(void, dirChanged, const PIString & , p_name, const PIString & , dir);
EVENT_HANDLER2(void, closeFileDialog, const PIString & , p_name, bool, ok); EVENT_HANDLER2(void, closeFileDialog, const PIString & , p_name, bool, ok);
EVENT_HANDLER2(void, localSend, const PIString & , p_name, const PIByteArray &, data); EVENT_HANDLER2(void, localSend, const PIString & , p_name, const PIByteArray &, data);

View File

@@ -40,7 +40,12 @@ bool FileManager::TileDir::keyEvent(PIKbdListener::KeyEvent key) {
break; break;
case PIKbdListener::F6: case PIKbdListener::F6:
if (key.modifiers[PIKbdListener::Shift]) { if (key.modifiers[PIKbdListener::Shift]) {
askQuestion("Crypt selected files?"); if (selected.isEmpty())
selected << cur;
if (!askQuestion("Crypt selected files?")) return true;
setFocus();
if (remote_mode) actionRequest(is_right, Crypt, selectedNames());
else actionRequest(is_right, LocalCrypt, selectedNames());
} }
break; break;
case PIKbdListener::F7: case PIKbdListener::F7:

View File

@@ -15,7 +15,7 @@ public:
PIScreenTile * localTile() const {return panels[0];} PIScreenTile * localTile() const {return panels[0];}
PIScreenTile * remoteTile() const {return panels[1];} PIScreenTile * remoteTile() const {return panels[1];}
enum Action {MkDir, Remove, Copy, Move, LocalCopy}; enum Action {MkDir, Remove, Copy, Move, LocalCopy, Crypt, LocalCrypt};
void setLocal(); void setLocal();
void setRemote(); void setRemote();

View File

@@ -1,4 +1,5 @@
#include "shared.h" #include "shared.h"
#include "picrypt.h"
extern PIScreen screen; extern PIScreen screen;
@@ -118,7 +119,7 @@ void showInfo(const PIString & t) {
void removeFiles(const PIDir & dir, PIStringList l) { void removeFiles(const PIDir & dir, PIStringList l) {
l.removeOne(".."); l.removeAll("..");
PIString ap = dir.absolutePath(); PIString ap = dir.absolutePath();
//piCout << "remove from" << ap; //piCout << "remove from" << ap;
piForeachC (PIString & s, l) { piForeachC (PIString & s, l) {
@@ -134,3 +135,42 @@ void removeFiles(const PIDir & dir, PIStringList l) {
PIFile::remove(fi.path); PIFile::remove(fi.path);
} }
} }
bool cryptFiles(const PIDir & dir, PIStringList l, const PIByteArray & secret) {
if (secret.size() != PICrypt::sizeKey() || secret.isEmpty()) return false;
l.removeAll("..");
PIString ap = dir.absolutePath();
piForeachC (PIString & s, l) {
PIFile::FileInfo fi = PIFile::fileInfo(ap + PIDir::separator + s);
if (fi.isDir()) {
PIVector<PIFile::FileInfo> el = PIDir::allEntries(fi.path);
piForeachCR (PIFile::FileInfo & e, el) {
if (e.size != 0)
cryptFile(e.path, secret);
}
}
if (fi.size != 0)
cryptFile(fi.path, secret);
}
return false;
}
bool cryptFile(const PIString & path, const PIByteArray & secret){
PIFile inf;
PIByteArray ba;
PICrypt crypt;
if (!crypt.setKey(secret)) return false;
if (!inf.open(path, PIIODevice::ReadOnly)) return false;
ba = inf.readAll();
ba = crypt.crypt(ba);
if (ba.isEmpty()) return false;
PIFile outf;
if (!outf.open(path + ".crypt", PIIODevice::ReadWrite)) return false;
outf.resize(0);
outf.write(ba);
outf.close();
return true;
}

View File

@@ -15,5 +15,7 @@ PIString askUserInput(const PIString &desc);
bool askQuestion(const PIString & t); bool askQuestion(const PIString & t);
void showInfo(const PIString & t); void showInfo(const PIString & t);
void removeFiles(const PIDir & dir, PIStringList l); void removeFiles(const PIDir & dir, PIStringList l);
bool cryptFiles(const PIDir & dir, PIStringList l, const PIByteArray & secret);
bool cryptFile(const PIString & path, const PIByteArray & secret);
#endif // SHARED_H #endif // SHARED_H