Actualización de Trabajo .
- Estruccturar adecuadamente mi proyecto en cuanto al HTML (Trabar lo más semantico que pueda).
- Ordenar y depurar los Archivos inecesarios con extensión .html y .js.
- Estructurar adecuadamente los archivos Chipher.js e index.js
- Crear clases coerentes y de manera descente para poder trabajr en CSS.
Fueron sobre todo en la parte visual y el numero de archivos trabajados.
Despues de varios dias y de un feed back de mis compañeras de que podia utilizar el conocimiento que tengo en base a mis experencias personales de que es lo que podria realizart lo que me llevo a lo siguiente:
Problemática: una aplicación web que pueda generar contraseñas seguras para poder acceder al correo electrónico. Ya que los usuarios no se sienten tranquilos con las aplicaciones o formularios donde les solicita ingresar su contraseña.
Objetivo: Realizar una página que ayude a los usuarios a cifrar una clave que ellos deseen y que se segura para que puedan ingresar a su correo electrónico.
Primordialmente mi pruducto fue pensado para personas que se encuentran en el hambito laboral, pero despues de un buen feedback en cuanto a mi propuesta y un formulario diseñado para obtener datos de mis posibles usrios que acontinuación anexo.
Llegue a la conclusion de cambiar el diseño de mi propuesta por un ambien mucho más practico y los usuarios destinados para utilizar lo amplie para Adolescentes y Adultos depues de analizar las graficas de resultados que obtuve con mi formulario.
[Resultados] (https://docs.google.com/forms/d/1QN1JIozMysQddXNS9awk0bGvQjHApiiIKXkGt0lDXx4/edit#responses)
Objetivo despues de Test: Realizar el cifrado una clave que ellos deseen y que se segura para que le permita reordar una clave segura para poder ingresar a su correo. El producto se diseño para resolver esta necesidad de manera inmediata con posibilidad de mejorar.
Muestro el diseño de los tres porototipos #Primer protoripo de baja fidelidad Maquetado1 Maquetado1 Maquetado1 Maquetado1 Maquetado1 Maquetado1
#Feedback #1
1.* Ser más especifica de para que?, en que pestaña ubicarme, como colocar el nombre del pasword de cada Iteración.
2.* Fue un poco intuitiva y clara.
3.* Crear instrucciones, botones de regreso más descriptivo.
#Primer prototipo mediana fidelidad en Marvel Protoripo de Marvel
#Feedback #2 1.* Recomendación de Karla quitar la parte de las contraseñas de mi idea original y prototipado.
2.* Recomendación de Jhon cambiar mi idea central y realizarlo deacuerdo a la funcionalidad ya que el solicitarle al usuario su contraseña personal no era buena idea.
#Segundo prototipo de baja fidelidad Maquetado2 Maquetado2 Maquetado2
#tercer prototipo de baja fidelidad Maquetado3 Maquetado3
1.- Bebes de entrar a la siguiente liga: [Archivo] (https://github.com/Pamela-C-Torres-Gtz/MEX-008-Cipher).
2.- Una vez que ingreses posicionate en la parte superior derecha de la pantalla y dale click en Fork.
3.- Una vez Forkeado debes dar click en el Boton de Clonar, esto para poner tener una copia en tu dispositivpo del repositorio y poder accerder al Proyecto completo.
4.- Una vez que tengas tu copia puedes entrar en la Carperte src en la cual se encuantra nuestro archivo principal para navegar en la pagina, que tiene como nombre "index.html.
5.- Una vez abierta en nuestro navegador nos aparece una pantalla donde apareceran las indicaciones de uso de la web asi como los botones de las opciones a utilizar.
6.- Puedes elegir cualquiera de las dos opciones "Cifrar" o "Decifrar". Recuerda que el objetivo de esta pagina es generar un cifrado de clave segura para que el surio la pueda utilizar para ingresar posterioremente a su cuenta de correo electronico. Teniendo obviamente la opción posterioremente de Desifrar estaclave o cambiarla.
###Consideraciones Tecnicas
1.- Como consideraciones el proyecto cumple con lo solicitado de manera funcional aunque a la vista el diseño es muy sencillo (el cual Sigue en desarrollo).
2.- Se realizaron Test unitarios de los cuales anexo iamgen:
[Resultado1] (/img/resultado-Git.jpg) [Resultado2] (/img/resultado tes unitarios.jpg)
3.- Tambien se llego al Haker Edition, debo mensionar que sin darme cuanta.
#=================================================================================================
Cifrar significa codificar. El cifrado César es uno de los primeros métodos de cifrado conocidos. El emperador romano Julio César lo usaba para enviar órdenes secretas a sus generales en los campos de batalla.
El cifrado césar es una de las técnicas más simples para cifrar un mensaje. Es un tipo de cifrado por sustitución, es decir que cada letra del texto original es reemplazada por otra que se encuentra un número fijo de posiciones (desplazamiento) más adelante en el mismo alfabeto.
Por ejemplo, si usamos un desplazamiento (offset) de 3 posiciones:
- La letra A se cifra como D.
- La palabra CASA se cifra como FDVD.
- Alfabeto sin cifrar: A B C D E F G H I J K L M N O P Q R S T U V W X Y Z
- Alfabeto cifrado: D E F G H I J K L M N O P Q R S T U V W X Y Z A B C
En la actualidad, todos los cifrados de sustitución simple se descifran con mucha facilidad y, aunque en la práctica no ofrecen mucha seguridad en la comunicación por sí mismos; el cifrado César sí puede formar parte de sistemas más complejos de codificación, como el cifrado Vigenère, e incluso tiene aplicación en el sistema ROT13.
¿Qué tengo que hacer exactamente? En este proyecto crearás la primera aplicación web del bootcamp. Servirá para que el usuario pueda cifrar y descifrar un texto indicando un desplazamiento específico de caracteres (offset).
La temática es libre. Tú debes pensar en qué situaciones de la vida real se necesitaría cifrar un mensaje y pensar en cómo debe ser esa experiencia de uso (qué pantallas, explicaciones, mensajes, colores, ¿marca?) etc. Algunas ideas de ejemplo:
- Crear claves seguras para el email.
- Encriptar/cifrar una tarjeta de crédito.
- Herramienta de mensajería interna de una organización de derechos humanos en una zona de conflicto.
- Mensajería secreta para parejas.
- Este proyecto se debe resolver de manera individual.
- El proyecto será entregado subiendo tu código a GitHub (commit/push) y la interfaz será desplegada usando GitHub pages. Si no sabes lo que es GitHub, no te preocupes, lo aprenderás durante este proyecto.
- Tiempo para completarlo: 2 semanas divididas en 2 sprints (1 entrega cada viernes)
En este proyecto aprenderás a construir una aplicación web que interactúe con el usuario a través del navegador y la lógica basada en esa interacción. Dicho en palabras sencillas, aprenderás a:
- Pintar elementos de formulario en la pantalla usando HTML y CSS.
- Permitir al usuario interactuar (eventos del DOM) y hacer algo cuando ocurran dichos eventos (cifrar/descifrar).
- Manipular strings (cadenas de texto).
- Usar control de flujo (bucles, condicionales, ...).
- Actualizar la pantalla con los resultados (manipular el DOM).
- Implementar funciones dada una descripción de su comportamiento.
- Verificar tu implementación con pruebas unitarias.
- Entender las necesidades del usuario y cómo proponer una solución.
- Organizar tu tiempo y priorizar tareas en un entorno de alta incertidumbre.
Usa este alfabeto simple (solamente mayúsculas y sin ñ):
- A B C D E F G H I J K L M N O P Q R S T U V W X Y Z
En el README.md, cuéntanos cómo pensaste en los usuarios y cuál fue tu proceso para definir el producto final a nivel de experiencia y de interfaz.
- Quiénes son los principales usuarios de producto.
- Cuáles son los objetivos de estos usuarios en relación con tu producto.
- Cómo crees que el producto que estás creando está resolviendo sus problemas.
La interfaz debe permitir al usuario:
- Elegir un desplazamiento (offset) indicando cuántas posiciones queremos que el cifrado desplace cada caracter.
- Insertar un mensaje (texto) que queremos cifrar.
- Ver el resultado del mensaje cifrado.
- Insertar un mensaje (texto) a descifrar.
- Ver el resultado del mensaje descifrado.
README.md
: debe explicar cómo descargar, instalar y ejecutar la aplicación así como una introducción a la aplicación, su funcionalidad y decisiones de diseño que tomaron.src/index.html
: este es el punto de entrada a tu aplicación. Este archivo debe contener tu markup (HTML) e incluir el CSS y JavaScript necesario.src/cipher.js
: acá debes implementar el objeto cipher, el cual debe estar exportado en el objeto global (window
). Este objeto (cipher
) debe contener dos métodos:cipher.encode(offset, string)
:offset
es el número de posiciones que queremos mover a la derecha en el alfabeto ystring
el mensaje (texto) que queremos cifrar.cipher.decode(offset, string)
:offset
es el número de posiciones que queremos mover a la izquierda en el alfabeto ystring
el mensaje (texto) que queremos descifrar.
src/index.js
: acá debes escuchar eventos del DOM, invocarcipher.encode()
ocipher.decode()
según sea necesario y actualizar el resultado en la UI.test/cipher.spec.js
: este archivo contiene algunos tests de ejemplo y acá tendrás que implementar los tests(pruebas ) paracipher.encode()
ycipher.decode()
.
Las secciones llamadas “Hacker Edition” son opcionales. Si terminaste con todo lo anterior y te queda tiempo, intenta completarlas. Así podrás profundizar y/o ejercitar más sobre los objetivos de aprendizaje del proyecto.
La descripción general de este proyecto no menciona qué pasaría con las letras minúsculas y otros caracteres (como espacios, puntuación, ñ, ...). El boilerplate incluye algunos tests (comentados al principio del archivo cipher.spec.js
) que puedes usar como punto de partida para implementar el soporte para estos casos.
Tampoco se menciona qué pasaría si el offset fuera negativo. Como parte del hacker edition te invitamos a explorar también este caso por tu cuenta.
Por otra parte, complementando la definición de tu producto, puedes plantear un modelo de negocio para tu aplicación, en el que se explique y justifique cómo podrías obtener ingresos a través de ella.
La lógica del proyecto debe estar implementada completamente en JavaScript (ES6). En este proyecto NO está permitido usar librerías o frameworks, sólo vanilla JavaScript.
No se debe utilizar la pseudo-variable this
.
Los tests unitarios deben cubrir un mínimo del 70% de statements, functions
y lines, y un mínimo del 50% de branches. El boilerplate ya contiene el
setup y configuración necesaria para ejecutar los tests (pruebas) así como code
coverage para ver el nivel de cobertura de los tests usando el comando npm run test
.
El boilerplate incluye tests (pruebas) de ejemplo como punto de partida.
Para comenzar este proyecto tendrás que hacer un fork y clonar este repositorio que contiene el boilerplate.
El boilerplate contiene una estructura de archivos como punto de partida así como toda la configuración de dependencias y tests de ejemplo:
./
├── .editorconfig
├── .eslintrc
├── .gitignore
├── README.md
├── package.json
├── src
│ ├── cipher.js
│ ├── index.html
│ ├── index.js
│ └── style.css
└── test
├── cipher.spec.js
├── headless.js
└── index.html
El boilerplate incluye tareas que ejecutan eslint y
htmlhint para verificar el HTML
y
JavaScript
con respecto a una guías de estilos. Ambas tareas se ejecutan
automáticamente antes de ejecutar las pruebas (tests) cuando usamos el comando
npm run test
. En el caso de JavaScript
estamos usando un archivo de
configuración de eslint
que se llama .eslintrc
que contiene un mínimo de
información sobre: qué version de JavaScript/ECMAScript, el
entorno (browser en este caso) y las reglas recomendadas ("eslint:recommended"
).
En cuanto a reglas/guías de estilo en sí,
usaremos las recomendaciones por defecto de tanto eslint
como htmlhint
.
Te aconsejamos revisar la rúbrica para ver la descripción detallada de cada habilidad y cada nivel. Esta es una lista de todas las habilidades involucradas en este proyecto y que evaluaremos cuando lo completes:
Característica/Habilidad |
---|
Completitud |
Habilidad |
---|
Planificación y organización |
Autoaprendizaje |
Solución de problemas |
Dar y recibir feedback |
Adaptabilidad |
Trabajo en equipo |
Comunicación eficaz |
Presentaciones |
Habilidad |
---|
Computer Science (CS) |
Lógica |
Arquitectura |
System Control Managmen(SCM)t |
Git |
GitHub |
JavaScript |
Estilo |
Nomenclatura/semántica |
Funciones/modularidad |
Tests |
HTML |
Validación |
Estilo |
Semántica |
CSS |
Dont Repeat YourSelf (DRY) |
Habilidad |
---|
User Centricity |
- Antes que nada, asegúrate de tener un 📝 editor de texto en condiciones, algo como Atom, Visual Code, Sublime Text o cualquier otro de tu preferencia.
- Para ejecutar los comandos a continuación necesitarás una 🐚
UNIX Shell,
que es un programita que interpreta líneas de comando (command-line
interpreter) así como tener git
instalado. Si usas un sistema operativo "UNIX-like", como GNU/Linux o MacOS,
ya tienes una shell (terminal) instalada por defecto (y probablemente
git
también). Si usas Windows puedes usar Git bash, aunque recomendaría que consideres probar 🐧 GNU/Linux como tu Sistema Operativo. - Haz tu propio 🍴 fork de este repositorio de tu cohort, tus coaches te compartirán un link a un repositorio y te darán acceso de lectura en ese repo.
- ⬇️ Clona tu fork a tu computadora (copia local).
- 📦 Instala las dependencias del proyecto con el comando
npm install
. Esto asume que has instalado Node.js (que incluye npm). - Si todo ha ido bien, deberías poder ejecutar las 🚥
pruebas unitarias (unit tests) con el comando
npm run test
. - A codear se ha dicho! 🚀
A continuación un video de Michelle que te lleva a través de la fórmula matemática del Cifrado César y un par de cosas más que debes saber para resolver este proyecto. ¡Escúchala con detenimiento y sigue sus consejos! :)
Diseño de experiencia de usuario (User Experience Design):
- Ideación
- Prototipado (sketching)
- Pruebas con usuarios (User Testing) e Iteración
Desarrollo Front-end:
- Valores
- Tipos
- Variables
- Control de flujo
- Pruebas nitarias (Unit test)
- Aprende más sobre
charCodeAt()
- Aprende más sobre
String.fromCharCode()
- Aprende más sobre
ASCII
- Documentación de NPM
Herramientas:
- GitHub y GitHub Pages.
- Guía de Scrum: solamente para comenzar a entender cómo organizar tu trabajo.
Esta sección está para ayudarte a llevar un control de lo que vas completando.
-
README.md
incluye info sobre proceso y decisiones de diseño. -
README.md
explica claramente quiénes son los usuarios y su relación con el producto. -
README.md
explica claramente cómo el producto soluciona los problemas/necesidades de los usuarios. - Usa VanillaJS.
- No utiliza
this
. - Implementa
cipher.encode
. - Implementa
cipher.decode
. - Pasa linter con configuración provista.
- Pasa pruebas unitarias.
- Pruebas unitarias cubren 70% de statements, functions y lines, y un mínimo del 50% de branches.
- Interfaz permite elegir el
offset
o desplazamiento a usar en el cifrado/descifrado. - Interfaz permite escribir un texto para ser cifrado.
- Interfaz muestra el resultado del cifrado correctamente.
- Interfaz permite escribir un texto para ser descifrado.
- Interfaz muestra el resultado del descifrado correctamente.
- Cifra/descifra minúsculas
- Cifra/descifra otros caracteres (espacios, puntuación,
ñ
,á
, ...) - Permite usar un
offset
negativo. - Modelo de negocio.