Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add group parameters checks to SRP6IntegerVariable #27

Open
Glusk opened this issue Jan 1, 2021 · 1 comment
Open

Add group parameters checks to SRP6IntegerVariable #27

Glusk opened this issue Jan 1, 2021 · 1 comment

Comments

@Glusk
Copy link
Owner

Glusk commented Jan 1, 2021

  • check if a variable is a safe prime of the form: p = 2q + 1, where p and q are prime numbers
  • check if a variable is generator or a primitive root modulo N
@Glusk Glusk changed the title Add checks to SRP6IntegerVariable Add group parameters checks to SRP6IntegerVariable Jan 1, 2021
@Glusk
Copy link
Owner Author

Glusk commented Dec 25, 2022

Generators

If p is a prime, and g is less than p, then g is a generator mod p if

  • for each b from 1 to p - 1, there exists some a where ga ≡ b (mod p).

Another way of saying this is that g is primitive with respect to p.

For example, if p = 11, 2 is a generator mod 11:

  • 210 = 1024 ≡ 1 (mod 11)
  • 21 = 2 ≡ 2 (mod 11)
  • 28 = 256 ≡ 3 (mod 11)
  • 22 = 4 ≡ 4 (mod 11)
  • 24 = 16 ≡ 5 (mod 11)
  • 29 = 512 ≡ 6 (mod 11)
  • 27 = 128 ≡ 7 (mod 11)
  • 23 = 8 ≡ 8 (mod 11)
  • 26 = 64 ≡ 9 (mod 11)
  • 25 = 32 ≡ 10 (mod 11)

Every number from 1 to 10 can be expressed as 2a (mod p).

For p = 11, the generators are 2, 6, 7, and 8. The other numbers are not generators. For example, 3 is not a generator because there is no solution to

  • 3a = 2 mod 11

In general, testing whether a given number is a generator is not an easy problem. It is easy, however, if you know the factorization of p - 1. Let q1, q2,..., qn be the distinct prime factors of p - 1. To test whether a number g is a generator mod p, calculate

  • g(p- 1)/q mod p

for all values of q = q1, q2,..., qn.

If that number equals 1 for some value of q, then g is not a generator. If that value does not equal 1 for any values of q, then g is a generator.

For example, let p = 11. The prime factors of p - 1 = 10 are 2 and 5. To test whether 2 is a generator:

  • 2(11- 1)/5 mod 11 = 4
  • 2(11- 1)/2 mod 11 = 10

Neither result is 1, so 2 is a generator.

To test whether 3 is a generator:

  • 3(11- 1)/5 mod 11 = 9
  • 3(11- 1)/2 mod 11 = 1

Therefore, 3 is not a generator.

If you need to find a generator mod p, simply choose a random number from 1 to p - 1 and test whether it is a generator. Enough of them will be, so you’ll probably find one fast.

[Source]: Applied Cryptography: Protocols, Algorithms, and Source Code in C (2nd Edition) by Bruce Schneier

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant