add initial public pi-star script, clean map page
This commit is contained in:
		
							parent
							
								
									3692621c6d
								
							
						
					
					
						commit
						2269b57b5c
					
				
							
								
								
									
										261
									
								
								web/app.py
									
									
									
									
									
								
							
							
						
						
									
										261
									
								
								web/app.py
									
									
									
									
									
								
							| @ -42,10 +42,7 @@ from socket import gethostbyname | |||||||
| import re | import re | ||||||
| import folium | import folium | ||||||
| 
 | 
 | ||||||
| try: | from gen_script_template import gen_script | ||||||
|     from gen_script_template import gen_script |  | ||||||
| except: |  | ||||||
|     pass |  | ||||||
| 
 | 
 | ||||||
| import os, ast | import os, ast | ||||||
| ##import hb_config | ##import hb_config | ||||||
| @ -702,7 +699,7 @@ def create_app(): | |||||||
|     @app.route('/map') |     @app.route('/map') | ||||||
|     @login_required |     @login_required | ||||||
|     def map_page(): |     def map_page(): | ||||||
|         f_map = folium.Map(location=[45.372, -121.6972], zoom_start=7) |         f_map = folium.Map(location=center_map, zoom_start=map_zoom) | ||||||
| ##        folium.Marker([45.372, -121.6972], popup="hello", icon=folium.Icon(color="red", icon="record"), tooltip='hi').add_to(f_map) | ##        folium.Marker([45.372, -121.6972], popup="hello", icon=folium.Icon(color="red", icon="record"), tooltip='hi').add_to(f_map) | ||||||
|         for l in peer_locations.items(): |         for l in peer_locations.items(): | ||||||
|             folium.Marker([float(l[1][1]), float(l[1][2])], popup=''' |             folium.Marker([float(l[1][1]), float(l[1][2])], popup=''' | ||||||
| @ -723,7 +720,7 @@ def create_app(): | |||||||
|          ''', icon=folium.Icon(color="red", icon="record"), tooltip='<strong>' + l[1][0] + '</strong>').add_to(f_map) |          ''', icon=folium.Icon(color="red", icon="record"), tooltip='<strong>' + l[1][0] + '</strong>').add_to(f_map) | ||||||
|         content = f_map._repr_html_() |         content = f_map._repr_html_() | ||||||
|         |         | ||||||
|         return render_template('flask_user_layout.html', markup_content = Markup(content)) |         return render_template('map.html', markup_content = Markup(content)) | ||||||
|      |      | ||||||
|     @app.route('/help') |     @app.route('/help') | ||||||
|     def help_page(): |     def help_page(): | ||||||
| @ -734,50 +731,30 @@ def create_app(): | |||||||
|     def gen_pi_star(): |     def gen_pi_star(): | ||||||
|         try: |         try: | ||||||
|             u = current_user |             u = current_user | ||||||
|     ##        print(u.username) |  | ||||||
|             id_dict = ast.literal_eval(u.dmr_ids) |             id_dict = ast.literal_eval(u.dmr_ids) | ||||||
|             #u = User.query.filter_by(username=user).first() |             #u = User.query.filter_by(username=user).first() | ||||||
|     ##        print(user_id) |  | ||||||
|     ##        print(request.args.get('mode')) |     ##        print(request.args.get('mode')) | ||||||
|     ##        if request.args.get('mode') == 'generated': |     ##        if request.args.get('mode') == 'generated': | ||||||
|             content = ''' |             content = '' | ||||||
| <table style="width: 800px; margin-left: auto; margin-right: auto;" border="1"> |  | ||||||
| <tbody> |  | ||||||
| <tr> |  | ||||||
| <td> |  | ||||||
| <h2 style="text-align: center;"><strong>Pi-Star Instructions</strong></h2> |  | ||||||
| <p> </p> |  | ||||||
| <p><strong>1</strong>: Log into your Pi-Star device. <br /><strong>2</strong>: Change to Read-Write mode of the device by issuing the command:<u></u></p> |  | ||||||
| <pre><u><strong>rpi-rw</strong></u></pre> |  | ||||||
| <p><strong><br />3a: Change to the root user by issuing the command:<u></u></strong></p> |  | ||||||
| <pre>sudo su -</pre> |  | ||||||
| <p><strong><u></u> <br />3b: Now type <u>pwd</u> and verify you get a return indicating you are in the /root directory. If you are in the wrong directory, it is because you're not following the instructions and syntax above! This is a show stopper, and your attempt to load the files correctly, will fail !<br /><br />4: Issue one of the commands below for the chosen DMR ID:</strong></p> |  | ||||||
| <p>Note: Link can be used only once. To run the script again, simply reload the page and paste a new command into the command line.</p> |  | ||||||
| 
 |  | ||||||
| ''' |  | ||||||
|             for i in id_dict.items(): |             for i in id_dict.items(): | ||||||
|                 #if i[1] == '': |                 #if i[1] == '': | ||||||
|                 link_num = str(random.randint(1,99999999)).zfill(8) + str(time.time()) + str(random.randint(1,99999999)).zfill(8) |                 link_num = str(random.randint(1,99999999)).zfill(8) + str(time.time()) + str(random.randint(1,99999999)).zfill(8) | ||||||
|                 script_links[i[0]] = link_num |                 script_links[i[0]] = link_num | ||||||
|                 content = content + '''\n |                 content = content + ''' | ||||||
|         <p style="text-align: center;">DMR ID: <strong>''' + str(i[0]) + '''</strong>:</p> |         <div class="panel panel-default"> | ||||||
|         <p style="text-align: center;"><strong><pre>bash <(curl -s "<a href="''' + str(url) + '/get_script?dmr_id=' + str(i[0]) + '&number=' + str(link_num) + '''">''' + str(url) + '/get_script?dmr_id=' + str(i[0]) + '&number=' + str(link_num) + '''</a>")</pre></strong></p> |   <div class="panel-heading" style="text-align: center;"><h4>ID: ''' + str(i[0]) + '''</h4></div> | ||||||
|         <p> </p> |   <div class="panel-body"><pre>rpi-rw; wget -O /root/auto_pistar.py "<a href="''' + str(url) + '/get_script?dmr_id=' + str(i[0]) + '&number=' + str(link_num) + '''">''' + str(url) + '/get_script?dmr_id=' + str(i[0]) + '&number=' + str(link_num) + '''</a>"; chmod +x /root/auto_pistar.py; python3 /root/auto_pistar.py; pistar-update</pre></div> | ||||||
|  | </div> | ||||||
|     ''' |     ''' | ||||||
|                 #else: |                 #else: | ||||||
|                 #    content = content + '''\n<p style="text-align: center;">Error</p>''' |                 #    content = content + '''\n<p style="text-align: center;">Error</p>''' | ||||||
|             content = content + '''\n<p><strong> <br />5: When asked for server ports, use the information above to populate the correct fields. <br />6: Reboot your Pi-Star device</strong></p> |              | ||||||
| </td> |  | ||||||
| </tr> |  | ||||||
| </tbody> |  | ||||||
| </table> |  | ||||||
| <p> </p>''' |  | ||||||
|         except: |         except: | ||||||
|             content = Markup('<strong>No DMR IDs found or other error.</strong>') |             content = Markup('<strong>No DMR IDs found or other error.</strong>') | ||||||
|          |          | ||||||
|              |              | ||||||
|         #return str(content) |         #return str(content) | ||||||
|         return render_template('flask_user_layout.html', markup_content = Markup(content)) |         return render_template('pi-star_gen.html', markup_content = Markup(content)) | ||||||
|          |          | ||||||
| 
 | 
 | ||||||
|      |      | ||||||
| @ -829,16 +806,11 @@ def create_app(): | |||||||
| 
 | 
 | ||||||
| ''' | ''' | ||||||
|         try: |         try: | ||||||
|             #content = Markup('<strong>The HTML String</strong>') |  | ||||||
|             #user_id = request.args.get('user_id') |             #user_id = request.args.get('user_id') | ||||||
|             u = current_user |             u = current_user | ||||||
|     ##        print(u.username) |  | ||||||
|             id_dict = ast.literal_eval(u.dmr_ids) |             id_dict = ast.literal_eval(u.dmr_ids) | ||||||
|             #u = User.query.filter_by(username=user).first() |             #u = User.query.filter_by(username=user).first() | ||||||
|     ##        print(user_id) |  | ||||||
|     ##        print(request.args.get('mode')) |  | ||||||
|     ##        if request.args.get('mode') == 'generated': |     ##        if request.args.get('mode') == 'generated': | ||||||
|             #print(id_dict) |  | ||||||
|            |            | ||||||
|             content = '\n' |             content = '\n' | ||||||
|             for i in id_dict.items(): |             for i in id_dict.items(): | ||||||
| @ -1342,6 +1314,11 @@ def create_app(): | |||||||
|         number = float(request.args.get('number')) |         number = float(request.args.get('number')) | ||||||
|         #print(type(script_links[dmr_id])) |         #print(type(script_links[dmr_id])) | ||||||
|         u = User.query.filter(User.dmr_ids.contains(request.args.get('dmr_id'))).first() |         u = User.query.filter(User.dmr_ids.contains(request.args.get('dmr_id'))).first() | ||||||
|  | 
 | ||||||
|  |         pub_list = [] | ||||||
|  |          | ||||||
|  | 
 | ||||||
|  |          | ||||||
|         #print(u.dmr_ids) |         #print(u.dmr_ids) | ||||||
| 
 | 
 | ||||||
|         if authorized_peer(dmr_id)[1] == 0: |         if authorized_peer(dmr_id)[1] == 0: | ||||||
| @ -1350,13 +1327,29 @@ def create_app(): | |||||||
|             passphrase = gen_passphrase(dmr_id) |             passphrase = gen_passphrase(dmr_id) | ||||||
|         elif authorized_peer(dmr_id)[1] == '': |         elif authorized_peer(dmr_id)[1] == '': | ||||||
|             passphrase = legacy_passphrase |             passphrase = legacy_passphrase | ||||||
|             print(passphrase) |  | ||||||
|         elif authorized_peer(dmr_id)[1] != '' or authorized_peer(dmr_id)[1] != 0: |         elif authorized_peer(dmr_id)[1] != '' or authorized_peer(dmr_id)[1] != 0: | ||||||
|             passphrase = authorized_peer(dmr_id)[1] |             passphrase = authorized_peer(dmr_id)[1] | ||||||
|         #try: |         #try: | ||||||
|         if dmr_id in script_links and number == float(script_links[dmr_id]): |         if dmr_id in script_links and number == float(script_links[dmr_id]): | ||||||
|             script_links.pop(dmr_id) |             script_links.pop(dmr_id) | ||||||
|             return str(gen_script(dmr_id, passphrase)) |              | ||||||
|  |             ml = MasterList.query.filter_by(public_list=True).filter_by(active=True).all() | ||||||
|  |             pl = ProxyList.query.filter_by(public_list=True).filter_by(active=True).all() | ||||||
|  | ##            print(ml) | ||||||
|  |             for m in ml: | ||||||
|  | ##                print(m.name) | ||||||
|  | ##                print(m.server) | ||||||
|  | ##                print(m.port) | ||||||
|  | ##                print(m.enable_um) | ||||||
|  | ##                print(m.passphrase) | ||||||
|  |                 sl = ServerList.query.filter_by(name=m.server).first() | ||||||
|  | ##                print(sl.ip) | ||||||
|  |                 if m.enable_um == True: | ||||||
|  |                     passp = passphrase | ||||||
|  |                 pub_list.append([m.server + '_' + m.name, sl.ip, passphrase, m.port]) | ||||||
|  | 
 | ||||||
|  |              | ||||||
|  |             return str(gen_script(dmr_id, pub_list)) | ||||||
|         #except: |         #except: | ||||||
|             #else: |             #else: | ||||||
|             #content = '<strong>Link used or other error.</strong>' |             #content = '<strong>Link used or other error.</strong>' | ||||||
| @ -2196,8 +2189,8 @@ TG #: <strong> ''' + str(tg_d.tg) + '''</strong> | |||||||
| <tr style="height: 18px;"> | <tr style="height: 18px;"> | ||||||
| <td style="text-align: center; height: 18px;"> <h4>Server: <strong>''' + svr.name + '''</strong>  -  IP/Host: <strong>''' + str(svr.ip) + '''</strong></h4></td> | <td style="text-align: center; height: 18px;"> <h4>Server: <strong>''' + svr.name + '''</strong>  -  IP/Host: <strong>''' + str(svr.ip) + '''</strong></h4></td> | ||||||
| </tr> ''' | </tr> ''' | ||||||
|         m_list = MasterList.query.filter_by(server=server).filter_by(public_list=True).all() |         m_list = MasterList.query.filter_by(server=server).filter_by(active=True).filter_by(public_list=True).all() | ||||||
|         p_list = ProxyList.query.filter_by(server=server).filter_by(public_list=True).all() |         p_list = ProxyList.query.filter_by(server=server).filter_by(active=True).filter_by(public_list=True).all() | ||||||
|         tg_list = '' |         tg_list = '' | ||||||
|         for m in m_list: |         for m in m_list: | ||||||
|             br = BridgeRules.query.filter_by(server=server).filter_by(system_name=m.name).all() |             br = BridgeRules.query.filter_by(server=server).filter_by(system_name=m.name).all() | ||||||
| @ -5691,98 +5684,100 @@ TG #: <strong> ''' + str(tg_d.tg) + '''</strong> | |||||||
|     ##                except: |     ##                except: | ||||||
|     ##                    message = jsonify(message='Config error') |     ##                    message = jsonify(message='Config error') | ||||||
|     ##                    response = make_response(message, 401) |     ##                    response = make_response(message, 401) | ||||||
|             elif 'update_tg' in hblink_req: |  | ||||||
|                 if hblink_req['update_tg']: |  | ||||||
|                     print(hblink_req) |  | ||||||
| ##                    print(hblink_req['data'][0]['SYSTEM']) |  | ||||||
|                     if 'on' == hblink_req['mode']: |  | ||||||
| ##                        try: |  | ||||||
|                               if hblink_req['dmr_id'] == 0: |  | ||||||
|                                 print('id 0') |  | ||||||
| ##                                print(active_tgs) |  | ||||||
|                                 for system in active_tgs[hblink_req['update_tg']].items(): |  | ||||||
|     ##                                print(system) |  | ||||||
|     ##                                print('sys') |  | ||||||
|                                     if system[0] == hblink_req['data'][0]['SYSTEM']: |  | ||||||
|                                         print(active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][0]['1']) |  | ||||||
| ##                                        print(hblink_req['data'][2]['tg']) |  | ||||||
|                                         print('---------') |  | ||||||
|                                         print(active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][1]['2']) |  | ||||||
|         ##                                print(hblink_req['data'][1]['ts']) |  | ||||||
|                                         if hblink_req['data'][1]['ts'] == 1: |  | ||||||
|         ####                                  print(active_tgs[hblink_req['update_tg']][system[0]][0]['1']) |  | ||||||
| 
 | 
 | ||||||
|                                             if active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][0]['1'] == hblink_req['data'][2]['tg']: | #################### Work in progress ###########################33 | ||||||
|                                                 pass | ##            elif 'update_tg' in hblink_req: | ||||||
|                                             else: | ##                if hblink_req['update_tg']: | ||||||
|                                                 active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][0]['1'].append(hblink_req['data'][2]['tg']) | ##                    print(hblink_req) | ||||||
|         ####                                    active_tgs[hblink_req['update_tg']][system[0]][0]['1'].append(0) | ####                    print(hblink_req['data'][0]['SYSTEM']) | ||||||
|                                         if hblink_req['data'][1]['ts'] == 2: | ##                    if 'on' == hblink_req['mode']: | ||||||
|                                             if active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][1]['2'] == hblink_req['data'][2]['tg']: | ####                        try: | ||||||
|                                                 pass | ##                              if hblink_req['dmr_id'] == 0: | ||||||
|         ####                                    print(active_tgs[hblink_req['update_tg']][system[0]][1]['2']) | ##                                print('id 0') | ||||||
|                                             else: | ####                                print(active_tgs) | ||||||
|                                                 active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][1]['2'].append(hblink_req['data'][2]['tg']) | ##                                for system in active_tgs[hblink_req['update_tg']].items(): | ||||||
|                               else: | ##    ##                                print(system) | ||||||
|                                   try: | ##    ##                                print('sys') | ||||||
|                                     print('---------on------------') | ##                                    if system[0] == hblink_req['data'][0]['SYSTEM']: | ||||||
|                                     print(hblink_req['data']) | ##                                        print(active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][0]['1']) | ||||||
|                                     print(active_tgs[hblink_req['update_tg']]) | ####                                        print(hblink_req['data'][2]['tg']) | ||||||
|                                     print(hblink_req['data'][2]['ts2']) | ##                                        print('---------') | ||||||
|                                     print('-----------------------') | ##                                        print(active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][1]['2']) | ||||||
|         ##                        active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][2]['SYSTEM'] = hblink_req['data'][0]['SYSTEM'] | ##        ##                                print(hblink_req['data'][1]['ts']) | ||||||
|         ####                        active_tgs[hblink_req['update_tg']][hblink_req['dmr_id']].update({hblink_req['data'][0]['SYSTEM']: [{1:[hblink_req['data'][1]['ts1']]}, {2:[hblink_req['data'][2]['ts2']]}]}) #.update({[hblink_req['dmr_id']]:hblink_req['data']}) | ##                                        if hblink_req['data'][1]['ts'] == 1: | ||||||
|                                     if hblink_req['data'][1]['ts1'] not in active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][0]['1']: | ##        ####                                  print(active_tgs[hblink_req['update_tg']][system[0]][0]['1']) | ||||||
|                                         active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][0]['1'].append(hblink_req['data'][1]['ts1']) | ## | ||||||
|                                         active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][2]['SYSTEM'] = hblink_req['data'][0]['SYSTEM'] | ##                                            if active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][0]['1'] == hblink_req['data'][2]['tg']: | ||||||
|                                     if hblink_req['data'][2]['ts2'] not in active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][1]['2']: | ##                                                pass | ||||||
|                                         print('---0---') | ##                                            else: | ||||||
|                                         print(hblink_req['data'][0]['SYSTEM']) | ##                                                active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][0]['1'].append(hblink_req['data'][2]['tg']) | ||||||
|                                         active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][2]['SYSTEM'] = hblink_req['data'][0]['SYSTEM'] | ##        ####                                    active_tgs[hblink_req['update_tg']][system[0]][0]['1'].append(0) | ||||||
|                                         active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][1]['2'].append(hblink_req['data'][2]['ts2']) | ##                                        if hblink_req['data'][1]['ts'] == 2: | ||||||
| ##                                        print('append') | ##                                            if active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][1]['2'] == hblink_req['data'][2]['tg']: | ||||||
|         ####                                    active_tgs[hblink_req['update_tg']][system[0]][1]['2'].append(0) | ##                                                pass | ||||||
|         ##                        print(hblink_req['data'][0]['SYSTEM']) | ##        ####                                    print(active_tgs[hblink_req['update_tg']][system[0]][1]['2']) | ||||||
| 
 | ##                                            else: | ||||||
|     ##                            print(active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']]) | ##                                                active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][1]['2'].append(hblink_req['data'][2]['tg']) | ||||||
|     ##                            print(active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][2]['2']) | ##                              else: | ||||||
|     ##                            print(hblink_req['data'][1]['ts2']) | ##                                  try: | ||||||
|         ##                        print(active_tgs[hblink_req['update_tg']]) | ##                                    print('---------on------------') | ||||||
|                                   except: | ##                                    print(hblink_req['data']) | ||||||
| ##                                      active_tgs[hblink_req['update_tg']] = {} | ##                                    print(active_tgs[hblink_req['update_tg']]) | ||||||
|                                       pass | ##                                    print(hblink_req['data'][2]['ts2']) | ||||||
|                                  | ##                                    print('-----------------------') | ||||||
| ##                        except: | ##        ##                        active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][2]['SYSTEM'] = hblink_req['data'][0]['SYSTEM'] | ||||||
| ##                            pass | ##        ####                        active_tgs[hblink_req['update_tg']][hblink_req['dmr_id']].update({hblink_req['data'][0]['SYSTEM']: [{1:[hblink_req['data'][1]['ts1']]}, {2:[hblink_req['data'][2]['ts2']]}]}) #.update({[hblink_req['dmr_id']]:hblink_req['data']}) | ||||||
| 
 | ##                                    if hblink_req['data'][1]['ts1'] not in active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][0]['1']: | ||||||
|                              | ##                                        active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][0]['1'].append(hblink_req['data'][1]['ts1']) | ||||||
|                     elif 'off' == hblink_req['mode']: | ##                                        active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][2]['SYSTEM'] = hblink_req['data'][0]['SYSTEM'] | ||||||
|                         print('off') | ##                                    if hblink_req['data'][2]['ts2'] not in active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][1]['2']: | ||||||
|                         for system in active_tgs[hblink_req['update_tg']].items(): | ##                                        print('---0---') | ||||||
|                             print(system) | ##                                        print(hblink_req['data'][0]['SYSTEM']) | ||||||
|                             if system[0] == hblink_req['data'][0]['SYSTEM']: | ##                                        active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][2]['SYSTEM'] = hblink_req['data'][0]['SYSTEM'] | ||||||
|                                 print('yes it is') | ##                                        active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][1]['2'].append(hblink_req['data'][2]['ts2']) | ||||||
| ####                                print(system[0]) | ####                                        print('append') | ||||||
| ####                                print(active_tgs[hblink_req['update_tg']][system[0]]) | ##        ####                                    active_tgs[hblink_req['update_tg']][system[0]][1]['2'].append(0) | ||||||
|                                 if hblink_req['data'][1]['ts'] == 1: | ##        ##                        print(hblink_req['data'][0]['SYSTEM']) | ||||||
| ####                                    print(active_tgs[hblink_req['update_tg']][system[0]][0]['1']) | ## | ||||||
|                                     active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][0]['1'].remove(hblink_req['data'][2]['tg']) | ##    ##                            print(active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']]) | ||||||
| ####                                    active_tgs[hblink_req['update_tg']][system[0]][0]['1'].append(0) | ##    ##                            print(active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][2]['2']) | ||||||
|                                 if hblink_req['data'][1]['ts'] == 2: | ##    ##                            print(hblink_req['data'][1]['ts2']) | ||||||
| ####                                    print(active_tgs[hblink_req['update_tg']][system[0]][1]['2']) | ##        ##                        print(active_tgs[hblink_req['update_tg']]) | ||||||
|                                     active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][1]['2'].remove(hblink_req['data'][2]['tg']) | ##                                  except: | ||||||
| ####                                    active_tgs[hblink_req['update_tg']][system[0]][1]['2'].append(0) | ####                                      active_tgs[hblink_req['update_tg']] = {} | ||||||
| 
 | ##                                      pass | ||||||
|                                      | ##                                 | ||||||
|      | ####                        except: | ||||||
| ##                            print() | ####                            pass | ||||||
| ##                            print(system) | ## | ||||||
| ##                            print(system[1][2]['SYSTEM']) | ##                             | ||||||
|  | ##                    elif 'off' == hblink_req['mode']: | ||||||
| ##                        print('off') | ##                        print('off') | ||||||
| ##                        print(hblink_req['data'][1]['ts']) | ##                        for system in active_tgs[hblink_req['update_tg']].items(): | ||||||
| ##                        print(hblink_req['data'][2]['tg']) | ##                            print(system) | ||||||
|                 print(active_tgs) | ##                            if system[0] == hblink_req['data'][0]['SYSTEM']: | ||||||
|                 response = 'got it' | ##                                print('yes it is') | ||||||
|  | ######                                print(system[0]) | ||||||
|  | ######                                print(active_tgs[hblink_req['update_tg']][system[0]]) | ||||||
|  | ##                                if hblink_req['data'][1]['ts'] == 1: | ||||||
|  | ######                                    print(active_tgs[hblink_req['update_tg']][system[0]][0]['1']) | ||||||
|  | ##                                    active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][0]['1'].remove(hblink_req['data'][2]['tg']) | ||||||
|  | ######                                    active_tgs[hblink_req['update_tg']][system[0]][0]['1'].append(0) | ||||||
|  | ##                                if hblink_req['data'][1]['ts'] == 2: | ||||||
|  | ######                                    print(active_tgs[hblink_req['update_tg']][system[0]][1]['2']) | ||||||
|  | ##                                    active_tgs[hblink_req['update_tg']][hblink_req['data'][0]['SYSTEM']][1]['2'].remove(hblink_req['data'][2]['tg']) | ||||||
|  | ######                                    active_tgs[hblink_req['update_tg']][system[0]][1]['2'].append(0) | ||||||
|  | ## | ||||||
|  | ##                                     | ||||||
|  | ##     | ||||||
|  | ####                            print() | ||||||
|  | ####                            print(system) | ||||||
|  | ####                            print(system[1][2]['SYSTEM']) | ||||||
|  | ####                        print('off') | ||||||
|  | ####                        print(hblink_req['data'][1]['ts']) | ||||||
|  | ####                        print(hblink_req['data'][2]['tg']) | ||||||
|  | ##                print(active_tgs) | ||||||
|  | ##                response = 'got it' | ||||||
|         else: |         else: | ||||||
|             message = jsonify(message='Authentication error') |             message = jsonify(message='Authentication error') | ||||||
|             response = make_response(message, 401) |             response = make_response(message, 401) | ||||||
|  | |||||||
| @ -29,8 +29,12 @@ secret_key = 'SUPER SECRET LONG KEY' | |||||||
| default_account_state = True | default_account_state = True | ||||||
| 
 | 
 | ||||||
| # Legacy passphrase used in hblink.cfg | # Legacy passphrase used in hblink.cfg | ||||||
| #legacy_passphrase = 'passw0rd' | legacy_passphrase = 'passw0rd' | ||||||
| 
 | 
 | ||||||
|  | # Coordinates to center map over | ||||||
|  | center_map = [45.372, -121.6972] | ||||||
|  | # Default map zoom level | ||||||
|  | map_zoom = 5 | ||||||
| 
 | 
 | ||||||
| # Passphrase calculation config. If REMOTE_CONFIG is not used in your DMR server config | # Passphrase calculation config. If REMOTE_CONFIG is not used in your DMR server config | ||||||
| # (hblink.cfg), then the values in section [USER_MANAGER] MUST match the values below. | # (hblink.cfg), then the values in section [USER_MANAGER] MUST match the values below. | ||||||
|  | |||||||
							
								
								
									
										43
									
								
								web/gen_script_template.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								web/gen_script_template.py
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,43 @@ | |||||||
|  | # Function to generate a script for Pi-Star that adds MASTER instances and generated passphrases to DMR_Hosts.txt. | ||||||
|  | 
 | ||||||
|  | def gen_script(dmr_id, svr_lst): | ||||||
|  |     auth_contents = '' | ||||||
|  |     header = ''' | ||||||
|  | ## DMR_hosts.txt, generated by HBNet. | ||||||
|  | 
 | ||||||
|  | ######################################################################################################## | ||||||
|  | ### Name				DMR-ID	IP/Hostname				Password	Port # | ||||||
|  | ######################################################################################################## | ||||||
|  | \n''' | ||||||
|  |     for i in svr_lst: | ||||||
|  | ##        print(i[1]) | ||||||
|  |         auth_contents = auth_contents + str(i[0]) + '''\t\t\t\t''' + str(dmr_id) + '''\t''' + i[1] + '''\t\t\t\t''' + i[2] + '''\t\t''' + str(i[3]) + '\n' | ||||||
|  | ##        print(header) | ||||||
|  | ##        print(auth_contents) | ||||||
|  | 
 | ||||||
|  |          | ||||||
|  | ##    return header + auth_contents | ||||||
|  | 
 | ||||||
|  |     output = ''' | ||||||
|  | #!/usr/bin/python3 | ||||||
|  | 
 | ||||||
|  | import os | ||||||
|  | from pathlib import Path | ||||||
|  | 
 | ||||||
|  | os.chdir('/root') | ||||||
|  | if Path('/root/DMR_Hosts.txt').is_file(): | ||||||
|  |      print('DMR_Hosts.txt exists, adding entries...') | ||||||
|  |      with open('/root/DMR_Hosts.txt', 'a') as dmr_hosts: | ||||||
|  |         dmr_hosts.write("""''' + auth_contents + '''""") | ||||||
|  |         dmr_hosts.close() | ||||||
|  | 
 | ||||||
|  | else: | ||||||
|  |     Path('/root/DMR_Hosts.txt').touch() | ||||||
|  |     print('DMR_Hosts.txt does not exist, creating...') | ||||||
|  |     with open('/root/DMR_Hosts.txt', 'w') as dmr_hosts: | ||||||
|  |         dmr_hosts.write("""''' + header + auth_contents + '""")' + ''' | ||||||
|  |         dmr_hosts.close() | ||||||
|  | print('DMR Host file updates.')''' | ||||||
|  |     print(output) | ||||||
|  |     return output | ||||||
|  | 
 | ||||||
| @ -37,10 +37,10 @@ | |||||||
|       <a class="navbar-brand">{{ user_manager.USER_APP_NAME }}</a> |       <a class="navbar-brand">{{ user_manager.USER_APP_NAME }}</a> | ||||||
|     </div> |     </div> | ||||||
|     <ul class="nav navbar-nav"> |     <ul class="nav navbar-nav"> | ||||||
|       <li><a href="/">Home</a></li> |       <li><a href="/"><span class="glyphicon glyphicon-home"></span> Home</a></li> | ||||||
|       <li><a href="{{url}}/talkgroups">Talkgroups</a></li> |       <li><a href="{{url}}/talkgroups"><span class="glyphicon glyphicon-list"></span> Talkgroups</a></li> | ||||||
|       <li><a href="{{url}}/news">News</a></li> |       <li><a href="{{url}}/news"><span class="glyphicon glyphicon-list-alt"></span> News</a></li> | ||||||
|       <li><a href="{{url}}/help">Help</a></li> |       <li><a href="{{url}}/help"><span class="glyphicon glyphicon-question-sign"></span> Help</a></li> | ||||||
|     </ul> |     </ul> | ||||||
|     <ul class="nav navbar-nav navbar-right"> |     <ul class="nav navbar-nav navbar-right"> | ||||||
|   {% if not call_or_get(current_user.is_authenticated) %} |   {% if not call_or_get(current_user.is_authenticated) %} | ||||||
|  | |||||||
							
								
								
									
										17
									
								
								web/templates/map.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								web/templates/map.html
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,17 @@ | |||||||
|  | {% extends 'flask_user/_public_base.html' %} | ||||||
|  | {% block content %} | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | <div class="row container-fluid" style="width: 800px;"> | ||||||
|  |   <div class="col-sm-12"> | ||||||
|  |   {{markup_content}} | ||||||
|  | 
 | ||||||
|  | </div> | ||||||
|  | </div> | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | <p> </p> | ||||||
|  | {% endblock %} | ||||||
							
								
								
									
										34
									
								
								web/templates/pi-star_gen.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								web/templates/pi-star_gen.html
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,34 @@ | |||||||
|  | {% extends 'flask_user/_public_base.html' %} | ||||||
|  | {% block content %} | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | <div class="panel panel-default" > | ||||||
|  |   <div class="panel-heading" style="text-align: center;"><h4>Pi-Star Instructions</h4></div> | ||||||
|  |   <div class="panel-body"> | ||||||
|  | <p> </p> | ||||||
|  | A script to enable the use of this network on a Pi-Star device is available. This script will automatically add information, including your generated passphrase and each Master/Proxy instance | ||||||
|  | on this network, to your device's DMR_Hosts.txt. This will allow you to connect to this network in the Pi-Star configuration page. | ||||||
|  | <p> </p> | ||||||
|  | 
 | ||||||
|  | A script(s) is generated for each of your DMR IDs when you load this page. Each link/command is valid for only one use. If you need execute a command again, | ||||||
|  | simply reload the page to get a fresh link. | ||||||
|  | <p> </p> | ||||||
|  | <hr /> | ||||||
|  | <p> </p> | ||||||
|  | 
 | ||||||
|  | <p><strong>1</strong>: Log into your Pi-Star device via SSH. <br /> | ||||||
|  | <strong>2</strong>: Become <strong>root</strong> user. DMR_Hosts.txt is stored in /root, thus you need to be root to modify it. | ||||||
|  | <pre>sudo su</pre><br /> | ||||||
|  | <strong>3</strong>: Decide which DMR ID you want Pi-Star to login with. Copy and past one of the commands below to update DMR_Hosts.txt. Each command is specific to a DMR ID.<br /> | ||||||
|  | 
 | ||||||
|  | <p> </p> | ||||||
|  | 
 | ||||||
|  | {{markup_content}} | ||||||
|  | <p> </p> | ||||||
|  | 
 | ||||||
|  | If you were sucessful, you can now go into the Pi-Star configuration and select this network from the dropdown list. | ||||||
|  |   </div> | ||||||
|  | </div> | ||||||
|  | <p> </p> | ||||||
|  | 
 | ||||||
|  | {% endblock %} | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user