hopefully fixed ci, mostly completed contactmanager.py
parent
47d5099e4d
commit
842a6e1edb
|
@ -87,3 +87,8 @@ class DiskAllocationReached(Exception):
|
||||||
|
|
||||||
class MissingAddress(Exception):
|
class MissingAddress(Exception):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
# Contact exceptions
|
||||||
|
|
||||||
|
class ContactDeleted(Exception):
|
||||||
|
pass
|
|
@ -17,16 +17,20 @@
|
||||||
You should have received a copy of the GNU General Public License
|
You should have received a copy of the GNU General Public License
|
||||||
along with this program. If not, see <https://www.gnu.org/licenses/>.
|
along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
'''
|
'''
|
||||||
import os, json
|
import os, json, onionrexceptions
|
||||||
from onionrusers import onionrusers
|
from onionrusers import onionrusers
|
||||||
|
|
||||||
class ContactManager(onionrusers.OnionrUser):
|
class ContactManager(onionrusers.OnionrUser):
|
||||||
def __init__(self, coreInst, publicKey, saveUser=False):
|
def __init__(self, coreInst, publicKey, saveUser=False, recordExpireSeconds=5):
|
||||||
super(ContactManager, self).__init__(coreInst, publicKey, saveUser=saveUser)
|
super(ContactManager, self).__init__(coreInst, publicKey, saveUser=saveUser)
|
||||||
self.data = {}
|
|
||||||
self.dataDir = coreInst.dataDir + '/contacts/'
|
self.dataDir = coreInst.dataDir + '/contacts/'
|
||||||
self.dataFile = coreInst.dataFile = publicKey + '.json'
|
self.dataFile = '%s/contacts/%s.json' % (coreInst.dataDir, publicKey)
|
||||||
if not os.path.exists(self.dataFile):
|
self.lastRead = 0
|
||||||
|
self.recordExpire = recordExpireSeconds
|
||||||
|
self.data = self._loadData()
|
||||||
|
self.deleted = False
|
||||||
|
|
||||||
|
if not os.path.exists(self.dataDir):
|
||||||
os.mkdir(self.dataDir)
|
os.mkdir(self.dataDir)
|
||||||
|
|
||||||
def _writeData(self):
|
def _writeData(self):
|
||||||
|
@ -34,10 +38,35 @@ class ContactManager(onionrusers.OnionrUser):
|
||||||
with open(self.dataFile, 'w') as dataFile:
|
with open(self.dataFile, 'w') as dataFile:
|
||||||
dataFile.write(data)
|
dataFile.write(data)
|
||||||
|
|
||||||
def set_info(self, key, value):
|
def _loadData(self):
|
||||||
return
|
self.lastRead = self._core._utils.getEpoch()
|
||||||
def add_contact(self):
|
retData = {}
|
||||||
return
|
if os.path.exists(self.dataFile):
|
||||||
def delete_contact(self):
|
with open(self.dataFile, 'r') as dataFile:
|
||||||
|
retData = json.loads(dataFile.read())
|
||||||
|
return retData
|
||||||
|
|
||||||
|
def set_info(self, key, value, autoWrite=True):
|
||||||
|
if self.deleted:
|
||||||
|
raise onionrexceptions.ContactDeleted
|
||||||
|
|
||||||
|
self.data[key] = value
|
||||||
|
if autoWrite:
|
||||||
|
self._writeData()
|
||||||
return
|
return
|
||||||
|
|
||||||
|
def get_info(self, key, forceReload=False):
|
||||||
|
if self.deleted:
|
||||||
|
raise onionrexceptions.ContactDeleted
|
||||||
|
|
||||||
|
if (self._core._utils.getEpoch() - self.lastRead >= self.recordExpire) or forceReload:
|
||||||
|
self.data = self._loadData()
|
||||||
|
try:
|
||||||
|
return self.data[key]
|
||||||
|
except KeyError:
|
||||||
|
return None
|
||||||
|
|
||||||
|
def delete_contact(self):
|
||||||
|
self.deleted = True
|
||||||
|
if os.path.exists(self.dataFile):
|
||||||
|
os.remove(self.dataFile)
|
|
@ -2,8 +2,15 @@
|
||||||
cd onionr;
|
cd onionr;
|
||||||
mkdir testdata;
|
mkdir testdata;
|
||||||
ran=0
|
ran=0
|
||||||
|
|
||||||
|
|
||||||
|
close () {
|
||||||
|
rm -rf testdata;
|
||||||
|
exit 10;
|
||||||
|
}
|
||||||
|
|
||||||
for f in tests/*.py; do
|
for f in tests/*.py; do
|
||||||
python3 "$f" || break # if needed
|
python3 "$f" || close # if needed
|
||||||
let "ran++"
|
let "ran++"
|
||||||
done
|
done
|
||||||
rm -rf testdata;
|
rm -rf testdata;
|
||||||
|
|
Loading…
Reference in New Issue