Netgear DGN2200 1.0.0.29_1.7.29_HotS – Password Disclosure

  • 作者: Dolev Farhi
    日期: 2014-07-23
  • 类别:
    平台:
  • 来源:https://www.exploit-db.com/exploits/34149/
  • # Exploit Title: Password Disclosure vulnerability
    # Software: NETGEAR DGN2200
    # Software Link: netgear.com
    # Version: DGN2200
    # Author: Dolev Farhi, email: dolev(at)openflare(dot)org
    # Date: 23.7.2014
    # Tested on: Kali Linux
    # Firmware 1.0.0.29_1.7.29_HotS
     
     
    2. Vulnerability Description:
    ===============================
    An attacker is able to extract sensitive information such as the password from the Basic Settings router page due to storing it in plaintext.
     
     
    3. Steps to reproduce:
    ======================
    Navigate to the Basic Settings page, right click in the browser -> view source/frame
    
    html>
    <head>
    <META name="description" content="DGN2200v2BEZEQ">
    <META http-equiv="Content-Type" content="text/html; charset=utf-8">
    <META http-equiv="Content-Style-Type" content="text/css">
    <META http-equiv="Pragma" content="no-cache">
    <META HTTP-equiv="Cache-Control" content="no-cache">
    <META HTTP-EQUIV="Expires" CONTENT="Mon, 06 Jan 1990 00:00:01 GMT">
    
    <title>PPPoE</title>
    <link rel="stylesheet" href="https://www.exploit-db.com/exploits/34149/form.css">
    <STYLE TYPE="text/javascript">
    	classes.num.all.fontFamily = "Courier";
    	classes.num.all.fontSize = "10pt" ;
    </style>
    <script language="javascript" type="text/javascript" src="https://www.exploit-db.com/exploits/34149/func.js"></script>
    <script language="javascript" type="text/javascript" src="https://www.exploit-db.com/exploits/34149/msg.js"></script>
    <script language="javascript" type="text/javascript" src="https://www.exploit-db.com/exploits/34149/utility.js"></script>
    <script language="javascript" type="text/javascript" src="https://www.exploit-db.com/exploits/34149/browser.js"></script>
    <script language="javascript" type="text/javascript" src="https://www.exploit-db.com/exploits/34149/md5.js"></script>
    
    <script language="javascript" type="text/javascript">
    var DisableFixedIP = false;
    var DisableFixedDNS = false;
    var all_wan_proto= new Array(8);
    var all_pppoe_localip = new Array(8);
    var all_wan_dns_sel = new Array(8);
    var all_wan_dns1_pri = new Array(8);
    var all_wan_dns1_sec = new Array(8);
    var all_wan_nat = new Array(8);
    var all_wan_fw = new Array(8);
    var all_ppp_dod = new Array(8);
    var all_pppoe_idletime = new Array(8);
    var all_pppoe_username = new Array(8);
    var all_pppoe_passwd =new Array(8);
    var all_pppoe_servicename = new Array(8);
    var all_is_static_ip = new Array(8);
    var all_wan_isbridge = new Array(8);
    
    
    function loadMultiWanInfo()
    {
    var cf = document.forms[0];
    cf.adslChoice.selectedIndex = cf.nowchoice.value;
    
    all_wan_proto[0] = "pppoe";
    all_wan_proto[1] = "pppoe";
    all_wan_proto[2] = "pppoe";
    all_wan_proto[3] = "pppoe";
    all_wan_proto[4] = "pppoe";
    all_wan_proto[5] = "pppoe";
    all_wan_proto[6] = "pppoe";
    all_wan_proto[7] = "pppoe";
    
    all_pppoe_localip[0] = "ip.add.re.ss";
    all_pppoe_localip[1] = "0.0.0.0";
    all_pppoe_localip[2] = "0.0.0.0";
    all_pppoe_localip[3] = "0.0.0.0";
    all_pppoe_localip[4] = "0.0.0.0";
    all_pppoe_localip[5] = "0.0.0.0";
    all_pppoe_localip[6] = "0.0.0.0";
    all_pppoe_localip[7] = "0.0.0.0";
    
    all_ppp_dod[0] = 0;
    all_ppp_dod[1] = 0;
    all_ppp_dod[2] = 0;
    all_ppp_dod[3] = 0;
    all_ppp_dod[4] = 0;
    all_ppp_dod[5] = 0;
    all_ppp_dod[6] = 0;
    all_ppp_dod[7] = 0;
    
    all_pppoe_idletime[0] = 0 / 60;
    all_pppoe_idletime[1] = 0 / 60;
    all_pppoe_idletime[2] = 0 / 60;
    all_pppoe_idletime[3] = 0 / 60;
    all_pppoe_idletime[4] = 0 / 60;
    all_pppoe_idletime[5] = 0 / 60;
    all_pppoe_idletime[6] = 0 / 60;
    all_pppoe_idletime[7] = 0 / 60;
    
    all_wan_dns_sel[0] = "0";
    all_wan_dns_sel[1] = "0";
    all_wan_dns_sel[2] = "0";
    all_wan_dns_sel[3] = "0";
    all_wan_dns_sel[4] = "0";
    all_wan_dns_sel[5] = "0";
    all_wan_dns_sel[6] = "0";
    all_wan_dns_sel[7] = "0";
    
    all_wan_dns1_pri[0] = "80.179.52.100";
    all_wan_dns1_pri[1] = "";
    all_wan_dns1_pri[2] = "";
    all_wan_dns1_pri[3] = "";
    all_wan_dns1_pri[4] = "";
    all_wan_dns1_pri[5] = "";
    all_wan_dns1_pri[6] = "";
    all_wan_dns1_pri[7] = "";
    
    all_wan_dns1_sec[0] = "80.179.55.100";
    all_wan_dns1_sec[1] = "";
    all_wan_dns1_sec[2] = "";
    all_wan_dns1_sec[3] = "";
    all_wan_dns1_sec[4] = "";
    all_wan_dns1_sec[5] = "";
    all_wan_dns1_sec[6] = "";
    all_wan_dns1_sec[7] = "";
    
    all_wan_nat[0] = "1";
    all_wan_nat[1] = "1"; 
    all_wan_nat[2] = "1"; 
    all_wan_nat[3] = "1"; 
    all_wan_nat[4] = "1"; 
    all_wan_nat[5] = "1"; 
    all_wan_nat[6] = "1"; 
    all_wan_nat[7] = "1";
    
    all_wan_fw[0] = "1";
    all_wan_fw[1] = "1";
    all_wan_fw[2] = "1"; 
    all_wan_fw[3] = "1"; 
    all_wan_fw[4] = "1"; 
    all_wan_fw[5] = "1"; 
    all_wan_fw[6] = "1"; 
    all_wan_fw[7] = "1";
    
    all_pppoe_username[0] = "user@012ISP";
    all_pppoe_username[1] = "";
    all_pppoe_username[2] = "";
    all_pppoe_username[3] = "";
    all_pppoe_username[4] = "";
    all_pppoe_username[5] = "";
    all_pppoe_username[6] = "";
    all_pppoe_username[7] = "";
    
    all_pppoe_passwd[0] = "MyPassword"; <--- password
    all_pppoe_passwd[1] = "";
    all_pppoe_passwd[2] = "";
    all_pppoe_passwd[3] = "";
    all_pppoe_passwd[4] = "";
    all_pppoe_passwd[5] = "";
    all_pppoe_passwd[6] = "";
    all_pppoe_passwd[7] = "";
    
    all_pppoe_servicename[0] = "";
    all_pppoe_servicename[1] = "";
    all_pppoe_servicename[2] = "";
    all_pppoe_servicename[3] = "";
    all_pppoe_servicename[4] = "";
    all_pppoe_servicename[5] = "";
    all_pppoe_servicename[6] = "";
    all_pppoe_servicename[7] = "";
    
    all_is_static_ip[0] = "0";
    all_is_static_ip[1] = "0";
    all_is_static_ip[2] = "0";
    all_is_static_ip[3] = "0";
    all_is_static_ip[4] = "0";
    all_is_static_ip[5] = "0";
    all_is_static_ip[6] = "0";
    all_is_static_ip[7] = "0";
    
    all_wan_isbridge[0] = "0";
    all_wan_isbridge[1] = "0";
    all_wan_isbridge[2] = "0";
    all_wan_isbridge[3] = "0";
    all_wan_isbridge[4] = "0";
    all_wan_isbridge[5] = "0";
    all_wan_isbridge[6] = "0";
    all_wan_isbridge[7] = "0";
    }
    
    function goTestApply()
    {
    	var winoptions = "width=640,height=480,menubar=yes,toolbar=yes,status=yes,location=yes,resizable=yes";
    	if(document.forms[0].runtest.value == "yes")
    	openDataSubWin('wtest.htm',winoptions);
    }
    
    function ChangeAdslChoice()
    {
    var cf = document.forms[0];
    var index = cf.adslChoice.selectedIndex;
    
    var wan_proto = all_wan_proto[index];
    if (wan_proto == "dhcp" || wan_proto == "ipoa" 
    || wan_proto == "mer" || wan_proto == "static" )
    doTypeChange2(0);
    else if (wan_proto == "pppoe")
    doTypeChange2(1);
    else
    doTypeChange2(2);
    
    //loadSettings(index);
    //loadcheck();
    }
    
    function doTypeChange2(newIndex)
    {
    var tmpstr;
    var cf = document.forms[0];
    var index = cf.adslChoice.selectedIndex;
    
    	if (newIndex == 0)
    	{
    	tmpstr = "ether_m.cgi?nowchoice=" + index + "&nowproto=0";
    		location.href = tmpstr;
    }
    	else if (newIndex == 1)
    	{
    	tmpstr = "pppoe_m.cgi?nowchoice=" + index+ "&nowproto=1";
    		location.href = tmpstr;	
    }
    	else if (newIndex == 2)
    	{
    	tmpstr = "pppoa_m.cgi?nowchoice=" + index+ "&nowproto=1";
    		location.href = tmpstr;	
    }
    }
    
    function doTypeChange3(newIndex)
    {
    var tmpstr;
    var cf = document.forms[0];
    var index = cf.adslChoice.selectedIndex;
    var mux = cf.dsl_multiplex.value;
    var vpi = cf.dsl_vpi.value;
    var vci = cf.dsl_vci.value;
    var msg = "";
    if( isNumeric(cf.dsl_vpi, 255) ) 
    msg = "VPI contains an invalid number"
    if( isNumeric(cf.dsl_vci, 65536) ) 
    msg = "VC contains an invalid number"
    if (vpi < 0 || vpi > 255) 
    msg = "VPI is out of range [0~255]"
    if (vci < 32 || vci > 65535)
    	msg = "VC is out of range [32~65535]"
    	if (msg.length > 1)
    	{
    		alert(msg);
    		return false;
    	}
    if (newIndex == 0)
    {
    tmpstr="ether_m.cgi?nowchoice="+index+"&havetmpvar=1&gui_mode=1&tmpmux="+mux+"&tmpvpi="+vpi+"&tmpvci="+vci;
    location.href = tmpstr;
    }
    else if (newIndex == 1)
    {
    tmpstr="pppoe_m.cgi?nowchoice="+index+"&havetmpvar=1&gui_mode=1&tmpmux="+mux+"&tmpvpi="+vpi+"&tmpvci="+vci;
    location.href = tmpstr;
    }
    }
    
    function setServer()
    {
    	var cf = document.forms[0];
    	var stype = cf.login_type.selectedIndex;
    	var tmpstr;
    	var index = cf.adslChoice.selectedIndex;
    	var mux = cf.dsl_multiplex.value;
    var vpi = cf.dsl_vpi.value;
    var vci = cf.dsl_vci.value;
    var msg = "";
    if( isNumeric(cf.dsl_vpi, 255) ) 
    msg = "VPI contains an invalid number"
    if( isNumeric(cf.dsl_vci, 65536) ) 
    msg = "VC contains an invalid number"
    if (vpi < 0 || vpi > 255) 
    msg = "VPI is out of range [0~255]"
    if (vci < 32 || vci > 65535)
    	msg = "VC is out of range [32~65535]"
    	if (msg.length > 1)
    	{
    		alert(msg);
    		return false;
    	}
    
    if(stype==0) //pppoe
    {
    tmpstr="pppoe_m.cgi?nowchoice="+index+"&havetmpvar=1&gui_mode=1&tmpmux="+mux+"&tmpvpi="+vpi+"&tmpvci="+vci;
    location.href = tmpstr;
    }
    else if(stype==1) //pppoa
    {
    tmpstr="pppoa_m.cgi?nowchoice="+index+"&havetmpvar=1&gui_mode=1&tmpmux="+mux+"&tmpvpi="+vpi+"&tmpvci="+vci;
    location.href = tmpstr;
    }
    }
    
    function loadcheck()
    {
    var cf = document.forms[0];
    if (isIE())
    {
    		cf.pppoe_username.size="24";
    		cf.pppoe_passwd.size="24";
    	}
    loadhelp('BAS_mpppoe');
    setIP();
    	setDNS();
    }
    
    function setIP()
    {
    	var cf = document.forms[0];
    	var dflag = cf.WANAssign[0].checked;
    	setDisabled(dflag,cf.WPethr1,cf.WPethr2,cf.WPethr3,cf.WPethr4);
    	if (cf.WANAssign[1].checked)
    	{
    	cf.DNSAssign[1].checked = true;
    	setDNS();
    	}
    	DisableFixedIP = dflag;
    }
    
    function setDNS()
    {
    	var cf = document.forms[0];
    	var dflag = cf.DNSAssign[0].checked;
    	if (cf.WANAssign[1].checked && cf.DNSAssign[0].checked)
    	{
    		cf.DNSAssign[1].checked=true;
    		dflag = false;
    	}
    	setDisabled(dflag,cf.DAddr1,cf.DAddr2,cf.DAddr3,cf.DAddr4,cf.PDAddr1,cf.PDAddr2,cf.PDAddr3,cf.PDAddr4);
    	DisableFixedDNS = dflag;
    }
    
    function checkData()
    {
    var cf = document.forms[0];
    	var msg = "";
    var vpi = cf.dsl_vpi.value;
    var vci = cf.dsl_vci.value;
    
    if( isNumeric(cf.dsl_vpi, 255) ) 
    msg = "VPI contains an invalid number"
    if( isNumeric(cf.dsl_vci, 65536) ) 
    msg = "VC contains an invalid number"
    if (vpi < 0 || vpi > 255) 
    msg = "VPI is out of range [0~255]"
    if (vci < 32 || vci > 65535)
    	msg = "VC is out of range [32~65535]"
    
    msg+= checkBlank(cf.pppoe_username, "User name");
    	if(cf.pppoe_idletime.value.length<=0)
    	 msg+= "Please enter idle time.\n";
    	else if(!_isNumeric(cf.pppoe_idletime.value))
    	 msg+= "Invalid idle time,please enter proper numeral.\n";
     
    if(cf.WANAssign[1].checked)
    	{
    		if(checkIP(cf.WPethr1,cf.WPethr2,cf.WPethr3,cf.WPethr4,254)||(parseInt(cf.WPethr4.value)==0))
    			msg+= "Invalid static IP address.\n";
    		cf.pppoe_localip.value = cf.WPethr1.value+'.'+cf.WPethr2.value+'.'+cf.WPethr3.value+'.'+cf.WPethr4.value;
    	}
    	else
    		cf.pppoe_localip.value = "0.0.0.0";
    
    if(cf.DNSAssign[1].checked)
    	{
    		if(checkIP(cf.DAddr1,cf.DAddr2,cf.DAddr3,cf.DAddr4,254)||(parseInt(cf.DAddr4.value)==0))
    			msg+= "Invalid Primary DNS Address, please enter again.\n";
    		if(cf.PDAddr1.value.length>0)
    			if(checkIP(cf.PDAddr1,cf.PDAddr2,cf.PDAddr3,cf.PDAddr4,254)||(parseInt(cf.PDAddr4.value)==0))
    				msg+= "Invalid Secondary DNS Address, please enter again.\n";
    	}
    
    if (duplicatepvcChk(vpi,vci))
    msg += "duplicate PVC found!\n";
    
    if (msg.length > 1)
    	{
    		alert(msg);
    		return false;
    	}
    
    cf.wan_dns1_pri.value = cf.DAddr1.value+'.'+cf.DAddr2.value+'.'+cf.DAddr3.value+'.'+cf.DAddr4.value;
    	cf.wan_dns1_sec.value = cf.PDAddr1.value+'.'+cf.PDAddr2.value+'.'+cf.PDAddr3.value+'.'+cf.PDAddr4.value;
    	cf.nowchoice.value = -1;
    return true;
    }
    
    function duplicatepvcChk(vpi, vci)
    {
    var cf = document.forms[0];
    var index = cf.adslChoice.selectedIndex;
    if (( index != 0) && (vpi == cf.atm0_vpi.value) && (vci == cf.atm0_vci.value) && (cf.wan0_dial.value == "1"))
    return true;
    if ((index != 1) && (vpi == cf.atm1_vpi.value) && (vci == cf.atm1_vci.value) && (cf.wan1_dial.value == "1"))
    return true;
    if ((index != 2) && (vpi == cf.atm2_vpi.value) && (vci == cf.atm2_vci.value) && (cf.wan2_dial.value == "1"))
    return true;
    if ((index != 3) && (vpi == cf.atm3_vpi.value) && (vci == cf.atm3_vci.value) && (cf.wan3_dial.value == "1"))
    return true;
    if ((index != 4) && (vpi == cf.atm4_vpi.value) && (vci == cf.atm4_vci.value) && (cf.wan4_dial.value == "1"))
    return true;
    if ((index != 5) && (vpi == cf.atm5_vpi.value) && (vci == cf.atm5_vci.value) && (cf.wan5_dial.value == "1"))
    return true;
    if ((index != 6) && (vpi == cf.atm6_vpi.value) && (vci == cf.atm6_vci.value) && (cf.wan6_dial.value == "1"))
    return true;
    if ((index != 7) && (vpi == cf.atm7_vpi.value) && (vci == cf.atm7_vci.value) && (cf.wan7_dial.value == "1"))
    return true;
    return false;
    }
    
    function resetPvc()
    {
    window.location.href="https://www.exploit-db.com/exploits/34149/BAS_mpppoe.htm";
    }
    
    function loadSettings(index)
    {
    var cf = document.forms[0];
    	var pppoe_localip;
    	var wan_dns1_pri;
    	var wan_dns1_sec;	
    	var tmp;
    	var wan_proto;
    var dod;
    
    if (index == 100)
    index = eval(cf.nowchoice.value);
    loadvpivci(index);
    wan_proto = all_wan_proto[index];
    
    if (all_pppoe_localip[index].length!=0)
    	{
    	pppoe_localip=all_pppoe_localip[index].split(".");
    	cf.WPethr1.value = pppoe_localip[0];
    	cf.WPethr2.value = pppoe_localip[1];
    	cf.WPethr3.value = pppoe_localip[2];
    	cf.WPethr4.value = pppoe_localip[3];
    }
    var wan_dns_sel = all_wan_dns_sel[index];
    if ( all_wan_dns1_pri[index].length!=0 )
    	{
    	wan_dns1_pri = all_wan_dns1_pri[index].split(".");
    	cf.DAddr1.value = wan_dns1_pri[0];
    		cf.DAddr2.value = wan_dns1_pri[1];
    		cf.DAddr3.value = wan_dns1_pri[2];
    		cf.DAddr4.value = wan_dns1_pri[3];
    }
    	if ( all_wan_dns1_sec[index].length!=0 )
    	{
    	wan_dns1_sec = all_wan_dns1_sec[index].split(".");
    	cf.PDAddr1.value = wan_dns1_sec[0];
    		cf.PDAddr2.value = wan_dns1_sec[1];
    		cf.PDAddr3.value = wan_dns1_sec[2];
    		cf.PDAddr4.value = wan_dns1_sec[3];
    }	
    cf.pppoe_idletime.value = all_pppoe_idletime[index];
    if (all_ppp_dod[index] == 2)
    cf.pppoe_idletime.disabled = true;
    else
    cf.pppoe_idletime.disabled = false;
    //if (all_pppoe_localip[index]=="0.0.0.0")
    	//	cf.WANAssign[0].checked = true;
    	//else
    	//	cf.WANAssign[1].checked = true;
    if (all_is_static_ip[index] == 1)//static ip
    cf.WANAssign[1].checked = true;
    else
    cf.WANAssign[0].checked = true;
    
    
    cf.DNSAssign[wan_dns_sel].checked = true;
    
    	if (all_wan_isbridge[index] == 1)
    cf.nat_enable[2].checked = true;
    else if (all_wan_nat[index] == 1)
    cf.nat_enable[0].checked = true;
    else
    cf.nat_enable[1].checked = true;
    
    cf.pppoe_username.value = all_pppoe_username[index];
    cf.pppoe_passwd.value = all_pppoe_passwd[index];
    cf.pppoe_servicename.value = all_pppoe_servicename[index];
    //water
    setIP();
    	setDNS();
    }
    
    function loadvpivci(index)
    {
    var cf = document.forms[0];
    var multiplex;
    var vpi;
    var vci;
    
    switch(index)
    {
    case 0:
    vpi=cf.atm0_vpi.value;
    vci=cf.atm0_vci.value;
    multiplex=cf.atm0_encap.value;
    break;
    case 1:
    vpi=cf.atm1_vpi.value;
    vci=cf.atm1_vci.value;
    multiplex=cf.atm1_encap.value;
    break;
    case 2:
    vpi=cf.atm2_vpi.value;
    vci=cf.atm2_vci.value;
    multiplex=cf.atm2_encap.value;
    break;
    case 3:
    vpi=cf.atm3_vpi.value;
    vci=cf.atm3_vci.value;
    multiplex=cf.atm3_encap.value;
    break;
    case 4:
    vpi=cf.atm4_vpi.value;
    vci=cf.atm4_vci.value;
    multiplex=cf.atm4_encap.value;
    break;
    case 5:
    vpi=cf.atm5_vpi.value;
    vci=cf.atm5_vci.value;
    multiplex=cf.atm5_encap.value;
    break;
    case 6:
    vpi=cf.atm6_vpi.value;
    vci=cf.atm6_vci.value;
    multiplex=cf.atm6_encap.value;
    break;
    case 7:
    vpi=cf.atm7_vpi.value;
    vci=cf.atm7_vci.value;
    multiplex=cf.atm7_encap.value;
    break;
    }
    var tmpvarhave = "";
    var tmpmux = "";
    var tmpvpi = "";
    var tmpvci = "";
    if (tmpvarhave == 1)
    {
    if (multiplex != tmpmux)
    cf.cfgChanged.value='1';
    if (vpi != tmpvpi)
    cf.cfgChanged.value='1';
    if (vci != tmpvci)
    cf.cfgChanged.value='1';
    
    multiplex = tmpmux;
    vpi = tmpvpi;
    vci = tmpvci;
    }
    
    if (multiplex == "LLC")
     	cf.dsl_multiplex.selectedIndex = 0;
    else 
    	cf.dsl_multiplex.selectedIndex = 1;
    cf.dsl_vpi.value=vpi;
    cf.dsl_vci.value=vci; 
    }
    
    function setCfgChanged()
    {
    var cf = document.forms[0];
    
    cf.cfgChanged.value='1';
    }
    
    function checkTest()
    {
    var cf = document.forms[0];
    var ret = checkData();
    var winoptions = "width=640,height=480,menubar=yes,toolbar=yes,status=yes,location=yes,resizable=yes";
    //var winoptions = "width=400,height=360,status=yes,resizable=yes";
    if ( ret == true)
    	{
    	if (cf.cfgChanged.value=='0')
    	{
    		//openDataSubWin('wtest.htm',winoptions);
    	//cf.nowchoice.value = 100;
    	//checkData();
    	//document.formname.submit();
    	var tmpstr = "pppoe_m.cgi?nowchoice=100" + "&nowproto=0";
    		location.href = tmpstr;
    	//return true;
    	}
    	else
    	{
    	cf.testpressed.value = '1';
    cf.nowchoice.value = -1;
    document.formname.submit();
    }
    }
    }
    
    </script>
    
    </head>
    
    <body bgcolor="#ffffff" onload="loadMultiWanInfo();loadSettings(100);loadcheck();goTestApply();">
    <form name="formname" method="POST" action="pppoe_m.cgi">
    <table border="0" cellpadding="0" cellspacing="3" width="99%">
    <tr>
    <td colspan="2"><h1>Basic Settings</h1></td>
    </tr>
    <tr>
    <td colspan="2">
    <select name="adslChoice" onChange="ChangeAdslChoice();" size="1">
    	<option value=0>WAN1</option>
    </select>
    </td>
    </tr>
    <!-- RULE 
    <tr>
    <td colspan="2" background="liteblue.gif" height="12"></td>
    </tr>
    <tr>
     <td nowrap width="50%">Multiplexing Method</TD>
     <td width="50%" align="right">
     <SELECT name="dsl_multiplex" size="1">
     <option value="LLC">LLC-BASED</option>
     <option value="VC">VC-BASED</option>
     </SELECT></TD>
    </TR>
    <TR>
    <td nowrap width="50%">VPI</td>
    <td nowrap width="50%" align="right"><input type="text" class="num" name="dsl_vpi" size="3" maxlength="3"></td>
    </tr>
    <TR>
    <td nowrap width="50%">VCI</td>
    <td nowrap width="50%" align="right"><input type="text" class="num" name="dsl_vci" size="5" maxlength="5"></td>
    </tr>
    -->
    <INPUT name=dsl_multiplex type=hidden value= "">
    <INPUT name=dsl_vpi type=hidden value= "">
    <INPUT name=dsl_vci type=hidden value= "">
    
    <tr><!-- RULE -->
    <td colspan="2" background="liteblue.gif" height="12"></td>
    </tr>
    <tr>
    	<td colspan="2">
    	<p><a href="javascript:loadhelp('BAS_mpppoe','question')" tabindex="-1"><b>Does Your Internet Connection Require A Login?</b></a></p></td>
    </tr>
    <tr>
    	<td colspan="2"><input type="radio" checked name="loginreq" value="pppoe" onClick="doTypeChange3(1);">
    	<a href="javascript:loadhelp('BAS_mpppoe','question')" tabindex="-1">Yes</a></td>
    </tr>
    <tr>
    	<td colspan="2"><input type="radio" name="loginreq" value="dhcp" onClick="doTypeChange3(0);">
    	<a href="javascript:loadhelp('BAS_mpppoe','question')" tabindex="-1">No</a></td>
    </tr>
    
    <tr>
     <td width="50%"><a href="javascript:loadhelp('BAS_mpppoe','isp')" tabindex="-1"><b>Encapsulation</b></a></td>
     <td width="50%" align="right"><select name="login_type" onChange="setServer()"><option>PPPoE (PPP over Ethernet)</option><!-- temp marked by Silver <option>PPPoA (PPP over ATM)</option>--></select></td>
    </tr>
    <tr><!-- RULE -->
    <td colspan="2" background="liteblue.gif" height="12"></td>
    <tr>
    	<td><a href="javascript:loadhelp('BAS_mpppoe','login')" tabindex="-1"><b>Login</b></a></td>
    	<td align="right"><input type="text" name="pppoe_username" size="15" maxlength="60" value="" onChange="setCfgChanged()"></td>
    </tr>
    <tr>
    	<td><a href="javascript:loadhelp('BAS_mpppoe','password')" tabindex="-1"><b>Password</b></a></td>
    	<td align="right"><input type="password" name="pppoe_passwd" size="15" maxlength="50" value="" onChange="setCfgChanged()"></td>
    </tr>
    
    <tr>
    	<td nowrap><a href="javascript:loadhelp('BAS_mpppoe','serv_name')" tabindex="-1"><b>Service Name</b></a> (If Required)</td>
    	<td align="right"><input type="text" name="pppoe_servicename" maxlength="63" size="15" value="" onChange="setCfgChanged()"></td>
    </tr>
    
    <tr>
    	<td nowrap><a href="javascript:loadhelp('BAS_mpppoe','idletime')" tabindex="-1"><b>Idle Timeout</b></a> (In Minutes)</td>
    	<td align="right"><input type="text" class="num" name="pppoe_idletime" size="3" maxlength="3" onChange="setCfgChanged()"></td>
    </tr>
    <tr><!-- RULE -->
    <td colspan="2" background="liteblue.gif" height="12"></td>
    </tr>
    <tr>
    	<td colspan="2"><a href="javascript:loadhelp('BAS_mpppoe','InternetIP')" tabindex="-1"><b>Internet IP Address</b></a></td>
    </tr>
    <tr>
    	<td colspan="2"><input type="radio" name="WANAssign" value="Dynamic" onClick="setIP()" onChange="setCfgChanged()">Get Dynamically From ISP</td>
    </tr>
    <tr>
    	<td nowrap><input type="radio" name="WANAssign" value="Fixed" onClick="setIP()" onChange="setCfgChanged()">Use Static IP Address</td>
    	<td align="right" class="num">
    	<input type="text" name="WPethr1" class="num" size="4" maxlength="3" onFocus="if(DisableFixedIP) this.blur()" onChange="setCfgChanged()">.
    	<input type="text" name="WPethr2" class="num" size="4" maxlength="3" onFocus="if(DisableFixedIP) this.blur()" onChange="setCfgChanged()">.
    	<input type="text" name="WPethr3" class="num" size="4" maxlength="3" onFocus="if(DisableFixedIP) this.blur()" onChange="setCfgChanged()">.
    	<input type="text" name="WPethr4" class="num" size="4" maxlength="3" onFocus="if(DisableFixedIP) this.blur()" onChange="setCfgChanged()"></td>
    </tr>
    <tr> <!-- RULE -->
     <td colspan="2" background="liteblue.gif" height="12"></td>
    </tr>
    
    <tr>
    	<td colspan="2"><a href="javascript:loadhelp('BAS_mpppoe','DNSaddress')" tabindex="-1"><b>Domain Name Server (DNS) Address </b></a></td>
    </tr>
    
    <tr>
    	<td colspan="2"><input type="radio" name="DNSAssign" value="0" onClick="setDNS()" onChange="setCfgChanged()"> Get Automatically From ISP</td>
    </tr>
    
    <tr>
    	<td colspan="2"><input type="radio" name="DNSAssign" value="1" onClick="setDNS()" onChange="setCfgChanged()"> Use These DNS Servers</td>
    </tr>
    
    <tr>
    		<td><img src="https://www.exploit-db.com/exploits/34149/spacer.gif" width="20" height="12" border="0">Primary DNS</td>
    		<td align="right" class="num">
    <input type="text" name="DAddr1" class="num" size="4" maxlength="3" onFocus="if(DisableFixedDNS) this.blur()" onChange="setCfgChanged()">.
    <input type="text" name="DAddr2" class="num" size="4" maxlength="3" onFocus="if(DisableFixedDNS) this.blur()" onChange="setCfgChanged()">.
    <input type="text" name="DAddr3" class="num" size="4" maxlength="3" onFocus="if(DisableFixedDNS) this.blur()" onChange="setCfgChanged()">.
    <input type="text" name="DAddr4" class="num" size="4" maxlength="3" onFocus="if(DisableFixedDNS) this.blur()" onChange="setCfgChanged()"></td>
    </tr>
    <tr>
    		<td><img src="https://www.exploit-db.com/exploits/34149/spacer.gif" width="20" height="12" border="0"><a href="javascript:loadhelp('BAS_mpppoe','DNSaddress')" tabindex="-1">Secondary DNS</a></td>
    		<td align="right" class="num">
    <input type="text" name="PDAddr1" class="num" size="4" maxlength="3" onFocus="if(DisableFixedDNS) this.blur()" onChange="setCfgChanged()">.
    <input type="text" name="PDAddr2" class="num" size="4" maxlength="3" onFocus="if(DisableFixedDNS) this.blur()" onChange="setCfgChanged()">.
    <input type="text" name="PDAddr3" class="num" size="4" maxlength="3" onFocus="if(DisableFixedDNS) this.blur()" onChange="setCfgChanged()">.
    <input type="text" name="PDAddr4" class="num" size="4" maxlength="3" onFocus="if(DisableFixedDNS) this.blur()" onChange="setCfgChanged()"></td>
    </tr>
    <tr> <!-- RULE -->
     <td colspan="2" background="liteblue.gif" height="12"></td>
    </tr>
    
    <tr>
    	<td colspan="2"><a href="javascript:loadhelp('BAS_mpppoe','nat')" tabindex="-1"><b>NAT (Network Address Translation) </b></a></td>
    </tr>
    
    <tr>
    	<td> </td>
    	<td align="right">
    <input type="radio" name="nat_enable" value="1" onChange="setCfgChanged()"> Enable
    <input type="radio" name="nat_enable" value="0" onChange="setCfgChanged()"> Disable
    <input type="radio" name="nat_enable" value="2" onChange="setCfgChanged()"> Bridge
    </td>
    </tr>
    <tr> <!-- RULE -->
     <td colspan="2" background="liteblue.gif" height="12"></td>
    </tr>
    
    <tr>
    <td colspan="2" align="center"><div ID="pppoebuttons" onmouseover="loadhelp('BAS_mpppoe','buttons')">
    	<input type="SUBMIT" name="apply" value="Apply" onClick="return checkData()">
    	<input type="BUTTON" name="Cancel" value="Cancel" onClick="resetPvc();">
    	<input type="BUTTON" name="Test" value="Test" onClick="checkTest();">
    	</div></td></tr>
    </table>
    <INPUT name=gui_mode type=hidden value= "1">
    <INPUT name=nowchoice type=hidden value= "0">
    <INPUT name=pppoe_localip type=hidden value= "">
    <INPUT name=wan_dns_sel type=hidden value= "">
    <INPUT name=wan_dns1_pri type=hidden value= "">
    <INPUT name=wan_dns1_sec type=hidden value= "">
    
    <INPUT name=atm0_vpi type=hidden value= "8">
    <INPUT name=atm0_vci type=hidden value= "48">
    <INPUT name=atm0_multiplex type=hidden value= "llcencaps">
    <INPUT name=atm0_encap type=hidden value= "LLC">
    <INPUT name=atm1_vpi type=hidden value= "0">
    <INPUT name=atm1_vci type=hidden value= "32">
    <INPUT name=atm1_multiplex type=hidden value= "llcencaps">
    <INPUT name=atm1_encap type=hidden value= "LLC">
    <INPUT name=atm2_vpi type=hidden value= "0">
    <INPUT name=atm2_vci type=hidden value= "33">
    <INPUT name=atm2_multiplex type=hidden value= "llcencaps">
    <INPUT name=atm2_encap type=hidden value= "LLC">
    <INPUT name=atm3_vpi type=hidden value= "0">
    <INPUT name=atm3_vci type=hidden value= "34">
    <INPUT name=atm3_multiplex type=hidden value= "llcencaps">
    <INPUT name=atm3_encap type=hidden value= "LLC">
    <INPUT name=atm4_vpi type=hidden value= "0">
    <INPUT name=atm4_vci type=hidden value= "35">
    <INPUT name=atm4_multiplex type=hidden value= "llcencaps">
    <INPUT name=atm4_encap type=hidden value= "LLC">
    <INPUT name=atm5_vpi type=hidden value= "0">
    <INPUT name=atm5_vci type=hidden value= "36">
    <INPUT name=atm5_multiplex type=hidden value= "llcencaps">
    <INPUT name=atm5_encap type=hidden value= "LLC">
    <INPUT name=atm6_vpi type=hidden value= "0">
    <INPUT name=atm6_vci type=hidden value= "37">
    <INPUT name=atm6_multiplex type=hidden value= "llcencaps">
    <INPUT name=atm6_encap type=hidden value= "LLC">
    <INPUT name=atm7_vpi type=hidden value= "0">
    <INPUT name=atm7_vci type=hidden value= "38">
    <INPUT name=atm7_multiplex type=hidden value= "llcencaps">
    <INPUT name=atm7_encap type=hidden value= "LLC">
    <input type="hidden" name="cfgChanged" value="0">
    <input type="hidden" name="testpressed" value="0">
    <input type="hidden" name="runtest" value="no">
    <INPUT name=wan0_dial type=hidden value= "1">
    <INPUT name=wan1_dial type=hidden value= "0">
    <INPUT name=wan2_dial type=hidden value= "0">
    <INPUT name=wan3_dial type=hidden value= "0">
    <INPUT name=wan4_dial type=hidden value= "0">
    <INPUT name=wan5_dial type=hidden value= "0">
    <INPUT name=wan6_dial type=hidden value= "0">
    <INPUT name=wan7_dial type=hidden value= "0">
    </form>
    <p></p>
    </body>
    
    </html>