Browse Source

Splitted READMEs

root 8 years ago
parent
commit
f19e1aa5b8
3 changed files with 734 additions and 734 deletions
  1. 362
    0
      README-en.md
  2. 370
    0
      README-es.md
  3. 2
    734
      README.md

+ 362
- 0
README-en.md View File

@@ -0,0 +1,362 @@
1
+
2
+# Decision Structures - Password Strength
3
+
4
+![main1.png](images/main1.png)
5
+![main2.png](images/main2.png)
6
+![main3.png](images/main3.png)
7
+
8
+Commonly, when solving a problem, there are one or more steps that depend on whether certain conditions are met. Computer programs are built to solve problems, so they should have a structure that allows them to make decisions. In C++ the decision instructions (or conditionals) are structured using  `if`, `else`, `else if` or `switch`. Relational expressions and logical operators are common when handling decision structures. In today's laboratory experience you will practice the use of some of these structures by completing the design of an application that determines the strength of a password.
9
+
10
+## Objectives:
11
+
12
+1. Use relational expressions and select adequate logical operators to make decisions.
13
+2. Apply decision structures.
14
+
15
+
16
+##Pre-Lab:
17
+
18
+Before you get to the laboratory you should have:
19
+
20
+1. Reviewed the following concepts:
21
+
22
+    a. Logical operators.
23
+
24
+    b. `if`, `else`, `else if`.
25
+
26
+2. Reviewed the use of objects of the `string` class and its `length()` method.
27
+
28
+3. Studied the concepts and instructions for this laboratory session.
29
+
30
+4. Taken the Pre-Lab quiz in Moodle.
31
+
32
+---
33
+
34
+---
35
+
36
+## Password strength
37
+
38
+Using strong passwords is essential to securing information. A password is considered strong if it is not cost-effective for a hacker to try and guess it using different methods or brute force. For example, a password that consists of a simple dictionary word, without digits, symbols or uppercase letters, is so easy to decipher that even a caveman could do it.
39
+
40
+Since an official system to measure password strength doesn't exist, we will use formulas created by the passwordmeter to evaluate the general strength of a given password [1]. We recommend that you play around a bit with the application in http://passwordmeter.com so that you understand how the application you will be implementing should behave. The strength of the password will be quantified by adding points for using good techniques of password selection (like using symbols and letters), and subtracting points for using bad habits (like only using lowercase letters or consecutive symbols of the same type).
41
+
42
+The following tables review the added and subtracted values for various criteria in passwords:
43
+
44
+
45
+### Assigning points to a password
46
+
47
+#### Adding Points:
48
+
49
+---
50
+
51
+
52
+
53
+|      | Category                        | Points                                   | Notes                                                |
54
+| :--- | :-------------------------------- | :-------------------------------------: | ----------------------------------------------------: |
55
+| 1.   | Number of characters             | $$4\left(len\right)$$                                 | $$len$$ is the length of the password                        |
56
+| 2.   | Uppercase letters                | ![addUpper.png](images/small/addUpper.png) | $$n$$ is the number of uppercase letters                |
57
+| 3.   | Lowercase letters                | ![addLower.png](images/small/addLower.png)  | $$n$$ is the number of lowercase letters                |
58
+| 4.   | Digits                          |  ![addDigits.png](images/small/addDigits.png) | $$n$$ is the number of digits                          |
59
+| 5.   | Symbols                        | $$6n$$     | $$n$$ is the number of symbols                       |
60
+| 6.   | Digits or symbols in the middle   | $$2n$$                                    | $$n$$ is the number of digits or symbols in the middle   |
61
+| 7.   | Requisites                       | ![criteria.png](images/small/criteria.png)                              | $$n$$ is the number of criteria that are met        |
62
+
63
+**Table 1.** Positive criteria for password strength.
64
+
65
+---
66
+
67
+What follows are some additional details and examples for the criteria of **adding points**.
68
+
69
+1. **Number of characters**: this is the simplestcriteria. The score will be $$4$$ times the length of the password. For example, `"ab453"` has a count of $$5$$ and a score of $$4 \cdot 5 = 20$$.
70
+
71
+2. **Uppercase letters**: the score is $$2 \left(len - n \right)$$ if the password consists of a mix of uppercase letters **AND** at least another type of character (lowercase, digits, symbols). If not, the score is $$0$$. For example,
72
+
73
+  a. the score for `"ab453"` would be $$0$$ since it doesn't have uppercase letters (the count is also $$0$$).
74
+
75
+  b. the score for `"ALGO"` would be $$0$$ since it **only** has uppercase letters (the count is $$4$$).
76
+
77
+  c. the score for `"SANC8in"` would be $$2  \left(7-4\right) = 6$$ since the password has a length of $$7$$, has $$4$$ uppercase letters, and contains characters of another type (the count is $$4$$).
78
+
79
+3. **Lowercase letters**: the score is $$2 \left(len - n\right)$$ if the password is a mix of lowercase letters **AND** at least another type of character (uppercase, digits, symbols). If not, the score is $$0$$. For example,
80
+
81
+  a. the score for `"ab453"` would be $$2 \left(5-2\right) = 6$$ because the password has a length of$$5$$, contains $$2$$ lowercase letters, and contains characters of another type. The count is $$2$$.
82
+
83
+  b. the score for `"ALGO"` would be $$0$$ because it doesn't have lowercase letters. The count is $$0$$.
84
+
85
+  c. the score for `"sancochin"`  would be $$0$$ because it contains **only** lowercase letters. The count is $$9$$.
86
+
87
+4. **Digits**: the score is $4n$ if the password consists of a mix of digits **AND** at least another type of character (lowercase, uppercase, symbols). If not, the score is $$0$$. For example,
88
+
89
+  a. the score for `"ab453"` would be  $$4 \cdot 3 = 12$$ because the password contains $$3$$ digits and contains characters of another type.
90
+
91
+  b. the score for `"ALGO"` would be $$0$$ because it doesn't have digits.
92
+
93
+  c. the score for `801145555` would be $$0$$ because it contains **only** digits.
94
+
95
+5. **Symbols** The score is $$6n$$ if the password contains $$n$$ symbols. Otherwise, the score is $$0$$. For example,
96
+
97
+  a. the score for `"ab453"` would be $$0$$ because it does not contain symbols.
98
+
99
+  b. the score for `"ALGO!!"` would be $$6 \cdot 2$$ because it contains $$2$$ symbols and contains other types of characters.
100
+
101
+  c. the score for `”---><&&”` would be $$6 \cdot 7 = 42$$ because it contains $$7$$ symbols. Note that in the case of symbols, points are given even when there aren't other types of characters.
102
+
103
+6. **Digits or symbols in the middle** The score is $$2n$$ if the password contains symbols or digits that are not in the first or last position. For example,
104
+
105
+  a. the score for `"ab453"` would be $$2 \cdot2 = 4$$ because it contains 2 digits that are not in the first or last position, these are `4` and `5`.
106
+
107
+  b. the score for `"ALGO!"` would be $$0$$ because it does not contain digits or symbols in the middle, the only symbol is in the last position.
108
+
109
+  c. the score for `S&c8i7o!` would be $$2 \cdot 3 = 6$$ because it contains $$3$$ symbols or digits in the middle, these are `&`, 8`, and `7`.
110
+
111
+7. **Requisites**: The score is $$2n$$ only if the length criteria **AND** 3 or 4 of the other criteria are met, where $$n$$ is the number of *criteria* that are met. The criteria are:
112
+
113
+  a. The password must contain 8 or more characters of length.
114
+
115
+  b. Contain:
116
+    - Uppercase letters
117
+    - Lowercase letters
118
+    - Numbers
119
+    - Symbols
120
+
121
+Each of the items listed in part b. count as one individual criteria. For example,
122
+
123
+  a. the score for `"ab453"` would be $$0$$ because the criteria for length is not met.
124
+
125
+  b. the score for `"abABCDEF"` would be $$0$$ because, despite the fact that the length criteria is met, only 2 of the 4 other criteria are met (uppercase and lowercase letters).
126
+
127
+  c. the score for `"abAB99!!"` would be $$2 \cdot 5 = 10$$ because the length criteria and the other 4 criteria are met.
128
+
129
+
130
+#### Subtracting points
131
+
132
+---
133
+
134
+|      | Category                         | Points                                   | Notes                                                                  |
135
+| :--- | :-------------------------------- | :-------------------------------------: | ----------------------------------------------------:                   |
136
+| 1.   | Only letters                       |![subsLetters.png](images/small/subsLetters.png)    | $$len$$ is the length of the password                                          |
137
+| 2.   | Only digits                      | ![subsDigits.png](images/small/subsDigits.png)    | $$len$$ is the length of the password                                           |
138
+| 3.   | Consecutive uppercase letters    | $$-2n$$                                   | $$n$$ is the number of uppercase letters that follow another uppercase letter |
139
+| 4.   | Consecutive lowercase letters   | $$-2n$$                                   | $$n$$ is the number of lowercase letters that follow another lowercase letter                                                                     |
140
+| 5.   | Consecutive digits             | $$-2n$$                                   | $$n$$ is the number of digits that follow another digit                     |
141
+
142
+
143
+**Table 2.** Negative criteria for password strength.
144
+
145
+---
146
+
147
+The following are additional details and examples of the criteria for **subtracting points**.
148
+
149
+1. **Only letters**: The score is $$-len$$ for a password that consists of letters only, otherwise it is $$0$$. For example,
150
+
151
+  a. the score for `"ab453"` would be $$0$$ since it contains letters and numbers.
152
+
153
+  b. the score for `"Barrunto"` would be $$-8$$ since it only contains letters and its length is $$8$$.
154
+
155
+2. **Only digits**: The score is $$-len$$ for a password that consists of digits only, otherwise it is $$0$$. For example,
156
+
157
+  a. the score for `"ab453"` would be $$0$$ since it contains only letters and numbers.
158
+
159
+  b. the score for `”987987987”` would be $$-9$$ since it contains only digits and its length is $$9$$.
160
+
161
+3. **Consecutive uppercase letters**: The score is $$-2n$$ where $$n$$ is the number of uppercase letters that follow another uppercase letter. For example,
162
+
163
+  a. the score for `"DB453"` would be $$-2 \cdot 1 = -2$$ since it only contains one uppercase letter (`B`) that follows another uppercase letter.
164
+
165
+  b. the score for `"TNS1PBMA"` would be $$-2 \cdot 5 = -10$$ since it contains 5 uppercase letters (`N`, `S`, `B`, `M`, `A`) that follow another uppercase letter.
166
+
167
+4. **Consecutive lowercase letters**: The same as for criteria #3 but for lowercase letters.
168
+
169
+5. **Consecutive digits**: The same as for criteria #3 but for digits.
170
+
171
+
172
+---
173
+
174
+---
175
+
176
+!INCLUDE "../../eip-diagnostic/password-strength/en/diag-password-strength-01.html"
177
+
178
+!INCLUDE "../../eip-diagnostic/password-strength/en/diag-password-strength-02.html"
179
+
180
+!INCLUDE "../../eip-diagnostic/password-strength/en/diag-password-strength-03.html"
181
+
182
+!INCLUDE "../../eip-diagnostic/password-strength/en/diag-password-strength-04.html"
183
+
184
+!INCLUDE "../../eip-diagnostic/password-strength/en/diag-password-strength-05.html"
185
+
186
+---
187
+
188
+---
189
+
190
+## Laboratory session:
191
+
192
+In this laboratory session you will practice the use of mathematical expressions and conditional structures to compute the score for the strength of a password combining the points for the individual criteria.
193
+
194
+Your task is to complete the design of the application to measure the strength of a password. When done, you will obtain a simplified version of the application in http://www.passwordmeter.com/. Since there isn't an official system to measure passwords, the formulas created by "passwordmeter" will be used to evaluate the general strength of a given password. The application will allow users to enter a password and calculate its strength using a series of rules.
195
+
196
+The strength of the password will be quantified by adding points for using good password selection techniques (like combining symbols and letters) and subtracting points for using bad habits (like using only uppercase letters or consecutive symbols of the same type). Your program will analyze the password given by the user and use the criteria in the tables presented above to compute a score for the password's strength.
197
+
198
+Once the application is complete, it will show a window where, as the password characters are entered, the partial score will be displayed. This graphical interface will offer the user a way to improve his password and correct typical weak password habits.
199
+
200
+
201
+
202
+
203
+### Exercise 1: Familiarize yourself with the pre-defined functions
204
+
205
+The first step in this laboratory experience is to familiarize yourself with the functions that are pre-defined in the code.  You will call these functions as part of your own code to compute the score of the various password strength criteria.
206
+
207
+**Instructions**
208
+
209
+1. Load the project `PassworStrength` onto Qt by double clicking the file `PasswordStrength.pro` in the directory `Documents/eip/Conditionals-PasswordStrength` of your computer. You can also go to `http://bitbucket.org/eip-uprrp/conditionals-passwordstrength` to download the folder `Conditionals-PasswordStrength` to your computer.
210
+
211
+2. Configure the project. The project consists of several files. **You will only write code in the file  `readpassword.cpp`. You should not make any changes in the other files.** Despite this, you should familiarize yourself with the functions that are already defined in them, since you will be using some of them to create your code.
212
+
213
+  * `psfunctions.cpp` : contains the implementations of some of the functions that will invoke in your program to calculate the score for the password's strength. **You do not have to change anything in this file or in the file `psfunctions.h`**. Simply invoke the functions as necessary from the `readPass` function in the `readpassword.cpp` file. Note that the function names tell you what the functions do.
214
+
215
+  * `psfunctions.h` : contains the prototypes for the functions defined in `psfunctions.cpp`.
216
+
217
+
218
+### Exercise 2: Understand the functions to update the user's graphical interface.
219
+
220
+In the laboratory exercise you will write code to calculate the score associated to each one of the criteria in the tables for adding and subtracting points shown above. These scores should be updated in the user's graphical interface that is shown in Figure 1.
221
+
222
+---
223
+
224
+![interfaceGrafica.png](images/interfaceGrafica.png)
225
+
226
+**Figure 1.** User graphical interface for *Password strength* project.
227
+
228
+---
229
+
230
+There are predefined functions that update the graphical interface. For the application to work properly, each time that your code computes the score that is given for each criteria you should invoke the function to update that particular criteria in the graphical interface. The functions to update the criteria have the following syntax:
231
+
232
+
233
+  ```
234
+  void setCRITERIA(int count, int score) ;
235
+  ```
236
+
237
+  where CRITERIA should be replaced by the criteria that is being evaluated. Observe that the function requires two arguments: the **count** that is the amount of characters that meet the criteria and the **score** that is the calculation that you will implement following the tables presented above. For example,
238
+
239
+  ```
240
+  count = pass.length() ;
241
+  score = 4 * count ;
242
+  setNumberOfCharacters(count, score);
243
+  totalScore += score ;
244
+
245
+  ```
246
+
247
+  In the above code `count` contains the number of characters in the password, `score` contains the computation for the score of the criteria for the number of characters, and `setNumberOfCharacters(count, score);` invokes the function to update the corresponding information for the criteria "Number of characters" in the graphical interface.
248
+
249
+  The functions to update the graphical interface are:
250
+    ```
251
+    // To update the password's length.
252
+    void setNumberOfCharacters(int count, int score) ;  
253
+
254
+    // For adding points
255
+
256
+    // To update the uppercase characters.
257
+    void setUpperCharacters(int count, int score) ;
258
+
259
+    // To update the lowercase characters.
260
+    void setLowerCharacters(int count, int score) ;
261
+
262
+    // To update the characters that are digits.
263
+    void setDigits(int count, int score) ;
264
+
265
+    // To update the characters that are symbols.
266
+    void setSymbols(int count, int score) ;
267
+
268
+    // To update the digits or symbols in the middle
269
+    void setMiddleDigitsOrSymbols(int count, int score) ;
270
+
271
+    // To update the criterium of the requisites
272
+    void setRequirements(int count, int score) ;
273
+
274
+    // For subtracting points
275
+
276
+    // To update the criterium of only letters.
277
+    void setLettersOnly(int count, int score) ;
278
+
279
+    // To update the criterium of only digits.
280
+    void setDigitsOnly(int count, int score) ;
281
+
282
+    // To update the criterium of consecutive uppercase letters.
283
+    void setConsecutiveUpper(int count, int score) ;
284
+
285
+    // To update the criterium of consecutive lowercase letters.
286
+    void setConsecutiveLower(int count, int score) ;
287
+
288
+    // To update the criterium of consecutive digits.
289
+    void setConsecutiveDigits(int count, int score) ;
290
+    ```
291
+
292
+
293
+
294
+### Exercise 3: Compute the score for the criteria and the total score for the password
295
+
296
+The code that we're providing you contains the functions that compute the count for the majority of the criteria and whose names reflect what they do and what the function returns. For example, `countUppercase`, return the number of characters that are uppercase letters.
297
+
298
+[Here](http://ccom.uprrp.edu/~rarce/ccom3033f14/documentation/passwordStrengthCL/psfunctions_8cpp.html) is a list and description of the functions.
299
+
300
+Your task is to use mathematical expressions and decision structures for the individual criteria scores and combine them to compute the total score for the password's strength.
301
+
302
+**Example 1:**
303
+
304
+---
305
+
306
+![ventanaCaba77o.png](images/ventanaCaba77o.png)
307
+
308
+**Figure 2.** Window with the report for the password `caba77o`.
309
+
310
+---
311
+
312
+
313
+
314
+**Example 2:**
315
+
316
+---
317
+
318
+![ventanaS1nf@nia!.png](images/ventanaS1nf@nia!.png)
319
+
320
+**Figure 3.** Window with the report for the password `S1nf@nia!`.
321
+
322
+---
323
+
324
+In Example 2, the number of **requisites** is 5 because `"S1nf@nia!"` meets the criteria for length and also contains uppercase letters, lowercase letters, numbers and symbols. Therefore, the score for the number of requisites is $2 \cdot 5 =10$.
325
+
326
+In the project's code you will find examples of how to calculate the first two positive criteria: the number of characters in the password and the numbers of uppercase letters. You can compile and execute the example so you can see the working interface with these two criteria. Part of your task is to add the code to compute the score for the remaining criteria. Remember that you should accumulate the total score and invoke the functions to update the graphical interface.
327
+
328
+
329
+### Exercise 4: Determine and display the password's strength
330
+
331
+The password is entered in the top section of the graphical interface. The user will input the password in the top section of the graphical interface. Below appears the *report* that contains the different criteria, the count for each criteria, and the individual score for the criteria. This report will be updated as the user inputs the password's characters. The total score will be the sum of all of the points (addition and subtraction) of the individual criteria.
332
+
333
+Based on the total score, the program will classify the password's strength as follows:
334
+
335
+|   Total score   |  Strength   |
336
+|-----------------|-------------|
337
+| [0,20)          | Very weak   |
338
+| [20,40)         | Weak        |
339
+| [40,60)         | Good        |
340
+| [60,80)         | Strong      |
341
+| [80,100]        | Very strong |
342
+
343
+
344
+The provided code already invokes the `strengthDisplay` function with the strength calculated and the total score to update the classification, and the bar that indicates the password's strength in the graphical interface.
345
+
346
+---
347
+
348
+---
349
+
350
+## Deliverables
351
+
352
+Use "Deliverables" in Moodle to upload the `readpassword.cpp` file that contains the code with the computation for the score of the individual criteria, the final score, the function calls to update the graphical interface, the password's classification and the display functions. Remember to use good programming techniques, include the name of the programmers involved, and to document your program.
353
+
354
+
355
+
356
+---
357
+
358
+---
359
+
360
+## References
361
+
362
+[1] Passwordmeter, http://www.passwordmeter.com/

+ 370
- 0
README-es.md View File

@@ -0,0 +1,370 @@
1
+
2
+# Estructuras de decisión - Fortaleza de contraseñas
3
+
4
+![main1.png](images/main1.png)
5
+![main2.png](images/main2.png)
6
+![main3.png](images/main3.png)
7
+
8
+
9
+
10
+En casi todas las instancias en que queremos resolver un problema hay una o más opciones que dependen  de si se cumplen o no ciertas condiciones. Los programas de computadoras se construyen para resolver problemas y, por lo tanto, deben tener una estructura que permita tomar decisiones. En C++ las  instrucciones de decisión (o condicionales) se estructuran utilizando `if`, `else`, `else if` o `switch`. Muchas veces el uso de estas estructuras también envuelve el uso de expresiones de relación y operadores lógicos. En la experiencia de laboratorio de hoy practicarás el uso de algunas  estructuras de decisión completando el diseño de una aplicación que determina la fortaleza de  una contraseña de acceso ("password").
11
+
12
+## Objetivos:
13
+
14
+1.  Utilizar expresiones relacionales y seleccionar operadores lógicos adecuados para la toma de decisiones.
15
+2. Aplicar estructuras de decisión.
16
+
17
+
18
+## Pre-Lab:
19
+
20
+Antes de llegar al laboratorio debes:
21
+
22
+1. Haber repasado los siguientes conceptos:
23
+
24
+    a. operadores lógicos
25
+
26
+    b. `if`, `else`, `else if`.
27
+
28
+2. Haber repasado el uso de objetos de la clase `string` y su método `length()`.
29
+
30
+3. Haber estudiado los conceptos e instrucciones para la sesión de laboratorio.
31
+
32
+4. Haber tomado el quiz Pre-Lab que se encuentra en Moodle.
33
+
34
+
35
+---
36
+
37
+---
38
+
39
+## Fortaleza de contraseñas de acceso
40
+
41
+Utilizar contraseñas de acceso resistentes es esencial para mantener los datos seguros en los sistemas de información. Una contraseña se considera resistente o fuerte ("strong") si resulta costo-inefectivo para el "pirata informático" ("hacker") emplear tiempo tratando de adivinarla usando contraseñas ingenuas o fuerza bruta. Por ejemplo, una contraseña que consiste de una palabra simple del diccionario, sin números, símbolos o letras mayúsculas, es tan fácil de descifrar que hasta "un cavernícola puede hacerlo".
42
+
43
+Como no existe un sistema oficial para medir las contraseñas, utilizaremos fórmulas creadas por el "passwordmeter"  para evaluar la fortaleza general de una contraseña dada [1]. Te recomendamos que juegues un poco con la aplicación en http://passwordmeter.com para que entiendas cómo debe comportarse la aplicación que estarás implementando en esta experiencia de laboratorio. La fortaleza de la contraseña se cuantificará otorgando puntos por utilizar "buenas" técnicas de selección de contraseñas (como utilizar mezclas de símbolos y letras) y restando puntos por utilizar "malos" hábitos en las contraseñas (como utilizar solo letras minúsculas o símbolos consecutivos de un mismo tipo).
44
+
45
+Las siguientes tablas resumen los valores añadidos y sustraídos para varias características en las contraseñas.
46
+
47
+
48
+
49
+### Asignando puntuación a las contraseñas
50
+
51
+#### Sumando puntos
52
+
53
+---
54
+
55
+|      | Categoría                        | Puntos                                   | Notas                                                |
56
+| :--- | :-------------------------------- | :-------------------------------------: | ----------------------------------------------------: |
57
+| 1.   | Número de caracteres             | $$4\left(len\right)$$                                 | $$len$$ es el largo de la contraseña                        |
58
+| 2.   | Letras mayúsculas                | ![sumaMayus.png](images/small/sumaMayus.png)| $$n$$ es el número de letras mayúsculas                |
59
+| 3.   | Letras minúsculas                | ![sumaMin.png](images/small/sumaMin.png) | $$n$$ es el número de letras minúsculas                |
60
+| 4.   | Dígitos                          |  ![sumaDigitos.png](images/small/sumaDigitos.png) | $$n$$ es el número de dígitos                          |
61
+| 5.   | Símbolos                         | $$6n$$     | $$n$$ es el número de símbolos                         |
62
+| 6.   | Dígitos o símbolos en el medio   | $$2n$$                                   | $$n$$ es el número de dígitos y símbolos en el medio   |
63
+| 7.   | Requisitos                       | ![criterios.png](images/small/criterios.png)                              | $$n$$ es el número de criterios que se cumplen        |
64
+
65
+**Tabla 1.** Criterios positivos para  la fortaleza de la contraseña.
66
+
67
+---
68
+
69
+Lo que sigue son algunos detalles adicionales y ejemplos de los criterios para **sumas**.
70
+
71
+1. **Número de caracteres**: este es el criterio más simple. La puntuación es $$4$$ veces el largo de la contraseña. Por ejemplo, `"ab453"` tiene un conteo de $$5$$ y puntuación de $$4 \cdot 5= 20$$.
72
+
73
+2. **Letras mayúsculas** La puntuación es $$2 \left(len - n \right)$$ si la contraseña consiste de una mezcla de letras mayúsculas **Y** al menos otro tipo de caracter (minúscula, dígitos, símbolos). De lo contrario, la puntuación es $$0$$. Por ejemplo,
74
+
75
+    a. la puntuación para `"ab453"` sería $$0$$ ya que no tiene letras mayúsculas (el conteo también es $$0$$)
76
+
77
+    b. la puntuación para `"ALGO"` sería $$0$$ porque **solo** contiene letras mayúsculas (el conteo es $$4$$).
78
+
79
+    c. la puntuación para `"SANC8in"` sería $$2  \left(7-4\right) = 6$$ porque la contraseña es de largo $$7$$, contiene $$4$$ letras mayúsculas, y contiene caracteres de otro tipo (el conteo es $$4$$).
80
+
81
+3. **Letras minúsculas** La puntuación es $$2 \left(len - n\right)$$ si la contraseña es una mezcla de letras minúsculas **Y** al menos otro tipo de caracter (mayúscula, dígitos, símbolos). De lo contrario, la puntuación es $$0$$. Por ejemplo,
82
+
83
+    a. la puntuación para `"ab453"` sería $$2 \left(5-2\right) = 6$$ porque la contraseña es de largo $$5$$, contiene $$2$$ letras minúsculas, y contiene caracteres de otro tipo. El conteo es $$2$$.
84
+
85
+    b. la puntuación para `"ALGO"` sería $$0$$ porque no contiene letras minúsculas. El conteo es $$0$$.
86
+
87
+    c. la puntuación para `"sancochin"`  sería $$0$$ porque contiene **solo** letras minúsculas. El conteo es $$9$$.
88
+
89
+4. **Dígitos** La puntuación es $$4n$$ si la contraseña consiste de una mezcla de dígitos **Y** al menos otro tipo de caracter (minúscula, mayúscula, símbolos). De otro modo la puntuación es $$0$$. Por ejemplo,
90
+
91
+  a. la puntuación para `"ab453"` sería $$4 \cdot3 = 12$$ porque la contraseña contiene $$3$$ dígitos y contiene caracteres de otro tipo.
92
+
93
+  b. la puntuación para `"ALGO"` sería $$0$$ porque no tiene dígitos.
94
+
95
+  c. la puntuación para `801145555` sería $$0$$ porque contiene **solo** dígitos.
96
+
97
+5. **Símbolos** La puntuación es $$6n$$ si la contraseña contiene $n$ símbolos. De otro modo la puntuación es $$0$$. Por ejemplo,
98
+
99
+  a. la puntuación para `"ab453"` sería $$0$$ porque no contiene símbolos.
100
+
101
+  b. la puntuación para `"ALGO!!"` sería $$6 \cdot 2$$ porque contiene $$2$$ símbolos y contiene otros tipos de caracteres.
102
+
103
+  c. la puntuación para `”---><&&”`  sería $$6 \cdot 7 = 42$$ porque contiene $$7$$ símbolos. Nota que en el caso de símbolos, se otorga puntuación incluso cuando no hay otro tipo de caracteres.
104
+
105
+6. **Dígitos o símbolos en el medio** La puntuación es $$2n$$ si la contraseña contiene símbolos o dígitos que no están en la primera o última posición. Por ejemplo,
106
+
107
+  a. la puntuación para `"ab453"` sería $$2 \cdot2 = 4$$ porque contiene dos dígitos que no están en la primera o última posición, estos son `4` y `5`.
108
+
109
+  b. la puntuación para `"ALGO!"` sería $$0$$ porque no contiene dígitos ni símbolos en el medio, el único símbolo está al final.
110
+
111
+  c. la puntuación para `S&c8i7o!`  sería $$2 \cdot 3 = 6$$ porque contiene $$3$$ símbolos o dígitos en el medio, estos son `&`, 8`, y `7`.
112
+
113
+7. **Requisitos**: Se otorga  $$2n$$ solo si el criterio del largo **Y** 3 o 4 de los otros criterios se cumplen, donde $$n$$ es el número de *criterios* que se cumplen. Los criterios son:
114
+
115
+    a. La contraseña debe tener 8 o más caracteres de largo.
116
+
117
+    b. Contener:
118
+
119
+        1. Letras mayúsculas
120
+        2. Letras minúsculas
121
+        3. Números
122
+        4. Símbolos
123
+
124
+    Cada uno de los listados en la parte b. cuenta como un criterio individual. Por ejemplo,
125
+
126
+      a. la puntuación para `"ab453"` sería $$0$$ porque el criterio del largo no se cumple.
127
+
128
+      b. la puntuación para `"abABCDEF"` sería $$0$$ debido a que, a pesar de que se cumple el criterio del largo, solo 2 de los 4 otros criterios se cumplen (mayúsculas y minúsculas).
129
+
130
+      c. la puntuación para `"abAB99!!"` sería $$2 \cdot 5 = 10$$ debido a que cumple la condición del largo y también los otros 4 criterios.
131
+
132
+
133
+#### Restando puntos
134
+
135
+---
136
+
137
+|      | Categoría                         | Puntos                                   | Notas                                                                   |
138
+| :--- | :-------------------------------- | :-------------------------------------: | ----------------------------------------------------:                   |
139
+| 1.   | Solo letras                       |![resLetras.png](images/small/resLetras.png)    | $$len$$ es el largo de la contraseña                                           |
140
+| 2.   | Solo dígitos                      | ![resDigitos.png](images/small/resDigitos.png)    | $$len$$ es el largo de la contraseña                                           |
141
+| 3.   | Letras mayúsculas consecutivas    | $$-2n$$                                   | $$n$$ es el número de letras mayúsculas que siguen a otra letra mayúscula |
142
+| 4.   | Letras minúsculas consecutivas    | $$-2n$$                                   | $$n$$ es el número de letras minúsculas que siguen a otra letra minúscula                                                                     |
143
+| 5.   | Dígitos consecutivos              | $$-2n$$                                   | $$n$$ es el número de dígitos que siguen a otro dígito                     |
144
+
145
+**Tabla 2.** Criterios negativos para la fortaleza de la contraseña.
146
+
147
+---
148
+
149
+Lo que sigue son algunos detalles adicionales y ejemplos de los criterios para **restas**.
150
+
151
+1. **Letras solamente**: La puntuación es $$-len$$ para una contraseña que consista solo de letras, de otro modo obtiene $$0$$. Por ejemplo,
152
+
153
+    a. la puntuación para `"ab453"` sería $$0$$ ya que contiene letras y números
154
+
155
+    b. la puntuación para `"Barrunto"` sería $$-8$$ ya que consiste solo de letras y su largo es $$8$$.
156
+
157
+2. **Dígitos solamente**: La puntuación es $$-len$$ para una contraseña que consista solo de dígitos, de otro modo obtiene $$0$$. Por ejemplo,
158
+
159
+    a. la puntuación para `"ab453"` sería $$0$$ ya que contiene solo letras y números
160
+
161
+    b. la puntuación para `”987987987”` sería $$-9$$ ya que consiste solo de dígitos y su largo es $$9$$.
162
+
163
+3. **Letras mayúsculas consecutivas**: La puntuación es $$-2n$$ donde $$n$$ es el número de letras mayúsculas que siguen a otra letra mayúscula. Por ejemplo,
164
+
165
+    a. la puntuación para `"DB453"` sería $$-2 \cdot 1 = -2$$ ya que solo contiene una letra mayúscula (`B`) que sigue a otra letra mayúscula.
166
+
167
+    b. la puntuación para `"TNS1PBMA"` sería $$-2 \cdot 5 = -10$$ ya que contiene 5 letras mayúsculas (`N`, `S`, `B`, `M`, `A`) que siguen a otra letra mayúscula.
168
+
169
+4. **Letras minúsculas consecutivas**: Igual que el criterio #3 pero para letras minúsculas.
170
+
171
+5. **Dígitos consecutivos**: Igual que el criterio #3 pero para dígitos.
172
+
173
+---
174
+
175
+---
176
+
177
+!INCLUDE "../../eip-diagnostic/password-strength/es/diag-password-strength-01.html"
178
+
179
+!INCLUDE "../../eip-diagnostic/password-strength/es/diag-password-strength-02.html"
180
+
181
+!INCLUDE "../../eip-diagnostic/password-strength/es/diag-password-strength-03.html"
182
+
183
+!INCLUDE "../../eip-diagnostic/password-strength/es/diag-password-strength-04.html"
184
+
185
+!INCLUDE "../../eip-diagnostic/password-strength/es/diag-password-strength-05.html"
186
+
187
+---
188
+
189
+---
190
+
191
+## Sesión de laboratorio:
192
+
193
+En esta experiencia de laboratorio practicarás el uso de expresiones matemáticas y estructuras condicionales para computar la puntuación de resistencia o fortaleza de una contraseña combinando las puntuaciones de los criterios individuales.
194
+
195
+Tu tarea es completar el diseño de una aplicación para medir la fortaleza de las contraseñas de acceso ("password strength"). Al final obtendrás un programa que será una versión simplificada de la aplicación en http://www.passwordmeter.com/. Como no existe un sistema oficial para medir las contraseñas, se utilizarán las fórmulas creadas por el "passwordmeter" para evaluar la fortaleza general de una contraseña dada. La aplicación permitirá al usuario entrar una contraseña y calculará su fortaleza utilizando una serie de reglas.
196
+
197
+La fortaleza de la contraseña se cuantificará otorgando puntos por utilizar "buenas" técnicas de selección de contraseñas (como combinar símbolos y letras) y restando puntos por utilizar "malos" hábitos (como utilizar solo letras minúsculas o caracteres consecutivos de un mismo tipo). Tu programa analizará la contraseña dada por el usuario y usará los criterios en las tablas presentadas arriba para computar una puntuación para la fortaleza de la contraseña.
198
+
199
+Una vez completada la aplicación, esta mostrará una ventana en donde, según se vayan entrando los caracteres de la contraseña, se desglosará la puntuación parcial obtenida. Esta interface gráfica para el usuario le ofrecerá  una manera de mejorar su contraseña y corregir los  malos hábitos típicos al formular contraseñas débiles.
200
+
201
+
202
+
203
+### Ejercicio 1: Familiarizarte con las funciones pre-definidas
204
+
205
+El primer paso en esta experiencia de laboratorio es familiarizarte con las funciones pre-definidas en el código. Invocarás estas funciones en el código que crearás para computar la puntuación de varios de los criterios para fortaleza de contraseñas.
206
+
207
+**Instrucciones**
208
+
209
+1.  Carga a Qt el proyecto `PassworStrength`  haciendo doble "click" en el archivo `PasswordStrength.pro` en el directorio `Documents/eip/Conditionals-PasswordStrength` de tu computadora. También puedes ir a `http://bitbucket.org/eip-uprrp/conditionals-passwordstrength` para descargar la carpeta `Conditionals-PasswordStrength` a tu computadora.
210
+
211
+2. Configura el proyecto.  El proyecto consiste de varios archivos. **Solo escribirás código en el archivo `readpassword.cpp`. No debes cambiar nada en los demás archivos.** Sin embargo, debes familiarizarte con las funciones que ya están definidas en ellos, ya que usarás algunas de ellas para crear tu código.
212
+
213
+      * `psfunctions.cpp` : contiene las implementaciones de algunas de las funciones que tu programa va a invocar para calcular la puntuación de la fortaleza total de la contraseña. **No tienes que cambiar nada del código en este archivo ni en el archivo `psfunctions.h`**. Simplemente invocarás desde la función `readPass` en el archivo `readpassword.cpp` las funciones contenidas en ellos, según sea necesario. Hay funciones que no necesitarás invocar. Nota que el nombre de las funciones te dice lo que la función hace.
214
+
215
+      * `psfunctions.h` : contiene los prototipos de las funciones definidas en `psfunctions.cpp`.
216
+
217
+
218
+
219
+### Ejercicio 2: Conocer las funciones para actualizar la interface gráfica de usuarios.
220
+
221
+En el ejercicio de laboratorio crearás el código para calcular la puntuación asociada a cada uno de los criterios de las tablas de sumas y deducciones mostradas arriba. Estas puntuaciones deben ser actualizadas en la interface gráfica de usuarios que se muestra en la Figura 1.
222
+
223
+---
224
+
225
+![interfaceGrafica.png](images/interfaceGrafica.png)
226
+
227
+**Figura 1.** Interface gráfica de usuarios del proyecto *Fortaleza de contraseñas*
228
+
229
+---
230
+
231
+Hay funciones pre-definidas que actualizan la interface gráfica. Para que la aplicación funcione como esperada, cada vez que tu código compute la puntuación que se adjudica para un criterio debes invocar la función que actualiza ese criterio en el interface gráfico. Las funciones para actualizar los criterios tienen la siguiente sintaxis:  
232
+
233
+
234
+  ```
235
+  void setCRITERIO(int count, int score) ;
236
+  ```
237
+
238
+  donde CRITERIO debe reemplazarse por el criterio evaluado. Observa que la función requiere dos argumentos: el **conteo** que es la cantidad de caracteres que cumple con el criterio y la **puntuación** que es el cálculo que tu implementarás siguiendo las tablas de arriba.  Por ejemplo,
239
+
240
+```
241
+count = pass.length() ;
242
+score = 4 * count ;
243
+setNumberOfCharacters(count, score);
244
+totalScore += score ;
245
+
246
+```
247
+En  el código de arriba `count` contiene  el número de caracteres en la contraseña, `score` contiene el cómputo de la puntuación del criterio de número de caracteres y `setNumberOfCharacters(count, score);` invoca la función para que se actualice la información correspondiente al criterio “Number of characters” en la interface gráfica.
248
+
249
+
250
+  Las funciones para actualizar la interface gráfica son:
251
+  ```
252
+    // Para actualizar el largo de  la contraseña.
253
+    void setNumberOfCharacters(int count, int score) ;  
254
+
255
+    // Para las sumas
256
+
257
+    // Para actualizar los caracteres en mayúscula.
258
+    void setUpperCharacters(int count, int score) ;
259
+
260
+    // Para actualizar los caracteres en minúscula.
261
+    void setLowerCharacters(int count, int score) ;
262
+
263
+    // Para actualizar los caracteres que son dígitos.
264
+    void setDigits(int count, int score) ;
265
+
266
+    // Para actualizar los caracteres que son símbolos.
267
+    void setSymbols(int count, int score) ;
268
+
269
+    // Para actualizar digitos o simbolos en el medio
270
+    void setMiddleDigitsOrSymbols(int count, int score) ;
271
+
272
+    // Para actualizar el criterio de  los requisitos
273
+    void setRequirements(int count, int score) ;
274
+
275
+    // Para las restas
276
+
277
+    // Para actualizar el criterio de letras solamente.
278
+    void setLettersOnly(int count, int score) ;
279
+
280
+    // Para actualizar el criterio de dígitos solamente.
281
+    void setDigitsOnly(int count, int score) ;
282
+
283
+    // Para actualizar el criterio de mayúsculas consecutivas.
284
+    void setConsecutiveUpper(int count, int score) ;
285
+
286
+    // Para actualizar el criterio de minúsculas consecutivas.
287
+    void setConsecutiveLower(int count, int score) ;
288
+
289
+    // Para actualizar el criterio de dígitos consecutivos.
290
+    void setConsecutiveDigits(int count, int score) ;
291
+  ```
292
+
293
+### Ejercicio 3: Calcular la puntuación de los criterios y la puntuación total de la contraseña
294
+
295
+
296
+El código que te proveemos contiene las funciones que computan el conteo para  la mayoría de los criterios y cuyos nombres reflejan lo que hace y devuelve la función. Por ejemplo, `countUppercase`, devuelve el número de caracteres que son letras mayúsculas. [Aquí](http://ccom.uprrp.edu/~rarce/ccom3033f14/documentation/passwordStrengthCL/psfunctions_8cpp.html) hay una lista y descripción de las funciones.
297
+
298
+Tu tarea es utilizar expresiones matemáticas y estructuras condicionales para las puntuaciones de los criterios individuales y combinarlas para computar la puntuación total de fortaleza de una contraseña.
299
+
300
+
301
+
302
+
303
+**Ejemplo 1:**
304
+
305
+---
306
+
307
+![ventanaCaba77o.png](images/ventanaCaba77o.png)
308
+
309
+**Figura 2.** Ventana con el informe de la contraseña `caba77o`
310
+
311
+---
312
+
313
+**Ejemplo 2:**
314
+
315
+---
316
+
317
+![ventanaS1nf@nia!.png](images/ventanaS1nf@nia!.png)
318
+
319
+**Figura 3.** Ventana con el informe de la contraseña `S1nf@nia!`
320
+
321
+---
322
+
323
+En el Ejemplo 2, el conteo de los **requisitos** es 5 porque `"S1nf@nia!"` cumple con el criterio de largo y también contiene mayúsculas, minúsculas, números y símbolos. Por lo tanto, la puntuación del número de requisitos es $$2 \cdot 5 =10$$.
324
+
325
+En el código del proyecto vas a encontrar ejemplos de cómo calcular los primeros dos criterios positivos: el número de caracteres en la contraseña y el número de letras mayúsculas. Puedes compilar y ejecutar el ejemplo para que veas la interfase funcionando con esos dos criterios. Parte de tu tarea es añadir el código para computar las puntuaciones de los demás criterios. Recuerda que debes ir acumulando el resultado de la puntuación total y hacer invocaciones para actualizar la interface gráfica.
326
+
327
+
328
+
329
+### Ejercicio 4: Determinar y desplegar la fortaleza de la contraseña
330
+
331
+En la parte superior de la interface gráfica se ingresa la contraseña.  El usuario ingresará la contraseña en la parte superior de la interface gráfica. Debajo aparece un *informe* que contiene los distintos criterios, el conteo para cada criterio, y la puntuación individual para los criterios. Este informe se va actualizando según el usuario va ingresando los caracteres de la contraseña.  La puntuación total será la suma de todas los puntos (sumas y restas) de los criterios individuales.
332
+
333
+Basado en la puntuación total, el programa debe clasificar la fortaleza de la contraseña como sigue:
334
+
335
+| Puntación total |  Fortaleza  |
336
+|-----------------|-------------|
337
+| [0,20)          | Bien débil  |
338
+| [20,40)         | Débil       |
339
+| [40,60)         | Buena       |
340
+| [60,80)         | Fuerte      |
341
+| [80,100]        | Bien fuerte |
342
+
343
+El código provisto ya invoca la función `strengthDisplay` con la fortaleza calculada y la puntuación final para actualizar la clasificación y la barra que indica la fortaleza en la interface gráfica.
344
+
345
+---
346
+
347
+---
348
+
349
+## Entregas
350
+
351
+Utiliza "Entrega" en Moodle para entregar el archivo `readpassword.cpp` que contiene el código con el cómputo de las puntuaciones de los criterios individuales, la puntuación final, las invocaciones para actualizar la interface gráfica, la clasificación de la fortaleza y se despliegue. Recuerda utilizar buenas prácticas de programación, incluir el nombre de los programadores y documentar tu programa.
352
+
353
+
354
+
355
+---
356
+
357
+---
358
+
359
+## Referencias
360
+
361
+
362
+[1] Passwordmeter, http://www.passwordmeter.com/
363
+
364
+---
365
+
366
+---
367
+
368
+---
369
+
370
+

+ 2
- 734
README.md View File

@@ -1,734 +1,2 @@
1
-[English](#markdown-header-decision-structures-password-strength) | [Español](#markdown-header-estructuras-de-decision-fortaleza-de-contrasenas)
2
-
3
-# Estructuras de decisión - Fortaleza de contraseñas
4
-
5
-![main1.png](images/main1.png)
6
-![main2.png](images/main2.png)
7
-![main3.png](images/main3.png)
8
-
9
-
10
-
11
-En casi todas las instancias en que queremos resolver un problema hay una o más opciones que dependen  de si se cumplen o no ciertas condiciones. Los programas de computadoras se construyen para resolver problemas y, por lo tanto, deben tener una estructura que permita tomar decisiones. En C++ las  instrucciones de decisión (o condicionales) se estructuran utilizando `if`, `else`, `else if` o `switch`. Muchas veces el uso de estas estructuras también envuelve el uso de expresiones de relación y operadores lógicos. En la experiencia de laboratorio de hoy practicarás el uso de algunas  estructuras de decisión completando el diseño de una aplicación que determina la fortaleza de  una contraseña de acceso ("password").
12
-
13
-## Objetivos:
14
-
15
-1.  Utilizar expresiones relacionales y seleccionar operadores lógicos adecuados para la toma de decisiones.
16
-2. Aplicar estructuras de decisión.
17
-
18
-
19
-## Pre-Lab:
20
-
21
-Antes de llegar al laboratorio debes:
22
-
23
-1. Haber repasado los siguientes conceptos:
24
-
25
-    a. operadores lógicos
26
-
27
-    b. `if`, `else`, `else if`.
28
-
29
-2. Haber repasado el uso de objetos de la clase `string` y su método `length()`.
30
-
31
-3. Haber estudiado los conceptos e instrucciones para la sesión de laboratorio.
32
-
33
-4. Haber tomado el quiz Pre-Lab que se encuentra en Moodle.
34
-
35
-
36
----
37
-
38
----
39
-
40
-## Fortaleza de contraseñas de acceso
41
-
42
-Utilizar contraseñas de acceso resistentes es esencial para mantener los datos seguros en los sistemas de información. Una contraseña se considera resistente o fuerte ("strong") si resulta costo-inefectivo para el "pirata informático" ("hacker") emplear tiempo tratando de adivinarla usando contraseñas ingenuas o fuerza bruta. Por ejemplo, una contraseña que consiste de una palabra simple del diccionario, sin números, símbolos o letras mayúsculas, es tan fácil de descifrar que hasta "un cavernícola puede hacerlo".
43
-
44
-Como no existe un sistema oficial para medir las contraseñas, utilizaremos fórmulas creadas por el "passwordmeter"  para evaluar la fortaleza general de una contraseña dada [1]. Te recomendamos que juegues un poco con la aplicación en http://passwordmeter.com para que entiendas cómo debe comportarse la aplicación que estarás implementando en esta experiencia de laboratorio. La fortaleza de la contraseña se cuantificará otorgando puntos por utilizar "buenas" técnicas de selección de contraseñas (como utilizar mezclas de símbolos y letras) y restando puntos por utilizar "malos" hábitos en las contraseñas (como utilizar solo letras minúsculas o símbolos consecutivos de un mismo tipo).
45
-
46
-Las siguientes tablas resumen los valores añadidos y sustraídos para varias características en las contraseñas.
47
-
48
-
49
-
50
-### Asignando puntuación a las contraseñas
51
-
52
-#### Sumando puntos
53
-
54
----
55
-
56
-|      | Categoría                        | Puntos                                   | Notas                                                |
57
-| :--- | :-------------------------------- | :-------------------------------------: | ----------------------------------------------------: |
58
-| 1.   | Número de caracteres             | $$4\left(len\right)$$                                 | $$len$$ es el largo de la contraseña                        |
59
-| 2.   | Letras mayúsculas                | ![sumaMayus.png](images/small/sumaMayus.png)| $$n$$ es el número de letras mayúsculas                |
60
-| 3.   | Letras minúsculas                | ![sumaMin.png](images/small/sumaMin.png) | $$n$$ es el número de letras minúsculas                |
61
-| 4.   | Dígitos                          |  ![sumaDigitos.png](images/small/sumaDigitos.png) | $$n$$ es el número de dígitos                          |
62
-| 5.   | Símbolos                         | $$6n$$     | $$n$$ es el número de símbolos                         |
63
-| 6.   | Dígitos o símbolos en el medio   | $$2n$$                                   | $$n$$ es el número de dígitos y símbolos en el medio   |
64
-| 7.   | Requisitos                       | ![criterios.png](images/small/criterios.png)                              | $$n$$ es el número de criterios que se cumplen        |
65
-
66
-**Tabla 1.** Criterios positivos para  la fortaleza de la contraseña.
67
-
68
----
69
-
70
-Lo que sigue son algunos detalles adicionales y ejemplos de los criterios para **sumas**.
71
-
72
-1. **Número de caracteres**: este es el criterio más simple. La puntuación es $$4$$ veces el largo de la contraseña. Por ejemplo, `"ab453"` tiene un conteo de $$5$$ y puntuación de $$4 \cdot 5= 20$$.
73
-
74
-2. **Letras mayúsculas** La puntuación es $$2 \left(len - n \right)$$ si la contraseña consiste de una mezcla de letras mayúsculas **Y** al menos otro tipo de caracter (minúscula, dígitos, símbolos). De lo contrario, la puntuación es $$0$$. Por ejemplo,
75
-
76
-    a. la puntuación para `"ab453"` sería $$0$$ ya que no tiene letras mayúsculas (el conteo también es $$0$$)
77
-
78
-    b. la puntuación para `"ALGO"` sería $$0$$ porque **solo** contiene letras mayúsculas (el conteo es $$4$$).
79
-
80
-    c. la puntuación para `"SANC8in"` sería $$2  \left(7-4\right) = 6$$ porque la contraseña es de largo $$7$$, contiene $$4$$ letras mayúsculas, y contiene caracteres de otro tipo (el conteo es $$4$$).
81
-
82
-3. **Letras minúsculas** La puntuación es $$2 \left(len - n\right)$$ si la contraseña es una mezcla de letras minúsculas **Y** al menos otro tipo de caracter (mayúscula, dígitos, símbolos). De lo contrario, la puntuación es $$0$$. Por ejemplo,
83
-
84
-    a. la puntuación para `"ab453"` sería $$2 \left(5-2\right) = 6$$ porque la contraseña es de largo $$5$$, contiene $$2$$ letras minúsculas, y contiene caracteres de otro tipo. El conteo es $$2$$.
85
-
86
-    b. la puntuación para `"ALGO"` sería $$0$$ porque no contiene letras minúsculas. El conteo es $$0$$.
87
-
88
-    c. la puntuación para `"sancochin"`  sería $$0$$ porque contiene **solo** letras minúsculas. El conteo es $$9$$.
89
-
90
-4. **Dígitos** La puntuación es $$4n$$ si la contraseña consiste de una mezcla de dígitos **Y** al menos otro tipo de caracter (minúscula, mayúscula, símbolos). De otro modo la puntuación es $$0$$. Por ejemplo,
91
-
92
-  a. la puntuación para `"ab453"` sería $$4 \cdot3 = 12$$ porque la contraseña contiene $$3$$ dígitos y contiene caracteres de otro tipo.
93
-
94
-  b. la puntuación para `"ALGO"` sería $$0$$ porque no tiene dígitos.
95
-
96
-  c. la puntuación para `801145555` sería $$0$$ porque contiene **solo** dígitos.
97
-
98
-5. **Símbolos** La puntuación es $$6n$$ si la contraseña contiene $n$ símbolos. De otro modo la puntuación es $$0$$. Por ejemplo,
99
-
100
-  a. la puntuación para `"ab453"` sería $$0$$ porque no contiene símbolos.
101
-
102
-  b. la puntuación para `"ALGO!!"` sería $$6 \cdot 2$$ porque contiene $$2$$ símbolos y contiene otros tipos de caracteres.
103
-
104
-  c. la puntuación para `”---><&&”`  sería $$6 \cdot 7 = 42$$ porque contiene $$7$$ símbolos. Nota que en el caso de símbolos, se otorga puntuación incluso cuando no hay otro tipo de caracteres.
105
-
106
-6. **Dígitos o símbolos en el medio** La puntuación es $$2n$$ si la contraseña contiene símbolos o dígitos que no están en la primera o última posición. Por ejemplo,
107
-
108
-  a. la puntuación para `"ab453"` sería $$2 \cdot2 = 4$$ porque contiene dos dígitos que no están en la primera o última posición, estos son `4` y `5`.
109
-
110
-  b. la puntuación para `"ALGO!"` sería $$0$$ porque no contiene dígitos ni símbolos en el medio, el único símbolo está al final.
111
-
112
-  c. la puntuación para `S&c8i7o!`  sería $$2 \cdot 3 = 6$$ porque contiene $$3$$ símbolos o dígitos en el medio, estos son `&`, 8`, y `7`.
113
-
114
-7. **Requisitos**: Se otorga  $$2n$$ solo si el criterio del largo **Y** 3 o 4 de los otros criterios se cumplen, donde $$n$$ es el número de *criterios* que se cumplen. Los criterios son:
115
-
116
-    a. La contraseña debe tener 8 o más caracteres de largo.
117
-
118
-    b. Contener:
119
-
120
-        1. Letras mayúsculas
121
-        2. Letras minúsculas
122
-        3. Números
123
-        4. Símbolos
124
-
125
-    Cada uno de los listados en la parte b. cuenta como un criterio individual. Por ejemplo,
126
-
127
-      a. la puntuación para `"ab453"` sería $$0$$ porque el criterio del largo no se cumple.
128
-
129
-      b. la puntuación para `"abABCDEF"` sería $$0$$ debido a que, a pesar de que se cumple el criterio del largo, solo 2 de los 4 otros criterios se cumplen (mayúsculas y minúsculas).
130
-
131
-      c. la puntuación para `"abAB99!!"` sería $$2 \cdot 5 = 10$$ debido a que cumple la condición del largo y también los otros 4 criterios.
132
-
133
-
134
-#### Restando puntos
135
-
136
----
137
-
138
-|      | Categoría                         | Puntos                                   | Notas                                                                   |
139
-| :--- | :-------------------------------- | :-------------------------------------: | ----------------------------------------------------:                   |
140
-| 1.   | Solo letras                       |![resLetras.png](images/small/resLetras.png)    | $$len$$ es el largo de la contraseña                                           |
141
-| 2.   | Solo dígitos                      | ![resDigitos.png](images/small/resDigitos.png)    | $$len$$ es el largo de la contraseña                                           |
142
-| 3.   | Letras mayúsculas consecutivas    | $$-2n$$                                   | $$n$$ es el número de letras mayúsculas que siguen a otra letra mayúscula |
143
-| 4.   | Letras minúsculas consecutivas    | $$-2n$$                                   | $$n$$ es el número de letras minúsculas que siguen a otra letra minúscula                                                                     |
144
-| 5.   | Dígitos consecutivos              | $$-2n$$                                   | $$n$$ es el número de dígitos que siguen a otro dígito                     |
145
-
146
-**Tabla 2.** Criterios negativos para la fortaleza de la contraseña.
147
-
148
----
149
-
150
-Lo que sigue son algunos detalles adicionales y ejemplos de los criterios para **restas**.
151
-
152
-1. **Letras solamente**: La puntuación es $$-len$$ para una contraseña que consista solo de letras, de otro modo obtiene $$0$$. Por ejemplo,
153
-
154
-    a. la puntuación para `"ab453"` sería $$0$$ ya que contiene letras y números
155
-
156
-    b. la puntuación para `"Barrunto"` sería $$-8$$ ya que consiste solo de letras y su largo es $$8$$.
157
-
158
-2. **Dígitos solamente**: La puntuación es $$-len$$ para una contraseña que consista solo de dígitos, de otro modo obtiene $$0$$. Por ejemplo,
159
-
160
-    a. la puntuación para `"ab453"` sería $$0$$ ya que contiene solo letras y números
161
-
162
-    b. la puntuación para `”987987987”` sería $$-9$$ ya que consiste solo de dígitos y su largo es $$9$$.
163
-
164
-3. **Letras mayúsculas consecutivas**: La puntuación es $$-2n$$ donde $$n$$ es el número de letras mayúsculas que siguen a otra letra mayúscula. Por ejemplo,
165
-
166
-    a. la puntuación para `"DB453"` sería $$-2 \cdot 1 = -2$$ ya que solo contiene una letra mayúscula (`B`) que sigue a otra letra mayúscula.
167
-
168
-    b. la puntuación para `"TNS1PBMA"` sería $$-2 \cdot 5 = -10$$ ya que contiene 5 letras mayúsculas (`N`, `S`, `B`, `M`, `A`) que siguen a otra letra mayúscula.
169
-
170
-4. **Letras minúsculas consecutivas**: Igual que el criterio #3 pero para letras minúsculas.
171
-
172
-5. **Dígitos consecutivos**: Igual que el criterio #3 pero para dígitos.
173
-
174
----
175
-
176
----
177
-
178
-!INCLUDE "../../eip-diagnostic/password-strength/es/diag-password-strength-01.html"
179
-
180
-!INCLUDE "../../eip-diagnostic/password-strength/es/diag-password-strength-02.html"
181
-
182
-!INCLUDE "../../eip-diagnostic/password-strength/es/diag-password-strength-03.html"
183
-
184
-!INCLUDE "../../eip-diagnostic/password-strength/es/diag-password-strength-04.html"
185
-
186
-!INCLUDE "../../eip-diagnostic/password-strength/es/diag-password-strength-05.html"
187
-
188
----
189
-
190
----
191
-
192
-## Sesión de laboratorio:
193
-
194
-En esta experiencia de laboratorio practicarás el uso de expresiones matemáticas y estructuras condicionales para computar la puntuación de resistencia o fortaleza de una contraseña combinando las puntuaciones de los criterios individuales.
195
-
196
-Tu tarea es completar el diseño de una aplicación para medir la fortaleza de las contraseñas de acceso ("password strength"). Al final obtendrás un programa que será una versión simplificada de la aplicación en http://www.passwordmeter.com/. Como no existe un sistema oficial para medir las contraseñas, se utilizarán las fórmulas creadas por el "passwordmeter" para evaluar la fortaleza general de una contraseña dada. La aplicación permitirá al usuario entrar una contraseña y calculará su fortaleza utilizando una serie de reglas.
197
-
198
-La fortaleza de la contraseña se cuantificará otorgando puntos por utilizar "buenas" técnicas de selección de contraseñas (como combinar símbolos y letras) y restando puntos por utilizar "malos" hábitos (como utilizar solo letras minúsculas o caracteres consecutivos de un mismo tipo). Tu programa analizará la contraseña dada por el usuario y usará los criterios en las tablas presentadas arriba para computar una puntuación para la fortaleza de la contraseña.
199
-
200
-Una vez completada la aplicación, esta mostrará una ventana en donde, según se vayan entrando los caracteres de la contraseña, se desglosará la puntuación parcial obtenida. Esta interface gráfica para el usuario le ofrecerá  una manera de mejorar su contraseña y corregir los  malos hábitos típicos al formular contraseñas débiles.
201
-
202
-
203
-
204
-### Ejercicio 1: Familiarizarte con las funciones pre-definidas
205
-
206
-El primer paso en esta experiencia de laboratorio es familiarizarte con las funciones pre-definidas en el código. Invocarás estas funciones en el código que crearás para computar la puntuación de varios de los criterios para fortaleza de contraseñas.
207
-
208
-**Instrucciones**
209
-
210
-1.  Carga a Qt el proyecto `PassworStrength`  haciendo doble "click" en el archivo `PasswordStrength.pro` en el directorio `Documents/eip/Conditionals-PasswordStrength` de tu computadora. También puedes ir a `http://bitbucket.org/eip-uprrp/conditionals-passwordstrength` para descargar la carpeta `Conditionals-PasswordStrength` a tu computadora.
211
-
212
-2. Configura el proyecto.  El proyecto consiste de varios archivos. **Solo escribirás código en el archivo `readpassword.cpp`. No debes cambiar nada en los demás archivos.** Sin embargo, debes familiarizarte con las funciones que ya están definidas en ellos, ya que usarás algunas de ellas para crear tu código.
213
-
214
-      * `psfunctions.cpp` : contiene las implementaciones de algunas de las funciones que tu programa va a invocar para calcular la puntuación de la fortaleza total de la contraseña. **No tienes que cambiar nada del código en este archivo ni en el archivo `psfunctions.h`**. Simplemente invocarás desde la función `readPass` en el archivo `readpassword.cpp` las funciones contenidas en ellos, según sea necesario. Hay funciones que no necesitarás invocar. Nota que el nombre de las funciones te dice lo que la función hace.
215
-
216
-      * `psfunctions.h` : contiene los prototipos de las funciones definidas en `psfunctions.cpp`.
217
-
218
-
219
-
220
-### Ejercicio 2: Conocer las funciones para actualizar la interface gráfica de usuarios.
221
-
222
-En el ejercicio de laboratorio crearás el código para calcular la puntuación asociada a cada uno de los criterios de las tablas de sumas y deducciones mostradas arriba. Estas puntuaciones deben ser actualizadas en la interface gráfica de usuarios que se muestra en la Figura 1.
223
-
224
----
225
-
226
-![interfaceGrafica.png](images/interfaceGrafica.png)
227
-
228
-**Figura 1.** Interface gráfica de usuarios del proyecto *Fortaleza de contraseñas*
229
-
230
----
231
-
232
-Hay funciones pre-definidas que actualizan la interface gráfica. Para que la aplicación funcione como esperada, cada vez que tu código compute la puntuación que se adjudica para un criterio debes invocar la función que actualiza ese criterio en el interface gráfico. Las funciones para actualizar los criterios tienen la siguiente sintaxis:  
233
-
234
-
235
-  ```
236
-  void setCRITERIO(int count, int score) ;
237
-  ```
238
-
239
-  donde CRITERIO debe reemplazarse por el criterio evaluado. Observa que la función requiere dos argumentos: el **conteo** que es la cantidad de caracteres que cumple con el criterio y la **puntuación** que es el cálculo que tu implementarás siguiendo las tablas de arriba.  Por ejemplo,
240
-
241
-```
242
-count = pass.length() ;
243
-score = 4 * count ;
244
-setNumberOfCharacters(count, score);
245
-totalScore += score ;
246
-
247
-```
248
-En  el código de arriba `count` contiene  el número de caracteres en la contraseña, `score` contiene el cómputo de la puntuación del criterio de número de caracteres y `setNumberOfCharacters(count, score);` invoca la función para que se actualice la información correspondiente al criterio “Number of characters” en la interface gráfica.
249
-
250
-
251
-  Las funciones para actualizar la interface gráfica son:
252
-  ```
253
-    // Para actualizar el largo de  la contraseña.
254
-    void setNumberOfCharacters(int count, int score) ;  
255
-
256
-    // Para las sumas
257
-
258
-    // Para actualizar los caracteres en mayúscula.
259
-    void setUpperCharacters(int count, int score) ;
260
-
261
-    // Para actualizar los caracteres en minúscula.
262
-    void setLowerCharacters(int count, int score) ;
263
-
264
-    // Para actualizar los caracteres que son dígitos.
265
-    void setDigits(int count, int score) ;
266
-
267
-    // Para actualizar los caracteres que son símbolos.
268
-    void setSymbols(int count, int score) ;
269
-
270
-    // Para actualizar digitos o simbolos en el medio
271
-    void setMiddleDigitsOrSymbols(int count, int score) ;
272
-
273
-    // Para actualizar el criterio de  los requisitos
274
-    void setRequirements(int count, int score) ;
275
-
276
-    // Para las restas
277
-
278
-    // Para actualizar el criterio de letras solamente.
279
-    void setLettersOnly(int count, int score) ;
280
-
281
-    // Para actualizar el criterio de dígitos solamente.
282
-    void setDigitsOnly(int count, int score) ;
283
-
284
-    // Para actualizar el criterio de mayúsculas consecutivas.
285
-    void setConsecutiveUpper(int count, int score) ;
286
-
287
-    // Para actualizar el criterio de minúsculas consecutivas.
288
-    void setConsecutiveLower(int count, int score) ;
289
-
290
-    // Para actualizar el criterio de dígitos consecutivos.
291
-    void setConsecutiveDigits(int count, int score) ;
292
-  ```
293
-
294
-### Ejercicio 3: Calcular la puntuación de los criterios y la puntuación total de la contraseña
295
-
296
-
297
-El código que te proveemos contiene las funciones que computan el conteo para  la mayoría de los criterios y cuyos nombres reflejan lo que hace y devuelve la función. Por ejemplo, `countUppercase`, devuelve el número de caracteres que son letras mayúsculas. [Aquí](http://ccom.uprrp.edu/~rarce/ccom3033f14/documentation/passwordStrengthCL/psfunctions_8cpp.html) hay una lista y descripción de las funciones.
298
-
299
-Tu tarea es utilizar expresiones matemáticas y estructuras condicionales para las puntuaciones de los criterios individuales y combinarlas para computar la puntuación total de fortaleza de una contraseña.
300
-
301
-
302
-
303
-
304
-**Ejemplo 1:**
305
-
306
----
307
-
308
-![ventanaCaba77o.png](images/ventanaCaba77o.png)
309
-
310
-**Figura 2.** Ventana con el informe de la contraseña `caba77o`
311
-
312
----
313
-
314
-**Ejemplo 2:**
315
-
316
----
317
-
318
-![ventanaS1nf@nia!.png](images/ventanaS1nf@nia!.png)
319
-
320
-**Figura 3.** Ventana con el informe de la contraseña `S1nf@nia!`
321
-
322
----
323
-
324
-En el Ejemplo 2, el conteo de los **requisitos** es 5 porque `"S1nf@nia!"` cumple con el criterio de largo y también contiene mayúsculas, minúsculas, números y símbolos. Por lo tanto, la puntuación del número de requisitos es $$2 \cdot 5 =10$$.
325
-
326
-En el código del proyecto vas a encontrar ejemplos de cómo calcular los primeros dos criterios positivos: el número de caracteres en la contraseña y el número de letras mayúsculas. Puedes compilar y ejecutar el ejemplo para que veas la interfase funcionando con esos dos criterios. Parte de tu tarea es añadir el código para computar las puntuaciones de los demás criterios. Recuerda que debes ir acumulando el resultado de la puntuación total y hacer invocaciones para actualizar la interface gráfica.
327
-
328
-
329
-
330
-### Ejercicio 4: Determinar y desplegar la fortaleza de la contraseña
331
-
332
-En la parte superior de la interface gráfica se ingresa la contraseña.  El usuario ingresará la contraseña en la parte superior de la interface gráfica. Debajo aparece un *informe* que contiene los distintos criterios, el conteo para cada criterio, y la puntuación individual para los criterios. Este informe se va actualizando según el usuario va ingresando los caracteres de la contraseña.  La puntuación total será la suma de todas los puntos (sumas y restas) de los criterios individuales.
333
-
334
-Basado en la puntuación total, el programa debe clasificar la fortaleza de la contraseña como sigue:
335
-
336
-| Puntación total |  Fortaleza  |
337
-|-----------------|-------------|
338
-| [0,20)          | Bien débil  |
339
-| [20,40)         | Débil       |
340
-| [40,60)         | Buena       |
341
-| [60,80)         | Fuerte      |
342
-| [80,100]        | Bien fuerte |
343
-
344
-El código provisto ya invoca la función `strengthDisplay` con la fortaleza calculada y la puntuación final para actualizar la clasificación y la barra que indica la fortaleza en la interface gráfica.
345
-
346
----
347
-
348
----
349
-
350
-## Entregas
351
-
352
-Utiliza "Entrega" en Moodle para entregar el archivo `readpassword.cpp` que contiene el código con el cómputo de las puntuaciones de los criterios individuales, la puntuación final, las invocaciones para actualizar la interface gráfica, la clasificación de la fortaleza y se despliegue. Recuerda utilizar buenas prácticas de programación, incluir el nombre de los programadores y documentar tu programa.
353
-
354
-
355
-
356
----
357
-
358
----
359
-
360
-## Referencias
361
-
362
-
363
-[1] Passwordmeter, http://www.passwordmeter.com/
364
-
365
----
366
-
367
----
368
-
369
----
370
-
371
-
372
-[English](#markdown-header-decision-structures-password-strength) | [Español](#markdown-header-estructuras-de-decision-fortaleza-de-contrasenas)
373
-
374
-# Decision Structures - Password Strength
375
-
376
-![main1.png](images/main1.png)
377
-![main2.png](images/main2.png)
378
-![main3.png](images/main3.png)
379
-
380
-Commonly, when solving a problem, there are one or more steps that depend on whether certain conditions are met. Computer programs are built to solve problems, so they should have a structure that allows them to make decisions. In C++ the decision instructions (or conditionals) are structured using  `if`, `else`, `else if` or `switch`. Relational expressions and logical operators are common when handling decision structures. In today's laboratory experience you will practice the use of some of these structures by completing the design of an application that determines the strength of a password.
381
-
382
-## Objectives:
383
-
384
-1. Use relational expressions and select adequate logical operators to make decisions.
385
-2. Apply decision structures.
386
-
387
-
388
-##Pre-Lab:
389
-
390
-Before you get to the laboratory you should have:
391
-
392
-1. Reviewed the following concepts:
393
-
394
-    a. Logical operators.
395
-
396
-    b. `if`, `else`, `else if`.
397
-
398
-2. Reviewed the use of objects of the `string` class and its `length()` method.
399
-
400
-3. Studied the concepts and instructions for this laboratory session.
401
-
402
-4. Taken the Pre-Lab quiz in Moodle.
403
-
404
----
405
-
406
----
407
-
408
-## Password strength
409
-
410
-Using strong passwords is essential to securing information. A password is considered strong if it is not cost-effective for a hacker to try and guess it using different methods or brute force. For example, a password that consists of a simple dictionary word, without digits, symbols or uppercase letters, is so easy to decipher that even a caveman could do it.
411
-
412
-Since an official system to measure password strength doesn't exist, we will use formulas created by the passwordmeter to evaluate the general strength of a given password [1]. We recommend that you play around a bit with the application in http://passwordmeter.com so that you understand how the application you will be implementing should behave. The strength of the password will be quantified by adding points for using good techniques of password selection (like using symbols and letters), and subtracting points for using bad habits (like only using lowercase letters or consecutive symbols of the same type).
413
-
414
-The following tables review the added and subtracted values for various criteria in passwords:
415
-
416
-
417
-### Assigning points to a password
418
-
419
-#### Adding Points:
420
-
421
----
422
-
423
-
424
-
425
-|      | Category                        | Points                                   | Notes                                                |
426
-| :--- | :-------------------------------- | :-------------------------------------: | ----------------------------------------------------: |
427
-| 1.   | Number of characters             | $$4\left(len\right)$$                                 | $$len$$ is the length of the password                        |
428
-| 2.   | Uppercase letters                | ![addUpper.png](images/small/addUpper.png) | $$n$$ is the number of uppercase letters                |
429
-| 3.   | Lowercase letters                | ![addLower.png](images/small/addLower.png)  | $$n$$ is the number of lowercase letters                |
430
-| 4.   | Digits                          |  ![addDigits.png](images/small/addDigits.png) | $$n$$ is the number of digits                          |
431
-| 5.   | Symbols                        | $$6n$$     | $$n$$ is the number of symbols                       |
432
-| 6.   | Digits or symbols in the middle   | $$2n$$                                    | $$n$$ is the number of digits or symbols in the middle   |
433
-| 7.   | Requisites                       | ![criteria.png](images/small/criteria.png)                              | $$n$$ is the number of criteria that are met        |
434
-
435
-**Table 1.** Positive criteria for password strength.
436
-
437
----
438
-
439
-What follows are some additional details and examples for the criteria of **adding points**.
440
-
441
-1. **Number of characters**: this is the simplestcriteria. The score will be $$4$$ times the length of the password. For example, `"ab453"` has a count of $$5$$ and a score of $$4 \cdot 5 = 20$$.
442
-
443
-2. **Uppercase letters**: the score is $$2 \left(len - n \right)$$ if the password consists of a mix of uppercase letters **AND** at least another type of character (lowercase, digits, symbols). If not, the score is $$0$$. For example,
444
-
445
-  a. the score for `"ab453"` would be $$0$$ since it doesn't have uppercase letters (the count is also $$0$$).
446
-
447
-  b. the score for `"ALGO"` would be $$0$$ since it **only** has uppercase letters (the count is $$4$$).
448
-
449
-  c. the score for `"SANC8in"` would be $$2  \left(7-4\right) = 6$$ since the password has a length of $$7$$, has $$4$$ uppercase letters, and contains characters of another type (the count is $$4$$).
450
-
451
-3. **Lowercase letters**: the score is $$2 \left(len - n\right)$$ if the password is a mix of lowercase letters **AND** at least another type of character (uppercase, digits, symbols). If not, the score is $$0$$. For example,
452
-
453
-  a. the score for `"ab453"` would be $$2 \left(5-2\right) = 6$$ because the password has a length of$$5$$, contains $$2$$ lowercase letters, and contains characters of another type. The count is $$2$$.
454
-
455
-  b. the score for `"ALGO"` would be $$0$$ because it doesn't have lowercase letters. The count is $$0$$.
456
-
457
-  c. the score for `"sancochin"`  would be $$0$$ because it contains **only** lowercase letters. The count is $$9$$.
458
-
459
-4. **Digits**: the score is $4n$ if the password consists of a mix of digits **AND** at least another type of character (lowercase, uppercase, symbols). If not, the score is $$0$$. For example,
460
-
461
-  a. the score for `"ab453"` would be  $$4 \cdot 3 = 12$$ because the password contains $$3$$ digits and contains characters of another type.
462
-
463
-  b. the score for `"ALGO"` would be $$0$$ because it doesn't have digits.
464
-
465
-  c. the score for `801145555` would be $$0$$ because it contains **only** digits.
466
-
467
-5. **Symbols** The score is $$6n$$ if the password contains $$n$$ symbols. Otherwise, the score is $$0$$. For example,
468
-
469
-  a. the score for `"ab453"` would be $$0$$ because it does not contain symbols.
470
-
471
-  b. the score for `"ALGO!!"` would be $$6 \cdot 2$$ because it contains $$2$$ symbols and contains other types of characters.
472
-
473
-  c. the score for `”---><&&”` would be $$6 \cdot 7 = 42$$ because it contains $$7$$ symbols. Note that in the case of symbols, points are given even when there aren't other types of characters.
474
-
475
-6. **Digits or symbols in the middle** The score is $$2n$$ if the password contains symbols or digits that are not in the first or last position. For example,
476
-
477
-  a. the score for `"ab453"` would be $$2 \cdot2 = 4$$ because it contains 2 digits that are not in the first or last position, these are `4` and `5`.
478
-
479
-  b. the score for `"ALGO!"` would be $$0$$ because it does not contain digits or symbols in the middle, the only symbol is in the last position.
480
-
481
-  c. the score for `S&c8i7o!` would be $$2 \cdot 3 = 6$$ because it contains $$3$$ symbols or digits in the middle, these are `&`, 8`, and `7`.
482
-
483
-7. **Requisites**: The score is $$2n$$ only if the length criteria **AND** 3 or 4 of the other criteria are met, where $$n$$ is the number of *criteria* that are met. The criteria are:
484
-
485
-  a. The password must contain 8 or more characters of length.
486
-
487
-  b. Contain:
488
-    - Uppercase letters
489
-    - Lowercase letters
490
-    - Numbers
491
-    - Symbols
492
-
493
-Each of the items listed in part b. count as one individual criteria. For example,
494
-
495
-  a. the score for `"ab453"` would be $$0$$ because the criteria for length is not met.
496
-
497
-  b. the score for `"abABCDEF"` would be $$0$$ because, despite the fact that the length criteria is met, only 2 of the 4 other criteria are met (uppercase and lowercase letters).
498
-
499
-  c. the score for `"abAB99!!"` would be $$2 \cdot 5 = 10$$ because the length criteria and the other 4 criteria are met.
500
-
501
-
502
-#### Subtracting points
503
-
504
----
505
-
506
-|      | Category                         | Points                                   | Notes                                                                  |
507
-| :--- | :-------------------------------- | :-------------------------------------: | ----------------------------------------------------:                   |
508
-| 1.   | Only letters                       |![subsLetters.png](images/small/subsLetters.png)    | $$len$$ is the length of the password                                          |
509
-| 2.   | Only digits                      | ![subsDigits.png](images/small/subsDigits.png)    | $$len$$ is the length of the password                                           |
510
-| 3.   | Consecutive uppercase letters    | $$-2n$$                                   | $$n$$ is the number of uppercase letters that follow another uppercase letter |
511
-| 4.   | Consecutive lowercase letters   | $$-2n$$                                   | $$n$$ is the number of lowercase letters that follow another lowercase letter                                                                     |
512
-| 5.   | Consecutive digits             | $$-2n$$                                   | $$n$$ is the number of digits that follow another digit                     |
513
-
514
-
515
-**Table 2.** Negative criteria for password strength.
516
-
517
----
518
-
519
-The following are additional details and examples of the criteria for **subtracting points**.
520
-
521
-1. **Only letters**: The score is $$-len$$ for a password that consists of letters only, otherwise it is $$0$$. For example,
522
-
523
-  a. the score for `"ab453"` would be $$0$$ since it contains letters and numbers.
524
-
525
-  b. the score for `"Barrunto"` would be $$-8$$ since it only contains letters and its length is $$8$$.
526
-
527
-2. **Only digits**: The score is $$-len$$ for a password that consists of digits only, otherwise it is $$0$$. For example,
528
-
529
-  a. the score for `"ab453"` would be $$0$$ since it contains only letters and numbers.
530
-
531
-  b. the score for `”987987987”` would be $$-9$$ since it contains only digits and its length is $$9$$.
532
-
533
-3. **Consecutive uppercase letters**: The score is $$-2n$$ where $$n$$ is the number of uppercase letters that follow another uppercase letter. For example,
534
-
535
-  a. the score for `"DB453"` would be $$-2 \cdot 1 = -2$$ since it only contains one uppercase letter (`B`) that follows another uppercase letter.
536
-
537
-  b. the score for `"TNS1PBMA"` would be $$-2 \cdot 5 = -10$$ since it contains 5 uppercase letters (`N`, `S`, `B`, `M`, `A`) that follow another uppercase letter.
538
-
539
-4. **Consecutive lowercase letters**: The same as for criteria #3 but for lowercase letters.
540
-
541
-5. **Consecutive digits**: The same as for criteria #3 but for digits.
542
-
543
-
544
----
545
-
546
----
547
-
548
-!INCLUDE "../../eip-diagnostic/password-strength/en/diag-password-strength-01.html"
549
-
550
-!INCLUDE "../../eip-diagnostic/password-strength/en/diag-password-strength-02.html"
551
-
552
-!INCLUDE "../../eip-diagnostic/password-strength/en/diag-password-strength-03.html"
553
-
554
-!INCLUDE "../../eip-diagnostic/password-strength/en/diag-password-strength-04.html"
555
-
556
-!INCLUDE "../../eip-diagnostic/password-strength/en/diag-password-strength-05.html"
557
-
558
----
559
-
560
----
561
-
562
-## Laboratory session:
563
-
564
-In this laboratory session you will practice the use of mathematical expressions and conditional structures to compute the score for the strength of a password combining the points for the individual criteria.
565
-
566
-Your task is to complete the design of the application to measure the strength of a password. When done, you will obtain a simplified version of the application in http://www.passwordmeter.com/. Since there isn't an official system to measure passwords, the formulas created by "passwordmeter" will be used to evaluate the general strength of a given password. The application will allow users to enter a password and calculate its strength using a series of rules.
567
-
568
-The strength of the password will be quantified by adding points for using good password selection techniques (like combining symbols and letters) and subtracting points for using bad habits (like using only uppercase letters or consecutive symbols of the same type). Your program will analyze the password given by the user and use the criteria in the tables presented above to compute a score for the password's strength.
569
-
570
-Once the application is complete, it will show a window where, as the password characters are entered, the partial score will be displayed. This graphical interface will offer the user a way to improve his password and correct typical weak password habits.
571
-
572
-
573
-
574
-
575
-### Exercise 1: Familiarize yourself with the pre-defined functions
576
-
577
-The first step in this laboratory experience is to familiarize yourself with the functions that are pre-defined in the code.  You will call these functions as part of your own code to compute the score of the various password strength criteria.
578
-
579
-**Instructions**
580
-
581
-1. Load the project `PassworStrength` onto Qt by double clicking the file `PasswordStrength.pro` in the directory `Documents/eip/Conditionals-PasswordStrength` of your computer. You can also go to `http://bitbucket.org/eip-uprrp/conditionals-passwordstrength` to download the folder `Conditionals-PasswordStrength` to your computer.
582
-
583
-2. Configure the project. The project consists of several files. **You will only write code in the file  `readpassword.cpp`. You should not make any changes in the other files.** Despite this, you should familiarize yourself with the functions that are already defined in them, since you will be using some of them to create your code.
584
-
585
-  * `psfunctions.cpp` : contains the implementations of some of the functions that will invoke in your program to calculate the score for the password's strength. **You do not have to change anything in this file or in the file `psfunctions.h`**. Simply invoke the functions as necessary from the `readPass` function in the `readpassword.cpp` file. Note that the function names tell you what the functions do.
586
-
587
-  * `psfunctions.h` : contains the prototypes for the functions defined in `psfunctions.cpp`.
588
-
589
-
590
-### Exercise 2: Understand the functions to update the user's graphical interface.
591
-
592
-In the laboratory exercise you will write code to calculate the score associated to each one of the criteria in the tables for adding and subtracting points shown above. These scores should be updated in the user's graphical interface that is shown in Figure 1.
593
-
594
----
595
-
596
-![interfaceGrafica.png](images/interfaceGrafica.png)
597
-
598
-**Figure 1.** User graphical interface for *Password strength* project.
599
-
600
----
601
-
602
-There are predefined functions that update the graphical interface. For the application to work properly, each time that your code computes the score that is given for each criteria you should invoke the function to update that particular criteria in the graphical interface. The functions to update the criteria have the following syntax:
603
-
604
-
605
-  ```
606
-  void setCRITERIA(int count, int score) ;
607
-  ```
608
-
609
-  where CRITERIA should be replaced by the criteria that is being evaluated. Observe that the function requires two arguments: the **count** that is the amount of characters that meet the criteria and the **score** that is the calculation that you will implement following the tables presented above. For example,
610
-
611
-  ```
612
-  count = pass.length() ;
613
-  score = 4 * count ;
614
-  setNumberOfCharacters(count, score);
615
-  totalScore += score ;
616
-
617
-  ```
618
-
619
-  In the above code `count` contains the number of characters in the password, `score` contains the computation for the score of the criteria for the number of characters, and `setNumberOfCharacters(count, score);` invokes the function to update the corresponding information for the criteria "Number of characters" in the graphical interface.
620
-
621
-  The functions to update the graphical interface are:
622
-    ```
623
-    // To update the password's length.
624
-    void setNumberOfCharacters(int count, int score) ;  
625
-
626
-    // For adding points
627
-
628
-    // To update the uppercase characters.
629
-    void setUpperCharacters(int count, int score) ;
630
-
631
-    // To update the lowercase characters.
632
-    void setLowerCharacters(int count, int score) ;
633
-
634
-    // To update the characters that are digits.
635
-    void setDigits(int count, int score) ;
636
-
637
-    // To update the characters that are symbols.
638
-    void setSymbols(int count, int score) ;
639
-
640
-    // To update the digits or symbols in the middle
641
-    void setMiddleDigitsOrSymbols(int count, int score) ;
642
-
643
-    // To update the criterium of the requisites
644
-    void setRequirements(int count, int score) ;
645
-
646
-    // For subtracting points
647
-
648
-    // To update the criterium of only letters.
649
-    void setLettersOnly(int count, int score) ;
650
-
651
-    // To update the criterium of only digits.
652
-    void setDigitsOnly(int count, int score) ;
653
-
654
-    // To update the criterium of consecutive uppercase letters.
655
-    void setConsecutiveUpper(int count, int score) ;
656
-
657
-    // To update the criterium of consecutive lowercase letters.
658
-    void setConsecutiveLower(int count, int score) ;
659
-
660
-    // To update the criterium of consecutive digits.
661
-    void setConsecutiveDigits(int count, int score) ;
662
-    ```
663
-
664
-
665
-
666
-### Exercise 3: Compute the score for the criteria and the total score for the password
667
-
668
-The code that we're providing you contains the functions that compute the count for the majority of the criteria and whose names reflect what they do and what the function returns. For example, `countUppercase`, return the number of characters that are uppercase letters.
669
-
670
-[Here](http://ccom.uprrp.edu/~rarce/ccom3033f14/documentation/passwordStrengthCL/psfunctions_8cpp.html) is a list and description of the functions.
671
-
672
-Your task is to use mathematical expressions and decision structures for the individual criteria scores and combine them to compute the total score for the password's strength.
673
-
674
-**Example 1:**
675
-
676
----
677
-
678
-![ventanaCaba77o.png](images/ventanaCaba77o.png)
679
-
680
-**Figure 2.** Window with the report for the password `caba77o`.
681
-
682
----
683
-
684
-
685
-
686
-**Example 2:**
687
-
688
----
689
-
690
-![ventanaS1nf@nia!.png](images/ventanaS1nf@nia!.png)
691
-
692
-**Figure 3.** Window with the report for the password `S1nf@nia!`.
693
-
694
----
695
-
696
-In Example 2, the number of **requisites** is 5 because `"S1nf@nia!"` meets the criteria for length and also contains uppercase letters, lowercase letters, numbers and symbols. Therefore, the score for the number of requisites is $2 \cdot 5 =10$.
697
-
698
-In the project's code you will find examples of how to calculate the first two positive criteria: the number of characters in the password and the numbers of uppercase letters. You can compile and execute the example so you can see the working interface with these two criteria. Part of your task is to add the code to compute the score for the remaining criteria. Remember that you should accumulate the total score and invoke the functions to update the graphical interface.
699
-
700
-
701
-### Exercise 4: Determine and display the password's strength
702
-
703
-The password is entered in the top section of the graphical interface. The user will input the password in the top section of the graphical interface. Below appears the *report* that contains the different criteria, the count for each criteria, and the individual score for the criteria. This report will be updated as the user inputs the password's characters. The total score will be the sum of all of the points (addition and subtraction) of the individual criteria.
704
-
705
-Based on the total score, the program will classify the password's strength as follows:
706
-
707
-|   Total score   |  Strength   |
708
-|-----------------|-------------|
709
-| [0,20)          | Very weak   |
710
-| [20,40)         | Weak        |
711
-| [40,60)         | Good        |
712
-| [60,80)         | Strong      |
713
-| [80,100]        | Very strong |
714
-
715
-
716
-The provided code already invokes the `strengthDisplay` function with the strength calculated and the total score to update the classification, and the bar that indicates the password's strength in the graphical interface.
717
-
718
----
719
-
720
----
721
-
722
-## Deliverables
723
-
724
-Use "Deliverables" in Moodle to upload the `readpassword.cpp` file that contains the code with the computation for the score of the individual criteria, the final score, the function calls to update the graphical interface, the password's classification and the display functions. Remember to use good programming techniques, include the name of the programmers involved, and to document your program.
725
-
726
-
727
-
728
----
729
-
730
----
731
-
732
-## References
733
-
734
-[1] Passwordmeter, http://www.passwordmeter.com/
1
+## [\[English\]](README-en.md) - for README in English
2
+## [\[Spanish\]](README-es.md) - for README in Spanish