mirror of
				https://github.com/Telecominfraproject/wlan-ap.git
				synced 2025-10-31 10:28:06 +00:00 
			
		
		
		
	Compare commits
	
		
			6 Commits
		
	
	
		
			release/v1
			...
			release/v1
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 7bcd7093d2 | ||
|   | f273ec572e | ||
|   | 5fd49f6b64 | ||
|   | f3fc398eac | ||
|   | 7aea689d9a | ||
|   | 7a634d80ed | 
| @@ -30,4 +30,9 @@ static inline timer * tm_new_set( void (*hook)(struct _timer *), void *data, uns | ||||
|     return t; | ||||
| } | ||||
|  | ||||
| static inline void tm_free(timer *t) | ||||
| { | ||||
|     free(t); | ||||
| } | ||||
|  | ||||
| #endif | ||||
|   | ||||
| @@ -26,7 +26,8 @@ static void apc_dump( struct proto * P ) | ||||
| static struct proto * apc_init(struct proto_config * c) | ||||
| { | ||||
| 	struct proto * P = mb_allocz(sizeof(struct apc_proto)); | ||||
| 	 | ||||
|  | ||||
| 	printf("apc_init\n"); | ||||
| 	P->cf = c; | ||||
| 	P->debug = c->debug; | ||||
| 	P->mrtdump = c->mrtdump; | ||||
|   | ||||
| @@ -103,6 +103,7 @@ void apc_send_hello(struct apc_iface * ifa, int kind ) | ||||
| 	struct apc_hello2_packet ps; | ||||
| 	unsigned int length, report = 0; | ||||
| 	struct apc_spec ApcSpec; | ||||
| 	char dst_ip[16]; | ||||
| 	 | ||||
| 	if (WaitingToReelect ) | ||||
| 		return; | ||||
| @@ -202,8 +203,7 @@ void apc_send_hello(struct apc_iface * ifa, int kind ) | ||||
|  | ||||
| 	length += i * sizeof(u32); | ||||
|  | ||||
| 	printf("HELLO packet sent via %s\n", ifa->ifname ); | ||||
| 	char *dst_ip = malloc(16); | ||||
| 	printf("HELLO packet sent via  %s\n", ifa->ifname ); | ||||
| 	memset(dst_ip, 0, 16); | ||||
| 	if ((get_current_ip(dst_ip, IAC_IFACE)) < 0) { | ||||
| 		printf("Error: Cannot get IP for %s", IAC_IFACE); | ||||
|   | ||||
| @@ -36,7 +36,7 @@ reset_lists(struct apc_proto *p, struct apc_neighbor *n) | ||||
| struct apc_neighbor * apc_neighbor_new(struct apc_iface * ifa) | ||||
| { | ||||
| 	struct apc_neighbor * n = mb_allocz(sizeof(struct apc_neighbor)); | ||||
| 	 | ||||
| 	printf("apc_new_neighbor\n");	 | ||||
| 	n->ifa = ifa; | ||||
| 	add_tail(&ifa->neigh_list, NODE n); | ||||
| 	n->adj = 0; | ||||
| @@ -58,6 +58,8 @@ static void apc_neigh_down(struct apc_neighbor * n) | ||||
| 	rem_node(NODE n); | ||||
| 	 | ||||
| 	printf("Neighbor %x on %s removed", n->rid, ifa->ifname ); | ||||
| 	tm_free(n->inactim); | ||||
| 	mb_free(n); | ||||
| } | ||||
|  | ||||
| /** | ||||
|   | ||||
| @@ -26,6 +26,7 @@ static void receive_data_uloop(struct uloop_fd *fd, unsigned int events) | ||||
| 		printf("recvfrom() failed"); | ||||
|  | ||||
| 	ra.cb(recv_data, recv_data_len); | ||||
| 	free(recv_data); | ||||
|  | ||||
| } | ||||
|  | ||||
| @@ -41,6 +42,7 @@ static void receive_data(struct ev_loop *ev, ev_io *io, int event) | ||||
| 		printf("recvfrom() failed"); | ||||
|  | ||||
| 	ra.cb(recv_data, recv_data_len); | ||||
| 	free(recv_data); | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
							
								
								
									
										4
									
								
								feeds/wlan-ap/opensync/files/bin/wlan_ap_factory_reset.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										4
									
								
								feeds/wlan-ap/opensync/files/bin/wlan_ap_factory_reset.sh
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,4 @@ | ||||
| #!/bin/sh | ||||
|  | ||||
| tar czf /sysupgrade.tgz /usr/opensync/certs/ | ||||
| jffs2reset -r -y -k | ||||
| @@ -1,12 +1,49 @@ | ||||
| #!/bin/sh | ||||
|  | ||||
| if [ $# -ne 1 ] ; then | ||||
| 	echo "Usage: $0 <redirector address>" >&2 | ||||
| 	exit 1 | ||||
| AP_PRIVATE_KEY_FILE="/usr/opensync/certs/client_dec.key" | ||||
| AP_CERTIFICATE_FILE="/usr/opensync/certs/client.pem" | ||||
| AP_DEVICE_ID_FILE="/usr/opensync/certs/client_deviceid.txt" | ||||
| DIGICERT_API_URI="clientauth.one.digicert.com" | ||||
|  | ||||
| if [ "$1" = "-h" ]; then | ||||
|   echo "Usage: $0 [redirector address]" >&2 | ||||
|   exit 1 | ||||
| fi | ||||
|  | ||||
| redirector_addr=$1 | ||||
| # Query DigiCert's API if redirector wasn't specified | ||||
| if [ -z "$1" ]; then | ||||
|   if [ ! -f "$AP_DEVICE_ID_FILE" ]; then | ||||
|       echo "Device ID file $AP_DEVICE_ID_FILE does not exist. Make sure to create it or specify the redirector address manually." | ||||
|       exit 1 | ||||
|   fi | ||||
|  | ||||
|   digicert_device_id=`cat ${AP_DEVICE_ID_FILE}` | ||||
|   device_data=`curl -s \ | ||||
|     --retry 5 \ | ||||
|     --show-error \ | ||||
|     --key "${AP_PRIVATE_KEY_FILE}" \ | ||||
|     --cert "${AP_CERTIFICATE_FILE}" \ | ||||
|     "https://${DIGICERT_API_URI}/iot/api/v2/device/${digicert_device_id}"` | ||||
|  | ||||
|   controller_url=`echo ${device_data} | jsonfilter -e '@.fields[@.name="Redirector"].value'` | ||||
|   if [ -z "$controller_url" ]; then | ||||
|     echo "No redirector found for this device" | ||||
|     exit 1 | ||||
|   fi | ||||
|   controller_port=`echo ${controller_url} | cut -s -d ":" -f2)` | ||||
|   if [ -z "$controller_port" ]; then | ||||
|     redirector_addr="ssl:${controller_url}:6643" | ||||
|   else | ||||
|     redirector_addr="ssl:${controller_url}" | ||||
|   fi | ||||
| else | ||||
|   redirector_addr=$1 | ||||
| fi | ||||
|  | ||||
| echo "${redirector_addr}" > /usr/opensync/certs/redirector.txt | ||||
| /etc/init.d/uhttpd enable | ||||
| /etc/init.d/uhttpd start | ||||
| uci set system.tip.redirector="${redirector_addr}" | ||||
| uci set system.tip.deployed=0 | ||||
| uci commit system | ||||
| /etc/init.d/opensync restart | ||||
|   | ||||
| @@ -37,6 +37,20 @@ start_service() { | ||||
|     echo "Setting certificates" | ||||
|     mkdir -p ${CERTS_DEST_PATH} | ||||
|     cp ${CERTS_SRC_PATH}/* ${CERTS_DEST_PATH}/ | ||||
|     echo "Checking Redirector" | ||||
|     redirector=$(uci get system.tip.redirector) | ||||
|     if [ -z "$redirector" ]; then | ||||
|         [[ -f /usr/opensync/certs/redirector.txt ]] && redirector=$(cat /usr/opensync/certs/redirector.txt | tr -d '\r\n') | ||||
|         if [ -z "$redirector" ]; then | ||||
|             logger -t opensync "Contacting DigiCert for redirector address" | ||||
|             wlan_ap_redirector.sh | ||||
|         else | ||||
|             logger -t opensync "Restoring redirector ${redirector} after factory reset" | ||||
|             wlan_ap_redirector.sh ${redirector} | ||||
|         fi | ||||
|     fi | ||||
|     [[ -f /usr/opensync/certs/redirector.txt ]] || echo "${redirector}" > /usr/opensync/certs/redirector.txt | ||||
|   | ||||
|     echo "Starting OpenSync" | ||||
|     procd_set_param command ${PROG} | ||||
|     procd_close_instance | ||||
|   | ||||
| @@ -291,7 +291,7 @@ static void cb_osp_start_factory_reboot(EV_P_ ev_timer *w, int events) | ||||
| 	if (!strcmp(upg_url, "reboot")) | ||||
| 		system("reboot"); | ||||
| 	else | ||||
| 		system("jffs2reset -y -r"); | ||||
| 		system("wlan_ap_factory_reset.sh"); | ||||
|  | ||||
| 	upg_running = false; | ||||
|  | ||||
|   | ||||
| @@ -130,6 +130,7 @@ static int rx_msg(struct nl_msg *msg, void* arg) | ||||
| 	struct nlattr *attr[GENL_UCC_ATTR_MAX+1]; | ||||
|  | ||||
| 	struct voip_session *data; | ||||
| 	char dst_ip[16]; | ||||
| 	genlmsg_parse(nlmsg_hdr(msg), 0, attr,  | ||||
| 			GENL_UCC_ATTR_MAX, genl_ucc_policy); | ||||
|  | ||||
| @@ -140,7 +141,6 @@ static int rx_msg(struct nl_msg *msg, void* arg) | ||||
| 		return NL_OK; | ||||
| 	} | ||||
|  | ||||
| 	char *dst_ip = malloc(16); | ||||
| 	memset(dst_ip, 0, 16); | ||||
| 	if((get_current_ip(dst_ip, IAC_IFACE)) < 0) { | ||||
| 		LOGI("Error: Cannot get IP for %s", IAC_IFACE); | ||||
|   | ||||
| @@ -0,0 +1,81 @@ | ||||
| From 1f9978564420818d4ce4bdbb08fce2eca7c13d8e Mon Sep 17 00:00:00 2001 | ||||
| From: Rick Sommerville <rick.sommerville@netexperience.com> | ||||
| Date: Sun, 23 May 2021 14:36:03 -0400 | ||||
| Subject: [PATCH] Preserve certificates and redirector over factory-reset | ||||
|  | ||||
| --- | ||||
|  package/base-files/files/etc/rc.button/reset  |  2 +- | ||||
|  .../patches/001-jffs2reset-keep-option        | 48 +++++++++++++++++++ | ||||
|  2 files changed, 49 insertions(+), 1 deletion(-) | ||||
|  create mode 100644 package/system/fstools/patches/001-jffs2reset-keep-option | ||||
|  | ||||
| diff --git a/package/base-files/files/etc/rc.button/reset b/package/base-files/files/etc/rc.button/reset | ||||
| index 2403122ad2..56c0548ec9 100755 | ||||
| --- a/package/base-files/files/etc/rc.button/reset | ||||
| +++ b/package/base-files/files/etc/rc.button/reset | ||||
| @@ -23,7 +23,7 @@ released) | ||||
|  	elif [ "$SEEN" -ge 5 -a -n "$OVERLAY" ] | ||||
|  	then | ||||
|  		echo "FACTORY RESET" > /dev/console | ||||
| -		jffs2reset -y && reboot & | ||||
| +		wlan_ap_factory_reset.sh | ||||
|  	fi | ||||
|  ;; | ||||
|  esac | ||||
| diff --git a/package/system/fstools/patches/001-jffs2reset-keep-option b/package/system/fstools/patches/001-jffs2reset-keep-option | ||||
| new file mode 100644 | ||||
| index 0000000000..50209ea276 | ||||
| --- /dev/null | ||||
| +++ b/package/system/fstools/patches/001-jffs2reset-keep-option | ||||
| @@ -0,0 +1,48 @@ | ||||
| +--- a/jffs2reset.c | ||||
| ++++ b/jffs2reset.c | ||||
| +@@ -40,7 +40,7 @@ ask_user(void) | ||||
| + 	return 0; | ||||
| + } | ||||
| +  | ||||
| +-static int jffs2_reset(struct volume *v, int reset) | ||||
| ++static int jffs2_reset(struct volume *v, int reset, int keep) | ||||
| + { | ||||
| + 	char *mp; | ||||
| +  | ||||
| +@@ -48,7 +48,7 @@ static int jffs2_reset(struct volume *v, | ||||
| + 	if (mp) { | ||||
| + 		ULOG_INFO("%s is mounted as %s, only erasing files\n", v->blk, mp); | ||||
| + 		fs_state_set("/overlay", FS_STATE_PENDING); | ||||
| +-		overlay_delete(mp, false); | ||||
| ++		overlay_delete(mp, keep); | ||||
| + 		mount(mp, "/", NULL, MS_REMOUNT, 0); | ||||
| + 	} else { | ||||
| + 		ULOG_INFO("%s is not mounted\n", v->blk); | ||||
| +@@ -93,8 +93,8 @@ static int jffs2_mark(struct volume *v) | ||||
| + int main(int argc, char **argv) | ||||
| + { | ||||
| + 	struct volume *v; | ||||
| +-	int ch, yes = 0, reset = 0; | ||||
| +-	while ((ch = getopt(argc, argv, "yr")) != -1) { | ||||
| ++	int ch, yes = 0, reset = 0, keep = 0; | ||||
| ++	while ((ch = getopt(argc, argv, "yrk")) != -1) { | ||||
| + 		switch(ch) { | ||||
| + 		case 'y': | ||||
| + 			yes = 1; | ||||
| +@@ -102,6 +102,9 @@ int main(int argc, char **argv) | ||||
| + 		case 'r': | ||||
| + 			reset = 1; | ||||
| + 			break; | ||||
| ++                case 'k': | ||||
| ++                        keep = 1; | ||||
| ++                        break; | ||||
| + 		} | ||||
| +  | ||||
| + 	} | ||||
| +@@ -128,5 +131,5 @@ int main(int argc, char **argv) | ||||
| + 	volume_init(v); | ||||
| + 	if (!strcmp(*argv, "jffs2mark")) | ||||
| + 		return jffs2_mark(v); | ||||
| +-	return jffs2_reset(v, reset); | ||||
| ++	return jffs2_reset(v, reset, keep); | ||||
| + } | ||||
| --  | ||||
| 2.17.1 | ||||
|  | ||||
		Reference in New Issue
	
	Block a user