add email
This commit is contained in:
		
							parent
							
								
									0d82f375c3
								
							
						
					
					
						commit
						c864f7fdde
					
				| @ -158,6 +158,10 @@ def build_config(_config_file): | |||||||
|                     'IGATE_BEACON_COMMENT': config.get(section, 'IGATE_BEACON_COMMENT'), |                     'IGATE_BEACON_COMMENT': config.get(section, 'IGATE_BEACON_COMMENT'), | ||||||
|                     'IGATE_LATITUDE': config.get(section, 'IGATE_LATITUDE'), |                     'IGATE_LATITUDE': config.get(section, 'IGATE_LATITUDE'), | ||||||
|                     'IGATE_LONGITUDE': config.get(section, 'IGATE_LONGITUDE'), |                     'IGATE_LONGITUDE': config.get(section, 'IGATE_LONGITUDE'), | ||||||
|  |                     'EMAIL_SENDER': config.get(section, 'EMAIL_SENDER'), | ||||||
|  |                     'EMAIL_PASSWORD': config.get(section, 'EMAIL_PASSWORD'), | ||||||
|  |                     'SMTP_SERVER': config.get(section, 'SMTP_SERVER'), | ||||||
|  |                     'SMTP_PORT': config.get(section, 'SMTP_PORT'), | ||||||
| 
 | 
 | ||||||
|                 }) |                 }) | ||||||
|                 if not CONFIG['LOGGER']['LOG_FILE']: |                 if not CONFIG['LOGGER']['LOG_FILE']: | ||||||
|  | |||||||
| @ -132,6 +132,13 @@ IGATE_BEACON_ICON = /I | |||||||
| IGATE_LATITUDE = 0000.00N | IGATE_LATITUDE = 0000.00N | ||||||
| IGATE_LONGITUDE = 00000.00W | IGATE_LONGITUDE = 00000.00W | ||||||
| 
 | 
 | ||||||
|  | # The email gateway settingns below are OPTIONAL. They are NOT REQUIRED if you don't want | ||||||
|  | # to enable the email gateway. Leave as is to disable. | ||||||
|  | EMAIL_SENDER: test@example.org | ||||||
|  | EMAIL_PASSWORD: letmein | ||||||
|  | SMTP_SERVER: smtp.gmail.com | ||||||
|  | SMTP_PORT: 465 | ||||||
|  | 
 | ||||||
| # OPENBRIDGE INSTANCES - DUPLICATE SECTION FOR MULTIPLE CONNECTIONS | # OPENBRIDGE INSTANCES - DUPLICATE SECTION FOR MULTIPLE CONNECTIONS | ||||||
| # OpenBridge is a protocol originall created by DMR+ for connection between an | # OpenBridge is a protocol originall created by DMR+ for connection between an | ||||||
| # IPSC2 server and Brandmeister. It has been implemented here at the suggestion | # IPSC2 server and Brandmeister. It has been implemented here at the suggestion | ||||||
|  | |||||||
							
								
								
									
										31
									
								
								gps_data.py
									
									
									
									
									
								
							
							
						
						
									
										31
									
								
								gps_data.py
									
									
									
									
									
								
							| @ -67,7 +67,15 @@ import os | |||||||
| from gps_functions import cmd_list | from gps_functions import cmd_list | ||||||
| 
 | 
 | ||||||
| # Module for maidenhead grids | # Module for maidenhead grids | ||||||
|  | try: | ||||||
|     import maidenhead as mh |     import maidenhead as mh | ||||||
|  | except: | ||||||
|  |     logger.info('Error importing maidenhead module, make sure it is installed.') | ||||||
|  | # Module for sending email | ||||||
|  | try: | ||||||
|  |     import smtplib | ||||||
|  | except: | ||||||
|  |     logger.info('Error importing smtplib module, make sure it is installed.') | ||||||
| 
 | 
 | ||||||
| #Modules for APRS settings | #Modules for APRS settings | ||||||
| import ast | import ast | ||||||
| @ -162,6 +170,16 @@ def dashboard_bb_write(call, dmr_id, time, bulletin): | |||||||
|     logger.info('User bulletin entry saved.') |     logger.info('User bulletin entry saved.') | ||||||
|     #logger.info(dash_bb) |     #logger.info(dash_bb) | ||||||
| 
 | 
 | ||||||
|  | # Send email via SMTP function | ||||||
|  | def send_email(to_email, email_subject, email_message): | ||||||
|  |     global smtp_server | ||||||
|  |     sender_address = email_sender | ||||||
|  |     account_password = email_password | ||||||
|  |     smtp_server = smtplib.SMTP_SSL(smtp_server, int(smtp_port)) | ||||||
|  |     smtp_server.login(sender_address, account_password) | ||||||
|  |     message = "From: " + aprs_callsign + " D-APRS Gateway\nTo: " + to_email + "\nContent-type: text/html\nSubject: " + email_subject + "\n\n" + '<strong>' + email_subject + '</strong><p> </p><h3>' + email_message + '</h3><p> </p><p>This message was sent to you from a D-APRS gateway operated by <strong>' + aprs_callsign + '</strong>. Do not reply as this gateway is only one way at this time.</p>' | ||||||
|  |     smtp_server.sendmail(sender_address, to_email, message) | ||||||
|  |     smtp_server.close() | ||||||
| 
 | 
 | ||||||
| # Thanks for this forum post for this - https://stackoverflow.com/questions/2579535/convert-dd-decimal-degrees-to-dms-degrees-minutes-seconds-in-python | # Thanks for this forum post for this - https://stackoverflow.com/questions/2579535/convert-dd-decimal-degrees-to-dms-degrees-minutes-seconds-in-python | ||||||
| 
 | 
 | ||||||
| @ -241,6 +259,14 @@ def process_sms(_rf_src, sms): | |||||||
|         user_setting_write(int_id(_rf_src), re.sub(' .*|@','',sms), re.sub('@COM |@COM','',sms)) |         user_setting_write(int_id(_rf_src), re.sub(' .*|@','',sms), re.sub('@COM |@COM','',sms)) | ||||||
|     elif '@BB' in sms: |     elif '@BB' in sms: | ||||||
|         dashboard_bb_write(get_alias(int_id(_rf_src), subscriber_ids), int_id(_rf_src), time.strftime('%H:%M:%S - %m/%d/%y'), re.sub('@BB|@BB ','',sms)) |         dashboard_bb_write(get_alias(int_id(_rf_src), subscriber_ids), int_id(_rf_src), time.strftime('%H:%M:%S - %m/%d/%y'), re.sub('@BB|@BB ','',sms)) | ||||||
|  |     elif '@@' and 'E-' in sms: | ||||||
|  |         to_email = re.sub('@@| .*', '', sms) | ||||||
|  |         email_message = re.sub('@@.*@.*E-', '', sms) | ||||||
|  |         email_subject = 'New message from ' + str(get_alias(int_id(_rf_src), subscriber_ids)) | ||||||
|  |         logger.info(to_email) | ||||||
|  |         logger.info(email_message) | ||||||
|  |         logger.info(email_subject) | ||||||
|  |         send_email(to_email, email_subject, email_message) | ||||||
|     elif '@MH' in sms: |     elif '@MH' in sms: | ||||||
|         grid_square = re.sub('@MH ', '', sms) |         grid_square = re.sub('@MH ', '', sms) | ||||||
|         if len(grid_square) < 6: |         if len(grid_square) < 6: | ||||||
| @ -615,6 +641,11 @@ if __name__ == '__main__': | |||||||
|     aprs_port = int(CONFIG['GPS_DATA']['APRS_PORT']) |     aprs_port = int(CONFIG['GPS_DATA']['APRS_PORT']) | ||||||
|     user_ssid = CONFIG['GPS_DATA']['USER_APRS_SSID'] |     user_ssid = CONFIG['GPS_DATA']['USER_APRS_SSID'] | ||||||
|     aprs_comment = CONFIG['GPS_DATA']['USER_APRS_COMMENT'] |     aprs_comment = CONFIG['GPS_DATA']['USER_APRS_COMMENT'] | ||||||
|  |     # EMAIL variables | ||||||
|  |     email_sender = CONFIG['GPS_DATA']['EMAIL_SENDER'] | ||||||
|  |     email_password = CONFIG['GPS_DATA']['EMAIL_PASSWORD'] | ||||||
|  |     smtp_server = CONFIG['GPS_DATA']['SMTP_SERVER'] | ||||||
|  |     smtp_port = CONFIG['GPS_DATA']['SMTP_PORT'] | ||||||
|      |      | ||||||
|     # Start the system logger |     # Start the system logger | ||||||
|     if cli_args.LOG_LEVEL: |     if cli_args.LOG_LEVEL: | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user