﻿// Archivo JScript
function comprobar_email(emailStr)
{
	var emailPat=/^(.+)@(.+)$/
	var specialChars="\\(\\)<>@,;:\\\\\\\"\\.\\[\\]"
	var validChars="\[^\\s" + specialChars + "\]"
	var quotedUser="(\"[^\"]*\")"
	var ipDomainPat=/^\[(\d{1,3})\.(\d{1,3})\.(\d{1,3})\.(\d{1,3})\]$/
	var atom=validChars + '+'
	var word="(" + atom + "|" + quotedUser + ")"
	var userPat=new RegExp("^" + word + "(\\." + word + ")*$")
	var domainPat=new RegExp("^" + atom + "(\\." + atom +")*$")

	/* EMPEZAMOS BUSCANDO EL MODELO SIMPLE user@domain. */
	var matchArray=emailStr.match(emailPat)
	if (matchArray==null) {
	  /* DEMASIADOS O POCOS @'s; BASICAMENTE ESTA DIRECCION NO SE AJUSTA AL MODELO GENERAL. */
		alert("La dirección de email no es correcta")
		return false
	}
	
	var user=matchArray[1]
	var domain=matchArray[2]

	// MIRO SI EL NOMBRE DE USUARIO ES VALIDO
	if (user.match(userPat)==null) {
	    // EL NOMBRE DE USUARIO NO ES VALIDO
	    alert("La dirección de email no es correcta.")
	    return false
	}
	
	/* SI LA DIRECCION DE EMAIL ES UNA DIRECCION IP COMPRUEBO QUE LA DIRECCION IP ES VALIDA. */
	var IPArray=domain.match(ipDomainPat)
	if (IPArray!=null) {
	    // ES UNA DIRECCION IP
		  for (var i=1;i<=4;i++) {
		    if (IPArray[i]>255) {
		        alert("La dirección de email no es correcta")
				return false
		    }
	    }
	    return true
	}
	
	// EL DOMINIO ES UN NOMBRE SIMBOLICO
	var domainArray=domain.match(domainPat)
	if (domainArray==null) {
		alert("La dirección de email no es correcta.")
	    return false
	}
	
	/* AHORA NECESITAMOS DIVIDIR EL NOMBRE DEL DOMINIO. */
	var atomPat=new RegExp(atom,"g")
	var domArr=domain.match(atomPat)
	var len=domArr.length
	if (
			(	domArr[domArr.length-1].length<2
									|| 
	    		domArr[domArr.length-1].length>3
			) 
			&&
			(
				domArr[domArr.length-1] != 'info'
			)
			&&
			(
				domArr[domArr.length-1] != 'coop'
			)
			&&
			(
				domArr[domArr.length-1] != 'name'
			)
			&&
			(
				domArr[domArr.length-1] != 'museum'
			)
			&&
			(
				domArr[domArr.length-1] != 'aero'
			)			
		){
	   // LA DIRECCION DEBE ACABAR EN 2 O 3 LETRAS
		// o bien ser un .info
	   alert("La dirección de email no es correcta. TLD no válido")
	   return false
	}

	// TENEMOS QUE COMPROBAR QUE EXISTE EL NOMBRE DEL HOST PRECEDIENDO AL NOMBRE DEL DOMINIO.
	if (len<2) {
	   var errStr="La dirección de email no es correcta"
	   alert(errStr)
	   return false
	}

	// SI HEMOS LLEGADO HASTA AQUI TODO ES VALIDO
	return true;
	
}
