mirror of
				https://github.com/Telecominfraproject/wlan-ap.git
				synced 2025-10-31 02:17:58 +00:00 
			
		
		
		
	Compare commits
	
		
			3 Commits
		
	
	
		
			v1.0.4-rc2
			...
			v1.0.4
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 7bcd7093d2 | ||
|   | f273ec572e | ||
|   | 5fd49f6b64 | 
							
								
								
									
										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 | ||||||
| @@ -17,9 +17,10 @@ if [ -z "$1" ]; then | |||||||
|       exit 1 |       exit 1 | ||||||
|   fi |   fi | ||||||
|  |  | ||||||
|   # TODO: this command should be retried if it fails |  | ||||||
|   digicert_device_id=`cat ${AP_DEVICE_ID_FILE}` |   digicert_device_id=`cat ${AP_DEVICE_ID_FILE}` | ||||||
|   device_data=`curl -s \ |   device_data=`curl -s \ | ||||||
|  |     --retry 5 \ | ||||||
|  |     --show-error \ | ||||||
|     --key "${AP_PRIVATE_KEY_FILE}" \ |     --key "${AP_PRIVATE_KEY_FILE}" \ | ||||||
|     --cert "${AP_CERTIFICATE_FILE}" \ |     --cert "${AP_CERTIFICATE_FILE}" \ | ||||||
|     "https://${DIGICERT_API_URI}/iot/api/v2/device/${digicert_device_id}"` |     "https://${DIGICERT_API_URI}/iot/api/v2/device/${digicert_device_id}"` | ||||||
| @@ -29,7 +30,7 @@ if [ -z "$1" ]; then | |||||||
|     echo "No redirector found for this device" |     echo "No redirector found for this device" | ||||||
|     exit 1 |     exit 1 | ||||||
|   fi |   fi | ||||||
|   controller_port=`echo ${controller_url} | cut -d ":" -f2)` |   controller_port=`echo ${controller_url} | cut -s -d ":" -f2)` | ||||||
|   if [ -z "$controller_port" ]; then |   if [ -z "$controller_port" ]; then | ||||||
|     redirector_addr="ssl:${controller_url}:6643" |     redirector_addr="ssl:${controller_url}:6643" | ||||||
|   else |   else | ||||||
| @@ -39,6 +40,9 @@ else | |||||||
|   redirector_addr=$1 |   redirector_addr=$1 | ||||||
| fi | 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.redirector="${redirector_addr}" | ||||||
| uci set system.tip.deployed=0 | uci set system.tip.deployed=0 | ||||||
| uci commit system | uci commit system | ||||||
|   | |||||||
| @@ -40,11 +40,17 @@ start_service() { | |||||||
|     echo "Checking Redirector" |     echo "Checking Redirector" | ||||||
|     redirector=$(uci get system.tip.redirector) |     redirector=$(uci get system.tip.redirector) | ||||||
|     if [ -z "$redirector" ]; then |     if [ -z "$redirector" ]; then | ||||||
|         logger -t opensync "Contacting DigiCert for redirector address" |         [[ -f /usr/opensync/certs/redirector.txt ]] && redirector=$(cat /usr/opensync/certs/redirector.txt | tr -d '\r\n') | ||||||
|         wlan_ap_redirector.sh |         if [ -z "$redirector" ]; then | ||||||
|     else |             logger -t opensync "Contacting DigiCert for redirector address" | ||||||
|         logger -t opensync "Redirector address is ${redirector}" |             wlan_ap_redirector.sh | ||||||
|  |         else | ||||||
|  |             logger -t opensync "Restoring redirector ${redirector} after factory reset" | ||||||
|  |             wlan_ap_redirector.sh ${redirector} | ||||||
|  |         fi | ||||||
|     fi |     fi | ||||||
|  |     [[ -f /usr/opensync/certs/redirector.txt ]] || echo "${redirector}" > /usr/opensync/certs/redirector.txt | ||||||
|  |   | ||||||
|     echo "Starting OpenSync" |     echo "Starting OpenSync" | ||||||
|     procd_set_param command ${PROG} |     procd_set_param command ${PROG} | ||||||
|     procd_close_instance |     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")) | 	if (!strcmp(upg_url, "reboot")) | ||||||
| 		system("reboot"); | 		system("reboot"); | ||||||
| 	else | 	else | ||||||
| 		system("jffs2reset -y -r"); | 		system("wlan_ap_factory_reset.sh"); | ||||||
|  |  | ||||||
| 	upg_running = false; | 	upg_running = false; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -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