1
0
mirror of https://github.com/craigerl/aprsd.git synced 2024-11-25 17:38:44 -05:00

Merge pull request #5 from hemna/master

Added reading of a config file
This commit is contained in:
Craig Lamparter 2018-11-28 10:09:37 -08:00 committed by GitHub
commit 4c8d9c3b2c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 49 additions and 2 deletions

View File

@ -30,9 +30,14 @@ email server, and associated logins, passwords. search for "yourdomain",
"password". Search for "shortcuts" to setup email aliases as well. "password". Search for "shortcuts" to setup email aliases as well.
Installation:
```
pip install aprsd
```
Example usage: Example usage:
``` ```
./aprsd.py aprsd -h
``` ```
Example output: Example output:

View File

@ -43,7 +43,7 @@ import pprint
from imapclient import IMAPClient, SEEN from imapclient import IMAPClient, SEEN
# local imports here # local imports here
from fuzzyclock import fuzzy from aprsd.fuzzyclock import fuzzy
import utils import utils
# localization, please edit: # localization, please edit:
@ -107,6 +107,14 @@ else:
BASECALLSIGN = args.callsign BASECALLSIGN = args.callsign
# Now read the ~/.aprds/config.yml
config = utils.get_config()
if 'shortcuts' in config:
shortcuts = config['shortcuts']
else:
print("missing 'shortcuts' section of config.yml")
sys.exit(-1)
try: try:
tn = telnetlib.Telnet(HOST, 14580) tn = telnetlib.Telnet(HOST, 14580)
except Exception, e: except Exception, e:

View File

@ -3,7 +3,27 @@
import os import os
import pprint import pprint
import sys import sys
import yaml
# an example of what should be in the ~/.aprsd/config.yml
example_config = '''
shortcuts:
'aa': '5551239999@vtext.com'
'cl': 'craiglamparter@somedomain.org'
'wb': '555309@vtext.com'
smtp:
login: something
password: some lame password
imap:
login: imapuser
password: something dumb
ham:
callsign: something
basename: somebasename
'''
def env(*vars, **kwargs): def env(*vars, **kwargs):
"""This returns the first environment variable set. """This returns the first environment variable set.
@ -14,3 +34,16 @@ def env(*vars, **kwargs):
if value: if value:
return value return value
return kwargs.get('default', '') return kwargs.get('default', '')
def get_config():
"""This tries to read the yaml config from ~/.aprsd/config.yml."""
config_file = os.path.expanduser("~/.aprsd/config.yml")
if os.path.exists(config_file):
with open(config_file, "r") as stream:
config = yaml.load(stream)
return config
else:
print("%s is missing, please create a config file" % config_file)
print("example config is\n %s" % example_config)
sys.exit(-1)

View File

@ -1,2 +1,3 @@
pbr pbr
imapclient imapclient
pyyaml