Skip to content

Commit

Permalink
fix: Generate timestamps independently from current locale
Browse files Browse the repository at this point in the history
Inspired by wsgiref.handlers.format_date_time()
  • Loading branch information
marty-se committed Apr 26, 2022
1 parent 971314c commit 96bf825
Show file tree
Hide file tree
Showing 2 changed files with 58 additions and 6 deletions.
35 changes: 29 additions & 6 deletions pycognito/aws_srp.py
Original file line number Diff line number Diff line change
Expand Up @@ -202,18 +202,41 @@ def get_secret_hash(username, client_id, client_secret):
hmac_obj = hmac.new(bytearray(client_secret, "utf-8"), message, hashlib.sha256)
return base64.standard_b64encode(hmac_obj.digest()).decode("utf-8")

@staticmethod
def get_cognito_formatted_timestamp(input_datetime):
weekday_names = ["Mon", "Tue", "Wed", "Thu", "Fri", "Sat", "Sun"]
month_names = [
"Jan",
"Feb",
"Mar",
"Apr",
"May",
"Jun",
"Jul",
"Aug",
"Sep",
"Oct",
"Nov",
"Dec",
]

return "%s %s %d %02d:%02d:%02d UTC %d" % (
weekday_names[input_datetime.weekday()],
month_names[input_datetime.month - 1],
input_datetime.day,
input_datetime.hour,
input_datetime.minute,
input_datetime.second,
input_datetime.year,
)

def process_challenge(self, challenge_parameters):
internal_username = challenge_parameters["USERNAME"]
user_id_for_srp = challenge_parameters["USER_ID_FOR_SRP"]
salt_hex = challenge_parameters["SALT"]
srp_b_hex = challenge_parameters["SRP_B"]
secret_block_b64 = challenge_parameters["SECRET_BLOCK"]
# re strips leading zero from a day number (required by AWS Cognito)
timestamp = re.sub(
r" 0(\d) ",
r" \1 ",
datetime.datetime.utcnow().strftime("%a %b %d %H:%M:%S UTC %Y"),
)
timestamp = self.get_cognito_formatted_timestamp(datetime.datetime.utcnow())
hkdf = self.get_password_authentication_key(
user_id_for_srp, self.password, hex_to_long(srp_b_hex), salt_hex
)
Expand Down
29 changes: 29 additions & 0 deletions tests.py
Original file line number Diff line number Diff line change
Expand Up @@ -364,6 +364,35 @@ def test_authenticate_user(self, _):
self.assertTrue("RefreshToken" in tokens["AuthenticationResult"])
stub.assert_no_pending_responses()

def test_cognito_formatted_timestamp(self):
self.assertEqual(
self.aws.get_cognito_formatted_timestamp(
datetime.datetime(2022, 1, 1, 0, 0, 0)
),
"Sat Jan 1 00:00:00 UTC 2022",
)

self.assertEqual(
self.aws.get_cognito_formatted_timestamp(
datetime.datetime(2022, 1, 2, 12, 0, 0)
),
"Sun Jan 2 12:00:00 UTC 2022",
)

self.assertEqual(
self.aws.get_cognito_formatted_timestamp(
datetime.datetime(2022, 1, 3, 9, 0, 0)
),
"Mon Jan 3 09:00:00 UTC 2022",
)

self.assertEqual(
self.aws.get_cognito_formatted_timestamp(
datetime.datetime(2022, 12, 31, 23, 59, 59)
),
"Sat Dec 31 23:59:59 UTC 2022",
)


@moto.mock_cognitoidp
class UtilsTestCase(unittest.TestCase):
Expand Down

0 comments on commit 96bf825

Please sign in to comment.