From fb3fa1b1479e2244a571d237ac821c9c4302e55c Mon Sep 17 00:00:00 2001 From: Charley Cunningham Date: Sat, 4 Nov 2023 19:56:55 -0400 Subject: [PATCH] Reformat with latest black version --- backend/Pipfile | 2 +- backend/Pipfile.lock | 928 +++++++++--------- backend/Platform/settings/base.py | 12 +- backend/accounts/admin.py | 4 +- backend/accounts/backends.py | 6 +- backend/accounts/migrations/0001_initial.py | 25 +- .../migrations/0002_auto_20200213_1711.py | 5 +- .../migrations/0003_auto_20210918_2041.py | 5 +- .../migrations/0004_user_profile_pic.py | 1 - .../0005_privacyresource_privacysetting.py | 1 - backend/accounts/mixins.py | 22 +- backend/accounts/models.py | 23 +- backend/accounts/serializers.py | 52 +- backend/accounts/update_majors.py | 8 +- backend/accounts/views.py | 36 +- backend/identity/utils.py | 4 +- backend/identity/views.py | 6 +- backend/tests/accounts/test_admin.py | 12 +- backend/tests/accounts/test_backends.py | 20 +- backend/tests/accounts/test_serializers.py | 48 +- backend/tests/accounts/test_verification.py | 12 +- backend/tests/accounts/test_views.py | 141 +-- backend/tests/identity/test_views.py | 12 +- 23 files changed, 561 insertions(+), 824 deletions(-) diff --git a/backend/Pipfile b/backend/Pipfile index 832ac951..12185043 100644 --- a/backend/Pipfile +++ b/backend/Pipfile @@ -4,7 +4,7 @@ url = "https://pypi.org/simple" verify_ssl = true [dev-packages] -black = "==21.9b0" +black = "==23.10.1" unittest-xml-reporting = "*" flake8 = "*" flake8-isort = "*" diff --git a/backend/Pipfile.lock b/backend/Pipfile.lock index 0105d7e6..e36fb489 100644 --- a/backend/Pipfile.lock +++ b/backend/Pipfile.lock @@ -1,7 +1,7 @@ { "_meta": { "hash": { - "sha256": "f76b09120edc94d74def7b4673187fa7a2e460723f3310c3ff71e3074d75344c" + "sha256": "c587876dd6e88b33d5a56dd69f195ac256ef97cb159a855e8cbcf54cedf1785c" }, "pipfile-spec": 6, "requires": { @@ -18,96 +18,96 @@ "default": { "aiohttp": { "hashes": [ - "sha256:00ad4b6f185ec67f3e6562e8a1d2b69660be43070bd0ef6fcec5211154c7df67", - "sha256:0175d745d9e85c40dcc51c8f88c74bfbaef9e7afeeeb9d03c37977270303064c", - "sha256:01d4c0c874aa4ddfb8098e85d10b5e875a70adc63db91f1ae65a4b04d3344cda", - "sha256:043d2299f6dfdc92f0ac5e995dfc56668e1587cea7f9aa9d8a78a1b6554e5755", - "sha256:0c413c633d0512df4dc7fd2373ec06cc6a815b7b6d6c2f208ada7e9e93a5061d", - "sha256:0d21c684808288a98914e5aaf2a7c6a3179d4df11d249799c32d1808e79503b5", - "sha256:0e584a10f204a617d71d359fe383406305a4b595b333721fa50b867b4a0a1548", - "sha256:1274477e4c71ce8cfe6c1ec2f806d57c015ebf84d83373676036e256bc55d690", - "sha256:13bf85afc99ce6f9ee3567b04501f18f9f8dbbb2ea11ed1a2e079670403a7c84", - "sha256:153c2549f6c004d2754cc60603d4668899c9895b8a89397444a9c4efa282aaf4", - "sha256:1f7372f7341fcc16f57b2caded43e81ddd18df53320b6f9f042acad41f8e049a", - "sha256:23fb25a9f0a1ca1f24c0a371523546366bb642397c94ab45ad3aedf2941cec6a", - "sha256:28c543e54710d6158fc6f439296c7865b29e0b616629767e685a7185fab4a6b9", - "sha256:2a482e6da906d5e6e653be079b29bc173a48e381600161c9932d89dfae5942ef", - "sha256:2ad5c3c4590bb3cc28b4382f031f3783f25ec223557124c68754a2231d989e2b", - "sha256:2ce2ac5708501afc4847221a521f7e4b245abf5178cf5ddae9d5b3856ddb2f3a", - "sha256:2cf57fb50be5f52bda004b8893e63b48530ed9f0d6c96c84620dc92fe3cd9b9d", - "sha256:2e1b1e51b0774408f091d268648e3d57f7260c1682e7d3a63cb00d22d71bb945", - "sha256:2e2e9839e14dd5308ee773c97115f1e0a1cb1d75cbeeee9f33824fa5144c7634", - "sha256:2e460be6978fc24e3df83193dc0cc4de46c9909ed92dd47d349a452ef49325b7", - "sha256:312fcfbacc7880a8da0ae8b6abc6cc7d752e9caa0051a53d217a650b25e9a691", - "sha256:33279701c04351a2914e1100b62b2a7fdb9a25995c4a104259f9a5ead7ed4802", - "sha256:33776e945d89b29251b33a7e7d006ce86447b2cfd66db5e5ded4e5cd0340585c", - "sha256:34dd0c107799dcbbf7d48b53be761a013c0adf5571bf50c4ecad5643fe9cfcd0", - "sha256:3562b06567c06439d8b447037bb655ef69786c590b1de86c7ab81efe1c9c15d8", - "sha256:368a42363c4d70ab52c2c6420a57f190ed3dfaca6a1b19afda8165ee16416a82", - "sha256:4149d34c32f9638f38f544b3977a4c24052042affa895352d3636fa8bffd030a", - "sha256:461908b2578955045efde733719d62f2b649c404189a09a632d245b445c9c975", - "sha256:4a01951fabc4ce26ab791da5f3f24dca6d9a6f24121746eb19756416ff2d881b", - "sha256:4e874cbf8caf8959d2adf572a78bba17cb0e9d7e51bb83d86a3697b686a0ab4d", - "sha256:4f21e83f355643c345177a5d1d8079f9f28b5133bcd154193b799d380331d5d3", - "sha256:5443910d662db951b2e58eb70b0fbe6b6e2ae613477129a5805d0b66c54b6cb7", - "sha256:5798a9aad1879f626589f3df0f8b79b3608a92e9beab10e5fda02c8a2c60db2e", - "sha256:5d20003b635fc6ae3f96d7260281dfaf1894fc3aa24d1888a9b2628e97c241e5", - "sha256:5db3a5b833764280ed7618393832e0853e40f3d3e9aa128ac0ba0f8278d08649", - "sha256:5ed1c46fb119f1b59304b5ec89f834f07124cd23ae5b74288e364477641060ff", - "sha256:62360cb771707cb70a6fd114b9871d20d7dd2163a0feafe43fd115cfe4fe845e", - "sha256:6809a00deaf3810e38c628e9a33271892f815b853605a936e2e9e5129762356c", - "sha256:68c5a82c8779bdfc6367c967a4a1b2aa52cd3595388bf5961a62158ee8a59e22", - "sha256:6e4a280e4b975a2e7745573e3fc9c9ba0d1194a3738ce1cbaa80626cc9b4f4df", - "sha256:6e6783bcc45f397fdebc118d772103d751b54cddf5b60fbcc958382d7dd64f3e", - "sha256:72a860c215e26192379f57cae5ab12b168b75db8271f111019509a1196dfc780", - "sha256:7607ec3ce4993464368505888af5beb446845a014bc676d349efec0e05085905", - "sha256:773dd01706d4db536335fcfae6ea2440a70ceb03dd3e7378f3e815b03c97ab51", - "sha256:78d847e4cde6ecc19125ccbc9bfac4a7ab37c234dd88fbb3c5c524e8e14da543", - "sha256:7dde0009408969a43b04c16cbbe252c4f5ef4574ac226bc8815cd7342d2028b6", - "sha256:80bd372b8d0715c66c974cf57fe363621a02f359f1ec81cba97366948c7fc873", - "sha256:841cd8233cbd2111a0ef0a522ce016357c5e3aff8a8ce92bcfa14cef890d698f", - "sha256:84de26ddf621d7ac4c975dbea4c945860e08cccde492269db4e1538a6a6f3c35", - "sha256:84f8ae3e09a34f35c18fa57f015cc394bd1389bce02503fb30c394d04ee6b938", - "sha256:8af740fc2711ad85f1a5c034a435782fbd5b5f8314c9a3ef071424a8158d7f6b", - "sha256:8b929b9bd7cd7c3939f8bcfffa92fae7480bd1aa425279d51a89327d600c704d", - "sha256:910bec0c49637d213f5d9877105d26e0c4a4de2f8b1b29405ff37e9fc0ad52b8", - "sha256:96943e5dcc37a6529d18766597c491798b7eb7a61d48878611298afc1fca946c", - "sha256:a0215ce6041d501f3155dc219712bc41252d0ab76474615b9700d63d4d9292af", - "sha256:a3cf433f127efa43fee6b90ea4c6edf6c4a17109d1d037d1a52abec84d8f2e42", - "sha256:a6ce61195c6a19c785df04e71a4537e29eaa2c50fe745b732aa937c0c77169f3", - "sha256:a7a75ef35f2df54ad55dbf4b73fe1da96f370e51b10c91f08b19603c64004acc", - "sha256:a94159871304770da4dd371f4291b20cac04e8c94f11bdea1c3478e557fbe0d8", - "sha256:aa1990247f02a54185dc0dff92a6904521172a22664c863a03ff64c42f9b5410", - "sha256:ab88bafedc57dd0aab55fa728ea10c1911f7e4d8b43e1d838a1739f33712921c", - "sha256:ad093e823df03bb3fd37e7dec9d4670c34f9e24aeace76808fc20a507cace825", - "sha256:ae871a964e1987a943d83d6709d20ec6103ca1eaf52f7e0d36ee1b5bebb8b9b9", - "sha256:b0ba0d15164eae3d878260d4c4df859bbdc6466e9e6689c344a13334f988bb53", - "sha256:b5411d82cddd212644cf9360879eb5080f0d5f7d809d03262c50dad02f01421a", - "sha256:b9552ec52cc147dbf1944ac7ac98af7602e51ea2dcd076ed194ca3c0d1c7d0bc", - "sha256:bfb9162dcf01f615462b995a516ba03e769de0789de1cadc0f916265c257e5d8", - "sha256:c0a9034379a37ae42dea7ac1e048352d96286626251862e448933c0f59cbd79c", - "sha256:c1161b345c0a444ebcf46bf0a740ba5dcf50612fd3d0528883fdc0eff578006a", - "sha256:c11f5b099adafb18e65c2c997d57108b5bbeaa9eeee64a84302c0978b1ec948b", - "sha256:c44e65da1de4403d0576473e2344828ef9c4c6244d65cf4b75549bb46d40b8dd", - "sha256:c48c5c0271149cfe467c0ff8eb941279fd6e3f65c9a388c984e0e6cf57538e14", - "sha256:c7a815258e5895d8900aec4454f38dca9aed71085f227537208057853f9d13f2", - "sha256:cae533195e8122584ec87531d6df000ad07737eaa3c81209e85c928854d2195c", - "sha256:cc14be025665dba6202b6a71cfcdb53210cc498e50068bc088076624471f8bb9", - "sha256:cd56db019015b6acfaaf92e1ac40eb8434847d9bf88b4be4efe5bfd260aee692", - "sha256:d827176898a2b0b09694fbd1088c7a31836d1a505c243811c87ae53a3f6273c1", - "sha256:df72ac063b97837a80d80dec8d54c241af059cc9bb42c4de68bd5b61ceb37caa", - "sha256:e5980a746d547a6ba173fd5ee85ce9077e72d118758db05d229044b469d9029a", - "sha256:e5d47ae48db0b2dcf70bc8a3bc72b3de86e2a590fc299fdbbb15af320d2659de", - "sha256:e91d635961bec2d8f19dfeb41a539eb94bd073f075ca6dae6c8dc0ee89ad6f91", - "sha256:ea353162f249c8097ea63c2169dd1aa55de1e8fecbe63412a9bc50816e87b761", - "sha256:eaeed7abfb5d64c539e2db173f63631455f1196c37d9d8d873fc316470dfbacd", - "sha256:eca4bf3734c541dc4f374ad6010a68ff6c6748f00451707f39857f429ca36ced", - "sha256:f83a552443a526ea38d064588613aca983d0ee0038801bc93c0c916428310c28", - "sha256:fb1558def481d84f03b45888473fc5a1f35747b5f334ef4e7a571bc0dfcb11f8", - "sha256:fd1ed388ea7fbed22c4968dd64bab0198de60750a25fe8c0c9d4bef5abe13824" + "sha256:002f23e6ea8d3dd8d149e569fd580c999232b5fbc601c48d55398fbc2e582e8c", + "sha256:01770d8c04bd8db568abb636c1fdd4f7140b284b8b3e0b4584f070180c1e5c62", + "sha256:0912ed87fee967940aacc5306d3aa8ba3a459fcd12add0b407081fbefc931e53", + "sha256:0cccd1de239afa866e4ce5c789b3032442f19c261c7d8a01183fd956b1935349", + "sha256:0fa375b3d34e71ccccf172cab401cd94a72de7a8cc01847a7b3386204093bb47", + "sha256:13da35c9ceb847732bf5c6c5781dcf4780e14392e5d3b3c689f6d22f8e15ae31", + "sha256:14cd52ccf40006c7a6cd34a0f8663734e5363fd981807173faf3a017e202fec9", + "sha256:16d330b3b9db87c3883e565340d292638a878236418b23cc8b9b11a054aaa887", + "sha256:1bed815f3dc3d915c5c1e556c397c8667826fbc1b935d95b0ad680787896a358", + "sha256:1d84166673694841d8953f0a8d0c90e1087739d24632fe86b1a08819168b4566", + "sha256:1f13f60d78224f0dace220d8ab4ef1dbc37115eeeab8c06804fec11bec2bbd07", + "sha256:229852e147f44da0241954fc6cb910ba074e597f06789c867cb7fb0621e0ba7a", + "sha256:253bf92b744b3170eb4c4ca2fa58f9c4b87aeb1df42f71d4e78815e6e8b73c9e", + "sha256:255ba9d6d5ff1a382bb9a578cd563605aa69bec845680e21c44afc2670607a95", + "sha256:2817b2f66ca82ee699acd90e05c95e79bbf1dc986abb62b61ec8aaf851e81c93", + "sha256:2b8d4e166e600dcfbff51919c7a3789ff6ca8b3ecce16e1d9c96d95dd569eb4c", + "sha256:2d5b785c792802e7b275c420d84f3397668e9d49ab1cb52bd916b3b3ffcf09ad", + "sha256:3161ce82ab85acd267c8f4b14aa226047a6bee1e4e6adb74b798bd42c6ae1f80", + "sha256:33164093be11fcef3ce2571a0dccd9041c9a93fa3bde86569d7b03120d276c6f", + "sha256:39a312d0e991690ccc1a61f1e9e42daa519dcc34ad03eb6f826d94c1190190dd", + "sha256:3b2ab182fc28e7a81f6c70bfbd829045d9480063f5ab06f6e601a3eddbbd49a0", + "sha256:3c68330a59506254b556b99a91857428cab98b2f84061260a67865f7f52899f5", + "sha256:3f0e27e5b733803333bb2371249f41cf42bae8884863e8e8965ec69bebe53132", + "sha256:3f5c7ce535a1d2429a634310e308fb7d718905487257060e5d4598e29dc17f0b", + "sha256:3fd194939b1f764d6bb05490987bfe104287bbf51b8d862261ccf66f48fb4096", + "sha256:41bdc2ba359032e36c0e9de5a3bd00d6fb7ea558a6ce6b70acedf0da86458321", + "sha256:41d55fc043954cddbbd82503d9cc3f4814a40bcef30b3569bc7b5e34130718c1", + "sha256:42c89579f82e49db436b69c938ab3e1559e5a4409eb8639eb4143989bc390f2f", + "sha256:45ad816b2c8e3b60b510f30dbd37fe74fd4a772248a52bb021f6fd65dff809b6", + "sha256:4ac39027011414dbd3d87f7edb31680e1f430834c8cef029f11c66dad0670aa5", + "sha256:4d4cbe4ffa9d05f46a28252efc5941e0462792930caa370a6efaf491f412bc66", + "sha256:4fcf3eabd3fd1a5e6092d1242295fa37d0354b2eb2077e6eb670accad78e40e1", + "sha256:5d791245a894be071d5ab04bbb4850534261a7d4fd363b094a7b9963e8cdbd31", + "sha256:6c43ecfef7deaf0617cee936836518e7424ee12cb709883f2c9a1adda63cc460", + "sha256:6c5f938d199a6fdbdc10bbb9447496561c3a9a565b43be564648d81e1102ac22", + "sha256:6e2f9cc8e5328f829f6e1fb74a0a3a939b14e67e80832975e01929e320386b34", + "sha256:713103a8bdde61d13490adf47171a1039fd880113981e55401a0f7b42c37d071", + "sha256:71783b0b6455ac8f34b5ec99d83e686892c50498d5d00b8e56d47f41b38fbe04", + "sha256:76b36b3124f0223903609944a3c8bf28a599b2cc0ce0be60b45211c8e9be97f8", + "sha256:7bc88fc494b1f0311d67f29fee6fd636606f4697e8cc793a2d912ac5b19aa38d", + "sha256:7ee912f7e78287516df155f69da575a0ba33b02dd7c1d6614dbc9463f43066e3", + "sha256:86f20cee0f0a317c76573b627b954c412ea766d6ada1a9fcf1b805763ae7feeb", + "sha256:89341b2c19fb5eac30c341133ae2cc3544d40d9b1892749cdd25892bbc6ac951", + "sha256:8a9b5a0606faca4f6cc0d338359d6fa137104c337f489cd135bb7fbdbccb1e39", + "sha256:8d399dade330c53b4106160f75f55407e9ae7505263ea86f2ccca6bfcbdb4921", + "sha256:8e31e9db1bee8b4f407b77fd2507337a0a80665ad7b6c749d08df595d88f1cf5", + "sha256:90c72ebb7cb3a08a7f40061079817133f502a160561d0675b0a6adf231382c92", + "sha256:918810ef188f84152af6b938254911055a72e0f935b5fbc4c1a4ed0b0584aed1", + "sha256:93c15c8e48e5e7b89d5cb4613479d144fda8344e2d886cf694fd36db4cc86865", + "sha256:96603a562b546632441926cd1293cfcb5b69f0b4159e6077f7c7dbdfb686af4d", + "sha256:99c5ac4ad492b4a19fc132306cd57075c28446ec2ed970973bbf036bcda1bcc6", + "sha256:9c19b26acdd08dd239e0d3669a3dddafd600902e37881f13fbd8a53943079dbc", + "sha256:9de50a199b7710fa2904be5a4a9b51af587ab24c8e540a7243ab737b45844543", + "sha256:9e2ee0ac5a1f5c7dd3197de309adfb99ac4617ff02b0603fd1e65b07dc772e4b", + "sha256:a2ece4af1f3c967a4390c284797ab595a9f1bc1130ef8b01828915a05a6ae684", + "sha256:a3628b6c7b880b181a3ae0a0683698513874df63783fd89de99b7b7539e3e8a8", + "sha256:ad1407db8f2f49329729564f71685557157bfa42b48f4b93e53721a16eb813ed", + "sha256:b04691bc6601ef47c88f0255043df6f570ada1a9ebef99c34bd0b72866c217ae", + "sha256:b0cf2a4501bff9330a8a5248b4ce951851e415bdcce9dc158e76cfd55e15085c", + "sha256:b2fe42e523be344124c6c8ef32a011444e869dc5f883c591ed87f84339de5976", + "sha256:b30e963f9e0d52c28f284d554a9469af073030030cef8693106d918b2ca92f54", + "sha256:bb54c54510e47a8c7c8e63454a6acc817519337b2b78606c4e840871a3e15349", + "sha256:bd111d7fc5591ddf377a408ed9067045259ff2770f37e2d94e6478d0f3fc0c17", + "sha256:bdf70bfe5a1414ba9afb9d49f0c912dc524cf60141102f3a11143ba3d291870f", + "sha256:ca80e1b90a05a4f476547f904992ae81eda5c2c85c66ee4195bb8f9c5fb47f28", + "sha256:caf486ac1e689dda3502567eb89ffe02876546599bbf915ec94b1fa424eeffd4", + "sha256:ccc360e87341ad47c777f5723f68adbb52b37ab450c8bc3ca9ca1f3e849e5fe2", + "sha256:d25036d161c4fe2225d1abff2bd52c34ed0b1099f02c208cd34d8c05729882f0", + "sha256:d52d5dc7c6682b720280f9d9db41d36ebe4791622c842e258c9206232251ab2b", + "sha256:d67f8baed00870aa390ea2590798766256f31dc5ed3ecc737debb6e97e2ede78", + "sha256:d76e8b13161a202d14c9584590c4df4d068c9567c99506497bdd67eaedf36403", + "sha256:d95fc1bf33a9a81469aa760617b5971331cdd74370d1214f0b3109272c0e1e3c", + "sha256:de6a1c9f6803b90e20869e6b99c2c18cef5cc691363954c93cb9adeb26d9f3ae", + "sha256:e1d8cb0b56b3587c5c01de3bf2f600f186da7e7b5f7353d1bf26a8ddca57f965", + "sha256:e2a988a0c673c2e12084f5e6ba3392d76c75ddb8ebc6c7e9ead68248101cd446", + "sha256:e3f1e3f1a1751bb62b4a1b7f4e435afcdade6c17a4fd9b9d43607cebd242924a", + "sha256:e6a00ffcc173e765e200ceefb06399ba09c06db97f401f920513a10c803604ca", + "sha256:e827d48cf802de06d9c935088c2924e3c7e7533377d66b6f31ed175c1620e05e", + "sha256:ebf3fd9f141700b510d4b190094db0ce37ac6361a6806c153c161dc6c041ccda", + "sha256:ec00c3305788e04bf6d29d42e504560e159ccaf0be30c09203b468a6c1ccd3b2", + "sha256:ec4fd86658c6a8964d75426517dc01cbf840bbf32d055ce64a9e63a40fd7b771", + "sha256:efd2fcf7e7b9d7ab16e6b7d54205beded0a9c8566cb30f09c1abe42b4e22bdcb", + "sha256:f0f03211fd14a6a0aed2997d4b1c013d49fb7b50eeb9ffdf5e51f23cfe2c77fa", + "sha256:f628dbf3c91e12f4d6c8b3f092069567d8eb17814aebba3d7d60c149391aee3a", + "sha256:f8ef51e459eb2ad8e7a66c1d6440c808485840ad55ecc3cafefadea47d1b1ba2", + "sha256:fc37e9aef10a696a5a4474802930079ccfc14d9f9c10b4662169671ff034b7df", + "sha256:fdee8405931b0615220e5ddf8cd7edd8592c606a8e4ca2a00704883c396e4479" ], "markers": "python_version >= '3.6'", - "version": "==3.8.5" + "version": "==3.8.6" }, "aiohttp-retry": { "hashes": [ @@ -154,24 +154,25 @@ "sha256:492bbc69dca35d12daac71c4db1bfff0c876c00ef4a2ffacce226d4638eb72da", "sha256:bd2520ca0d9d7d12694a53d44ac482d181b4ec1888909b035a3dbf40d0f57d4a" ], - "markers": "python_version >= '3.6'", + "markers": "python_full_version >= '3.6.0'", "version": "==4.12.2" }, "boto3": { "hashes": [ - "sha256:2680c0e36167e672777110ccef5303d59fa4a6a4f10086f9c14158c5cb008d5c", - "sha256:2ceb644b1df7c3c8907913ab367a9900af79e271b4cfca37b542ec1fa142faf8" + "sha256:aa970b1571321846543a6e615848352fe7621f1cb96b4454e919421924af95f7", + "sha256:ff8df4bb5aeb69acc64959a74b31042bfc52d64ca77dbe845a72c8062c48d179" ], "index": "pypi", - "version": "==1.28.55" + "markers": "python_version >= '3.7'", + "version": "==1.28.78" }, "botocore": { "hashes": [ - "sha256:21ba89c4df083338ec463d9c2a8cffca42a99f9ad5f24bcac1870393b216c5a7", - "sha256:5ec27caa440257619712af0a71524cc2e56110fc502853c3e4046f87b65e42e9" + "sha256:320c70bc412157813c2cf60217a592b4b345f8e97e4bf3b1ce49b6be69ed8965", + "sha256:a9ca8deeb3f47a10a25637859fee8d81cac2db37ace819d24471279e44879547" ], "markers": "python_version >= '3.7'", - "version": "==1.31.55" + "version": "==1.31.78" }, "certifi": { "hashes": [ @@ -183,182 +184,186 @@ }, "cffi": { "hashes": [ - "sha256:00a9ed42e88df81ffae7a8ab6d9356b371399b91dbdf0c3cb1e84c03a13aceb5", - "sha256:03425bdae262c76aad70202debd780501fabeaca237cdfddc008987c0e0f59ef", - "sha256:04ed324bda3cda42b9b695d51bb7d54b680b9719cfab04227cdd1e04e5de3104", - "sha256:0e2642fe3142e4cc4af0799748233ad6da94c62a8bec3a6648bf8ee68b1c7426", - "sha256:173379135477dc8cac4bc58f45db08ab45d228b3363adb7af79436135d028405", - "sha256:198caafb44239b60e252492445da556afafc7d1e3ab7a1fb3f0584ef6d742375", - "sha256:1e74c6b51a9ed6589199c787bf5f9875612ca4a8a0785fb2d4a84429badaf22a", - "sha256:2012c72d854c2d03e45d06ae57f40d78e5770d252f195b93f581acf3ba44496e", - "sha256:21157295583fe8943475029ed5abdcf71eb3911894724e360acff1d61c1d54bc", - "sha256:2470043b93ff09bf8fb1d46d1cb756ce6132c54826661a32d4e4d132e1977adf", - "sha256:285d29981935eb726a4399badae8f0ffdff4f5050eaa6d0cfc3f64b857b77185", - "sha256:30d78fbc8ebf9c92c9b7823ee18eb92f2e6ef79b45ac84db507f52fbe3ec4497", - "sha256:320dab6e7cb2eacdf0e658569d2575c4dad258c0fcc794f46215e1e39f90f2c3", - "sha256:33ab79603146aace82c2427da5ca6e58f2b3f2fb5da893ceac0c42218a40be35", - "sha256:3548db281cd7d2561c9ad9984681c95f7b0e38881201e157833a2342c30d5e8c", - "sha256:3799aecf2e17cf585d977b780ce79ff0dc9b78d799fc694221ce814c2c19db83", - "sha256:39d39875251ca8f612b6f33e6b1195af86d1b3e60086068be9cc053aa4376e21", - "sha256:3b926aa83d1edb5aa5b427b4053dc420ec295a08e40911296b9eb1b6170f6cca", - "sha256:3bcde07039e586f91b45c88f8583ea7cf7a0770df3a1649627bf598332cb6984", - "sha256:3d08afd128ddaa624a48cf2b859afef385b720bb4b43df214f85616922e6a5ac", - "sha256:3eb6971dcff08619f8d91607cfc726518b6fa2a9eba42856be181c6d0d9515fd", - "sha256:40f4774f5a9d4f5e344f31a32b5096977b5d48560c5592e2f3d2c4374bd543ee", - "sha256:4289fc34b2f5316fbb762d75362931e351941fa95fa18789191b33fc4cf9504a", - "sha256:470c103ae716238bbe698d67ad020e1db9d9dba34fa5a899b5e21577e6d52ed2", - "sha256:4f2c9f67e9821cad2e5f480bc8d83b8742896f1242dba247911072d4fa94c192", - "sha256:50a74364d85fd319352182ef59c5c790484a336f6db772c1a9231f1c3ed0cbd7", - "sha256:54a2db7b78338edd780e7ef7f9f6c442500fb0d41a5a4ea24fff1c929d5af585", - "sha256:5635bd9cb9731e6d4a1132a498dd34f764034a8ce60cef4f5319c0541159392f", - "sha256:59c0b02d0a6c384d453fece7566d1c7e6b7bae4fc5874ef2ef46d56776d61c9e", - "sha256:5d598b938678ebf3c67377cdd45e09d431369c3b1a5b331058c338e201f12b27", - "sha256:5df2768244d19ab7f60546d0c7c63ce1581f7af8b5de3eb3004b9b6fc8a9f84b", - "sha256:5ef34d190326c3b1f822a5b7a45f6c4535e2f47ed06fec77d3d799c450b2651e", - "sha256:6975a3fac6bc83c4a65c9f9fcab9e47019a11d3d2cf7f3c0d03431bf145a941e", - "sha256:6c9a799e985904922a4d207a94eae35c78ebae90e128f0c4e521ce339396be9d", - "sha256:70df4e3b545a17496c9b3f41f5115e69a4f2e77e94e1d2a8e1070bc0c38c8a3c", - "sha256:7473e861101c9e72452f9bf8acb984947aa1661a7704553a9f6e4baa5ba64415", - "sha256:8102eaf27e1e448db915d08afa8b41d6c7ca7a04b7d73af6514df10a3e74bd82", - "sha256:87c450779d0914f2861b8526e035c5e6da0a3199d8f1add1a665e1cbc6fc6d02", - "sha256:8b7ee99e510d7b66cdb6c593f21c043c248537a32e0bedf02e01e9553a172314", - "sha256:91fc98adde3d7881af9b59ed0294046f3806221863722ba7d8d120c575314325", - "sha256:94411f22c3985acaec6f83c6df553f2dbe17b698cc7f8ae751ff2237d96b9e3c", - "sha256:98d85c6a2bef81588d9227dde12db8a7f47f639f4a17c9ae08e773aa9c697bf3", - "sha256:9ad5db27f9cabae298d151c85cf2bad1d359a1b9c686a275df03385758e2f914", - "sha256:a0b71b1b8fbf2b96e41c4d990244165e2c9be83d54962a9a1d118fd8657d2045", - "sha256:a0f100c8912c114ff53e1202d0078b425bee3649ae34d7b070e9697f93c5d52d", - "sha256:a591fe9e525846e4d154205572a029f653ada1a78b93697f3b5a8f1f2bc055b9", - "sha256:a5c84c68147988265e60416b57fc83425a78058853509c1b0629c180094904a5", - "sha256:a66d3508133af6e8548451b25058d5812812ec3798c886bf38ed24a98216fab2", - "sha256:a8c4917bd7ad33e8eb21e9a5bbba979b49d9a97acb3a803092cbc1133e20343c", - "sha256:b3bbeb01c2b273cca1e1e0c5df57f12dce9a4dd331b4fa1635b8bec26350bde3", - "sha256:cba9d6b9a7d64d4bd46167096fc9d2f835e25d7e4c121fb2ddfc6528fb0413b2", - "sha256:cc4d65aeeaa04136a12677d3dd0b1c0c94dc43abac5860ab33cceb42b801c1e8", - "sha256:ce4bcc037df4fc5e3d184794f27bdaab018943698f4ca31630bc7f84a7b69c6d", - "sha256:cec7d9412a9102bdc577382c3929b337320c4c4c4849f2c5cdd14d7368c5562d", - "sha256:d400bfb9a37b1351253cb402671cea7e89bdecc294e8016a707f6d1d8ac934f9", - "sha256:d61f4695e6c866a23a21acab0509af1cdfd2c013cf256bbf5b6b5e2695827162", - "sha256:db0fbb9c62743ce59a9ff687eb5f4afbe77e5e8403d6697f7446e5f609976f76", - "sha256:dd86c085fae2efd48ac91dd7ccffcfc0571387fe1193d33b6394db7ef31fe2a4", - "sha256:e00b098126fd45523dd056d2efba6c5a63b71ffe9f2bbe1a4fe1716e1d0c331e", - "sha256:e229a521186c75c8ad9490854fd8bbdd9a0c9aa3a524326b55be83b54d4e0ad9", - "sha256:e263d77ee3dd201c3a142934a086a4450861778baaeeb45db4591ef65550b0a6", - "sha256:ed9cb427ba5504c1dc15ede7d516b84757c3e3d7868ccc85121d9310d27eed0b", - "sha256:fa6693661a4c91757f4412306191b6dc88c1703f780c8234035eac011922bc01", - "sha256:fcd131dd944808b5bdb38e6f5b53013c5aa4f334c5cad0c72742f6eba4b73db0" - ], - "version": "==1.15.1" + "sha256:0c9ef6ff37e974b73c25eecc13952c55bceed9112be2d9d938ded8e856138bcc", + "sha256:131fd094d1065b19540c3d72594260f118b231090295d8c34e19a7bbcf2e860a", + "sha256:1b8ebc27c014c59692bb2664c7d13ce7a6e9a629be20e54e7271fa696ff2b417", + "sha256:2c56b361916f390cd758a57f2e16233eb4f64bcbeee88a4881ea90fca14dc6ab", + "sha256:2d92b25dbf6cae33f65005baf472d2c245c050b1ce709cc4588cdcdd5495b520", + "sha256:31d13b0f99e0836b7ff893d37af07366ebc90b678b6664c955b54561fc36ef36", + "sha256:32c68ef735dbe5857c810328cb2481e24722a59a2003018885514d4c09af9743", + "sha256:3686dffb02459559c74dd3d81748269ffb0eb027c39a6fc99502de37d501faa8", + "sha256:582215a0e9adbe0e379761260553ba11c58943e4bbe9c36430c4ca6ac74b15ed", + "sha256:5b50bf3f55561dac5438f8e70bfcdfd74543fd60df5fa5f62d94e5867deca684", + "sha256:5bf44d66cdf9e893637896c7faa22298baebcd18d1ddb6d2626a6e39793a1d56", + "sha256:6602bc8dc6f3a9e02b6c22c4fc1e47aa50f8f8e6d3f78a5e16ac33ef5fefa324", + "sha256:673739cb539f8cdaa07d92d02efa93c9ccf87e345b9a0b556e3ecc666718468d", + "sha256:68678abf380b42ce21a5f2abde8efee05c114c2fdb2e9eef2efdb0257fba1235", + "sha256:68e7c44931cc171c54ccb702482e9fc723192e88d25a0e133edd7aff8fcd1f6e", + "sha256:6b3d6606d369fc1da4fd8c357d026317fbb9c9b75d36dc16e90e84c26854b088", + "sha256:748dcd1e3d3d7cd5443ef03ce8685043294ad6bd7c02a38d1bd367cfd968e000", + "sha256:7651c50c8c5ef7bdb41108b7b8c5a83013bfaa8a935590c5d74627c047a583c7", + "sha256:7b78010e7b97fef4bee1e896df8a4bbb6712b7f05b7ef630f9d1da00f6444d2e", + "sha256:7e61e3e4fa664a8588aa25c883eab612a188c725755afff6289454d6362b9673", + "sha256:80876338e19c951fdfed6198e70bc88f1c9758b94578d5a7c4c91a87af3cf31c", + "sha256:8895613bcc094d4a1b2dbe179d88d7fb4a15cee43c052e8885783fac397d91fe", + "sha256:88e2b3c14bdb32e440be531ade29d3c50a1a59cd4e51b1dd8b0865c54ea5d2e2", + "sha256:8f8e709127c6c77446a8c0a8c8bf3c8ee706a06cd44b1e827c3e6a2ee6b8c098", + "sha256:9cb4a35b3642fc5c005a6755a5d17c6c8b6bcb6981baf81cea8bfbc8903e8ba8", + "sha256:9f90389693731ff1f659e55c7d1640e2ec43ff725cc61b04b2f9c6d8d017df6a", + "sha256:a09582f178759ee8128d9270cd1344154fd473bb77d94ce0aeb2a93ebf0feaf0", + "sha256:a6a14b17d7e17fa0d207ac08642c8820f84f25ce17a442fd15e27ea18d67c59b", + "sha256:a72e8961a86d19bdb45851d8f1f08b041ea37d2bd8d4fd19903bc3083d80c896", + "sha256:abd808f9c129ba2beda4cfc53bde801e5bcf9d6e0f22f095e45327c038bfe68e", + "sha256:ac0f5edd2360eea2f1daa9e26a41db02dd4b0451b48f7c318e217ee092a213e9", + "sha256:b29ebffcf550f9da55bec9e02ad430c992a87e5f512cd63388abb76f1036d8d2", + "sha256:b2ca4e77f9f47c55c194982e10f058db063937845bb2b7a86c84a6cfe0aefa8b", + "sha256:b7be2d771cdba2942e13215c4e340bfd76398e9227ad10402a8767ab1865d2e6", + "sha256:b84834d0cf97e7d27dd5b7f3aca7b6e9263c56308ab9dc8aae9784abb774d404", + "sha256:b86851a328eedc692acf81fb05444bdf1891747c25af7529e39ddafaf68a4f3f", + "sha256:bcb3ef43e58665bbda2fb198698fcae6776483e0c4a631aa5647806c25e02cc0", + "sha256:c0f31130ebc2d37cdd8e44605fb5fa7ad59049298b3f745c74fa74c62fbfcfc4", + "sha256:c6a164aa47843fb1b01e941d385aab7215563bb8816d80ff3a363a9f8448a8dc", + "sha256:d8a9d3ebe49f084ad71f9269834ceccbf398253c9fac910c4fd7053ff1386936", + "sha256:db8e577c19c0fda0beb7e0d4e09e0ba74b1e4c092e0e40bfa12fe05b6f6d75ba", + "sha256:dc9b18bf40cc75f66f40a7379f6a9513244fe33c0e8aa72e2d56b0196a7ef872", + "sha256:e09f3ff613345df5e8c3667da1d918f9149bd623cd9070c983c013792a9a62eb", + "sha256:e4108df7fe9b707191e55f33efbcb2d81928e10cea45527879a4749cbe472614", + "sha256:e6024675e67af929088fda399b2094574609396b1decb609c55fa58b028a32a1", + "sha256:e70f54f1796669ef691ca07d046cd81a29cb4deb1e5f942003f401c0c4a2695d", + "sha256:e715596e683d2ce000574bae5d07bd522c781a822866c20495e52520564f0969", + "sha256:e760191dd42581e023a68b758769e2da259b5d52e3103c6060ddc02c9edb8d7b", + "sha256:ed86a35631f7bfbb28e108dd96773b9d5a6ce4811cf6ea468bb6a359b256b1e4", + "sha256:ee07e47c12890ef248766a6e55bd38ebfb2bb8edd4142d56db91b21ea68b7627", + "sha256:fa3a0128b152627161ce47201262d3140edb5a5c3da88d73a1b790a959126956", + "sha256:fcc8eb6d5902bb1cf6dc4f187ee3ea80a1eba0a89aba40a5cb20a5087d961357" + ], + "markers": "python_version >= '3.8'", + "version": "==1.16.0" }, "charset-normalizer": { "hashes": [ - "sha256:04e57ab9fbf9607b77f7d057974694b4f6b142da9ed4a199859d9d4d5c63fe96", - "sha256:09393e1b2a9461950b1c9a45d5fd251dc7c6f228acab64da1c9c0165d9c7765c", - "sha256:0b87549028f680ca955556e3bd57013ab47474c3124dc069faa0b6545b6c9710", - "sha256:1000fba1057b92a65daec275aec30586c3de2401ccdcd41f8a5c1e2c87078706", - "sha256:1249cbbf3d3b04902ff081ffbb33ce3377fa6e4c7356f759f3cd076cc138d020", - "sha256:1920d4ff15ce893210c1f0c0e9d19bfbecb7983c76b33f046c13a8ffbd570252", - "sha256:193cbc708ea3aca45e7221ae58f0fd63f933753a9bfb498a3b474878f12caaad", - "sha256:1a100c6d595a7f316f1b6f01d20815d916e75ff98c27a01ae817439ea7726329", - "sha256:1f30b48dd7fa1474554b0b0f3fdfdd4c13b5c737a3c6284d3cdc424ec0ffff3a", - "sha256:203f0c8871d5a7987be20c72442488a0b8cfd0f43b7973771640fc593f56321f", - "sha256:246de67b99b6851627d945db38147d1b209a899311b1305dd84916f2b88526c6", - "sha256:2dee8e57f052ef5353cf608e0b4c871aee320dd1b87d351c28764fc0ca55f9f4", - "sha256:2efb1bd13885392adfda4614c33d3b68dee4921fd0ac1d3988f8cbb7d589e72a", - "sha256:2f4ac36d8e2b4cc1aa71df3dd84ff8efbe3bfb97ac41242fbcfc053c67434f46", - "sha256:3170c9399da12c9dc66366e9d14da8bf7147e1e9d9ea566067bbce7bb74bd9c2", - "sha256:3b1613dd5aee995ec6d4c69f00378bbd07614702a315a2cf6c1d21461fe17c23", - "sha256:3bb3d25a8e6c0aedd251753a79ae98a093c7e7b471faa3aa9a93a81431987ace", - "sha256:3bb7fda7260735efe66d5107fb7e6af6a7c04c7fce9b2514e04b7a74b06bf5dd", - "sha256:41b25eaa7d15909cf3ac4c96088c1f266a9a93ec44f87f1d13d4a0e86c81b982", - "sha256:45de3f87179c1823e6d9e32156fb14c1927fcc9aba21433f088fdfb555b77c10", - "sha256:46fb8c61d794b78ec7134a715a3e564aafc8f6b5e338417cb19fe9f57a5a9bf2", - "sha256:48021783bdf96e3d6de03a6e39a1171ed5bd7e8bb93fc84cc649d11490f87cea", - "sha256:4957669ef390f0e6719db3613ab3a7631e68424604a7b448f079bee145da6e09", - "sha256:5e86d77b090dbddbe78867a0275cb4df08ea195e660f1f7f13435a4649e954e5", - "sha256:6339d047dab2780cc6220f46306628e04d9750f02f983ddb37439ca47ced7149", - "sha256:681eb3d7e02e3c3655d1b16059fbfb605ac464c834a0c629048a30fad2b27489", - "sha256:6c409c0deba34f147f77efaa67b8e4bb83d2f11c8806405f76397ae5b8c0d1c9", - "sha256:7095f6fbfaa55defb6b733cfeb14efaae7a29f0b59d8cf213be4e7ca0b857b80", - "sha256:70c610f6cbe4b9fce272c407dd9d07e33e6bf7b4aa1b7ffb6f6ded8e634e3592", - "sha256:72814c01533f51d68702802d74f77ea026b5ec52793c791e2da806a3844a46c3", - "sha256:7a4826ad2bd6b07ca615c74ab91f32f6c96d08f6fcc3902ceeedaec8cdc3bcd6", - "sha256:7c70087bfee18a42b4040bb9ec1ca15a08242cf5867c58726530bdf3945672ed", - "sha256:855eafa5d5a2034b4621c74925d89c5efef61418570e5ef9b37717d9c796419c", - "sha256:8700f06d0ce6f128de3ccdbc1acaea1ee264d2caa9ca05daaf492fde7c2a7200", - "sha256:89f1b185a01fe560bc8ae5f619e924407efca2191b56ce749ec84982fc59a32a", - "sha256:8b2c760cfc7042b27ebdb4a43a4453bd829a5742503599144d54a032c5dc7e9e", - "sha256:8c2f5e83493748286002f9369f3e6607c565a6a90425a3a1fef5ae32a36d749d", - "sha256:8e098148dd37b4ce3baca71fb394c81dc5d9c7728c95df695d2dca218edf40e6", - "sha256:94aea8eff76ee6d1cdacb07dd2123a68283cb5569e0250feab1240058f53b623", - "sha256:95eb302ff792e12aba9a8b8f8474ab229a83c103d74a750ec0bd1c1eea32e669", - "sha256:9bd9b3b31adcb054116447ea22caa61a285d92e94d710aa5ec97992ff5eb7cf3", - "sha256:9e608aafdb55eb9f255034709e20d5a83b6d60c054df0802fa9c9883d0a937aa", - "sha256:a103b3a7069b62f5d4890ae1b8f0597618f628b286b03d4bc9195230b154bfa9", - "sha256:a386ebe437176aab38c041de1260cd3ea459c6ce5263594399880bbc398225b2", - "sha256:a38856a971c602f98472050165cea2cdc97709240373041b69030be15047691f", - "sha256:a401b4598e5d3f4a9a811f3daf42ee2291790c7f9d74b18d75d6e21dda98a1a1", - "sha256:a7647ebdfb9682b7bb97e2a5e7cb6ae735b1c25008a70b906aecca294ee96cf4", - "sha256:aaf63899c94de41fe3cf934601b0f7ccb6b428c6e4eeb80da72c58eab077b19a", - "sha256:b0dac0ff919ba34d4df1b6131f59ce95b08b9065233446be7e459f95554c0dc8", - "sha256:baacc6aee0b2ef6f3d308e197b5d7a81c0e70b06beae1f1fcacffdbd124fe0e3", - "sha256:bf420121d4c8dce6b889f0e8e4ec0ca34b7f40186203f06a946fa0276ba54029", - "sha256:c04a46716adde8d927adb9457bbe39cf473e1e2c2f5d0a16ceb837e5d841ad4f", - "sha256:c0b21078a4b56965e2b12f247467b234734491897e99c1d51cee628da9786959", - "sha256:c1c76a1743432b4b60ab3358c937a3fe1341c828ae6194108a94c69028247f22", - "sha256:c4983bf937209c57240cff65906b18bb35e64ae872da6a0db937d7b4af845dd7", - "sha256:c4fb39a81950ec280984b3a44f5bd12819953dc5fa3a7e6fa7a80db5ee853952", - "sha256:c57921cda3a80d0f2b8aec7e25c8aa14479ea92b5b51b6876d975d925a2ea346", - "sha256:c8063cf17b19661471ecbdb3df1c84f24ad2e389e326ccaf89e3fb2484d8dd7e", - "sha256:ccd16eb18a849fd8dcb23e23380e2f0a354e8daa0c984b8a732d9cfaba3a776d", - "sha256:cd6dbe0238f7743d0efe563ab46294f54f9bc8f4b9bcf57c3c666cc5bc9d1299", - "sha256:d62e51710986674142526ab9f78663ca2b0726066ae26b78b22e0f5e571238dd", - "sha256:db901e2ac34c931d73054d9797383d0f8009991e723dab15109740a63e7f902a", - "sha256:e03b8895a6990c9ab2cdcd0f2fe44088ca1c65ae592b8f795c3294af00a461c3", - "sha256:e1c8a2f4c69e08e89632defbfabec2feb8a8d99edc9f89ce33c4b9e36ab63037", - "sha256:e4b749b9cc6ee664a3300bb3a273c1ca8068c46be705b6c31cf5d276f8628a94", - "sha256:e6a5bf2cba5ae1bb80b154ed68a3cfa2fa00fde979a7f50d6598d3e17d9ac20c", - "sha256:e857a2232ba53ae940d3456f7533ce6ca98b81917d47adc3c7fd55dad8fab858", - "sha256:ee4006268ed33370957f55bf2e6f4d263eaf4dc3cfc473d1d90baff6ed36ce4a", - "sha256:eef9df1eefada2c09a5e7a40991b9fc6ac6ef20b1372abd48d2794a316dc0449", - "sha256:f058f6963fd82eb143c692cecdc89e075fa0828db2e5b291070485390b2f1c9c", - "sha256:f25c229a6ba38a35ae6e25ca1264621cc25d4d38dca2942a7fce0b67a4efe918", - "sha256:f2a1d0fd4242bd8643ce6f98927cf9c04540af6efa92323e9d3124f57727bfc1", - "sha256:f7560358a6811e52e9c4d142d497f1a6e10103d3a6881f18d04dbce3729c0e2c", - "sha256:f779d3ad205f108d14e99bb3859aa7dd8e9c68874617c72354d7ecaec2a054ac", - "sha256:f87f746ee241d30d6ed93969de31e5ffd09a2961a051e60ae6bddde9ec3583aa" - ], - "markers": "python_version >= '3.7'", - "version": "==3.2.0" + "sha256:06435b539f889b1f6f4ac1758871aae42dc3a8c0e24ac9e60c2384973ad73027", + "sha256:06a81e93cd441c56a9b65d8e1d043daeb97a3d0856d177d5c90ba85acb3db087", + "sha256:0a55554a2fa0d408816b3b5cedf0045f4b8e1a6065aec45849de2d6f3f8e9786", + "sha256:0b2b64d2bb6d3fb9112bafa732def486049e63de9618b5843bcdd081d8144cd8", + "sha256:10955842570876604d404661fbccbc9c7e684caf432c09c715ec38fbae45ae09", + "sha256:122c7fa62b130ed55f8f285bfd56d5f4b4a5b503609d181f9ad85e55c89f4185", + "sha256:1ceae2f17a9c33cb48e3263960dc5fc8005351ee19db217e9b1bb15d28c02574", + "sha256:1d3193f4a680c64b4b6a9115943538edb896edc190f0b222e73761716519268e", + "sha256:1f79682fbe303db92bc2b1136016a38a42e835d932bab5b3b1bfcfbf0640e519", + "sha256:2127566c664442652f024c837091890cb1942c30937add288223dc895793f898", + "sha256:22afcb9f253dac0696b5a4be4a1c0f8762f8239e21b99680099abd9b2b1b2269", + "sha256:25baf083bf6f6b341f4121c2f3c548875ee6f5339300e08be3f2b2ba1721cdd3", + "sha256:2e81c7b9c8979ce92ed306c249d46894776a909505d8f5a4ba55b14206e3222f", + "sha256:3287761bc4ee9e33561a7e058c72ac0938c4f57fe49a09eae428fd88aafe7bb6", + "sha256:34d1c8da1e78d2e001f363791c98a272bb734000fcef47a491c1e3b0505657a8", + "sha256:37e55c8e51c236f95b033f6fb391d7d7970ba5fe7ff453dad675e88cf303377a", + "sha256:3d47fa203a7bd9c5b6cee4736ee84ca03b8ef23193c0d1ca99b5089f72645c73", + "sha256:3e4d1f6587322d2788836a99c69062fbb091331ec940e02d12d179c1d53e25fc", + "sha256:42cb296636fcc8b0644486d15c12376cb9fa75443e00fb25de0b8602e64c1714", + "sha256:45485e01ff4d3630ec0d9617310448a8702f70e9c01906b0d0118bdf9d124cf2", + "sha256:4a78b2b446bd7c934f5dcedc588903fb2f5eec172f3d29e52a9096a43722adfc", + "sha256:4ab2fe47fae9e0f9dee8c04187ce5d09f48eabe611be8259444906793ab7cbce", + "sha256:4d0d1650369165a14e14e1e47b372cfcb31d6ab44e6e33cb2d4e57265290044d", + "sha256:549a3a73da901d5bc3ce8d24e0600d1fa85524c10287f6004fbab87672bf3e1e", + "sha256:55086ee1064215781fff39a1af09518bc9255b50d6333f2e4c74ca09fac6a8f6", + "sha256:572c3763a264ba47b3cf708a44ce965d98555f618ca42c926a9c1616d8f34269", + "sha256:573f6eac48f4769d667c4442081b1794f52919e7edada77495aaed9236d13a96", + "sha256:5b4c145409bef602a690e7cfad0a15a55c13320ff7a3ad7ca59c13bb8ba4d45d", + "sha256:6463effa3186ea09411d50efc7d85360b38d5f09b870c48e4600f63af490e56a", + "sha256:65f6f63034100ead094b8744b3b97965785388f308a64cf8d7c34f2f2e5be0c4", + "sha256:663946639d296df6a2bb2aa51b60a2454ca1cb29835324c640dafb5ff2131a77", + "sha256:6897af51655e3691ff853668779c7bad41579facacf5fd7253b0133308cf000d", + "sha256:68d1f8a9e9e37c1223b656399be5d6b448dea850bed7d0f87a8311f1ff3dabb0", + "sha256:6ac7ffc7ad6d040517be39eb591cac5ff87416c2537df6ba3cba3bae290c0fed", + "sha256:6b3251890fff30ee142c44144871185dbe13b11bab478a88887a639655be1068", + "sha256:6c4caeef8fa63d06bd437cd4bdcf3ffefe6738fb1b25951440d80dc7df8c03ac", + "sha256:6ef1d82a3af9d3eecdba2321dc1b3c238245d890843e040e41e470ffa64c3e25", + "sha256:753f10e867343b4511128c6ed8c82f7bec3bd026875576dfd88483c5c73b2fd8", + "sha256:7cd13a2e3ddeed6913a65e66e94b51d80a041145a026c27e6bb76c31a853c6ab", + "sha256:7ed9e526742851e8d5cc9e6cf41427dfc6068d4f5a3bb03659444b4cabf6bc26", + "sha256:7f04c839ed0b6b98b1a7501a002144b76c18fb1c1850c8b98d458ac269e26ed2", + "sha256:802fe99cca7457642125a8a88a084cef28ff0cf9407060f7b93dca5aa25480db", + "sha256:80402cd6ee291dcb72644d6eac93785fe2c8b9cb30893c1af5b8fdd753b9d40f", + "sha256:8465322196c8b4d7ab6d1e049e4c5cb460d0394da4a27d23cc242fbf0034b6b5", + "sha256:86216b5cee4b06df986d214f664305142d9c76df9b6512be2738aa72a2048f99", + "sha256:87d1351268731db79e0f8e745d92493ee2841c974128ef629dc518b937d9194c", + "sha256:8bdb58ff7ba23002a4c5808d608e4e6c687175724f54a5dade5fa8c67b604e4d", + "sha256:8c622a5fe39a48f78944a87d4fb8a53ee07344641b0562c540d840748571b811", + "sha256:8d756e44e94489e49571086ef83b2bb8ce311e730092d2c34ca8f7d925cb20aa", + "sha256:8f4a014bc36d3c57402e2977dada34f9c12300af536839dc38c0beab8878f38a", + "sha256:9063e24fdb1e498ab71cb7419e24622516c4a04476b17a2dab57e8baa30d6e03", + "sha256:90d558489962fd4918143277a773316e56c72da56ec7aa3dc3dbbe20fdfed15b", + "sha256:923c0c831b7cfcb071580d3f46c4baf50f174be571576556269530f4bbd79d04", + "sha256:95f2a5796329323b8f0512e09dbb7a1860c46a39da62ecb2324f116fa8fdc85c", + "sha256:96b02a3dc4381e5494fad39be677abcb5e6634bf7b4fa83a6dd3112607547001", + "sha256:9f96df6923e21816da7e0ad3fd47dd8f94b2a5ce594e00677c0013018b813458", + "sha256:a10af20b82360ab00827f916a6058451b723b4e65030c5a18577c8b2de5b3389", + "sha256:a50aebfa173e157099939b17f18600f72f84eed3049e743b68ad15bd69b6bf99", + "sha256:a981a536974bbc7a512cf44ed14938cf01030a99e9b3a06dd59578882f06f985", + "sha256:a9a8e9031d613fd2009c182b69c7b2c1ef8239a0efb1df3f7c8da66d5dd3d537", + "sha256:ae5f4161f18c61806f411a13b0310bea87f987c7d2ecdbdaad0e94eb2e404238", + "sha256:aed38f6e4fb3f5d6bf81bfa990a07806be9d83cf7bacef998ab1a9bd660a581f", + "sha256:b01b88d45a6fcb69667cd6d2f7a9aeb4bf53760d7fc536bf679ec94fe9f3ff3d", + "sha256:b261ccdec7821281dade748d088bb6e9b69e6d15b30652b74cbbac25e280b796", + "sha256:b2b0a0c0517616b6869869f8c581d4eb2dd83a4d79e0ebcb7d373ef9956aeb0a", + "sha256:b4a23f61ce87adf89be746c8a8974fe1c823c891d8f86eb218bb957c924bb143", + "sha256:bd8f7df7d12c2db9fab40bdd87a7c09b1530128315d047a086fa3ae3435cb3a8", + "sha256:beb58fe5cdb101e3a055192ac291b7a21e3b7ef4f67fa1d74e331a7f2124341c", + "sha256:c002b4ffc0be611f0d9da932eb0f704fe2602a9a949d1f738e4c34c75b0863d5", + "sha256:c083af607d2515612056a31f0a8d9e0fcb5876b7bfc0abad3ecd275bc4ebc2d5", + "sha256:c180f51afb394e165eafe4ac2936a14bee3eb10debc9d9e4db8958fe36afe711", + "sha256:c235ebd9baae02f1b77bcea61bce332cb4331dc3617d254df3323aa01ab47bd4", + "sha256:cd70574b12bb8a4d2aaa0094515df2463cb429d8536cfb6c7ce983246983e5a6", + "sha256:d0eccceffcb53201b5bfebb52600a5fb483a20b61da9dbc885f8b103cbe7598c", + "sha256:d965bba47ddeec8cd560687584e88cf699fd28f192ceb452d1d7ee807c5597b7", + "sha256:db364eca23f876da6f9e16c9da0df51aa4f104a972735574842618b8c6d999d4", + "sha256:ddbb2551d7e0102e7252db79ba445cdab71b26640817ab1e3e3648dad515003b", + "sha256:deb6be0ac38ece9ba87dea880e438f25ca3eddfac8b002a2ec3d9183a454e8ae", + "sha256:e06ed3eb3218bc64786f7db41917d4e686cc4856944f53d5bdf83a6884432e12", + "sha256:e27ad930a842b4c5eb8ac0016b0a54f5aebbe679340c26101df33424142c143c", + "sha256:e537484df0d8f426ce2afb2d0f8e1c3d0b114b83f8850e5f2fbea0e797bd82ae", + "sha256:eb00ed941194665c332bf8e078baf037d6c35d7c4f3102ea2d4f16ca94a26dc8", + "sha256:eb6904c354526e758fda7167b33005998fb68c46fbc10e013ca97f21ca5c8887", + "sha256:eb8821e09e916165e160797a6c17edda0679379a4be5c716c260e836e122f54b", + "sha256:efcb3f6676480691518c177e3b465bcddf57cea040302f9f4e6e191af91174d4", + "sha256:f27273b60488abe721a075bcca6d7f3964f9f6f067c8c4c605743023d7d3944f", + "sha256:f30c3cb33b24454a82faecaf01b19c18562b1e89558fb6c56de4d9118a032fd5", + "sha256:fb69256e180cb6c8a894fee62b3afebae785babc1ee98b81cdf68bbca1987f33", + "sha256:fd1abc0d89e30cc4e02e4064dc67fcc51bd941eb395c502aac3ec19fab46b519", + "sha256:ff8fa367d09b717b2a17a052544193ad76cd49979c805768879cb63d9ca50561" + ], + "markers": "python_full_version >= '3.7.0'", + "version": "==3.3.2" }, "cryptography": { "hashes": [ - "sha256:004b6ccc95943f6a9ad3142cfabcc769d7ee38a3f60fb0dddbfb431f818c3a67", - "sha256:047c4603aeb4bbd8db2756e38f5b8bd7e94318c047cfe4efeb5d715e08b49311", - "sha256:0d9409894f495d465fe6fda92cb70e8323e9648af912d5b9141d616df40a87b8", - "sha256:23a25c09dfd0d9f28da2352503b23e086f8e78096b9fd585d1d14eca01613e13", - "sha256:2ed09183922d66c4ec5fdaa59b4d14e105c084dd0febd27452de8f6f74704143", - "sha256:35c00f637cd0b9d5b6c6bd11b6c3359194a8eba9c46d4e875a3660e3b400005f", - "sha256:37480760ae08065437e6573d14be973112c9e6dcaf5f11d00147ee74f37a3829", - "sha256:3b224890962a2d7b57cf5eeb16ccaafba6083f7b811829f00476309bce2fe0fd", - "sha256:5a0f09cefded00e648a127048119f77bc2b2ec61e736660b5789e638f43cc397", - "sha256:5b72205a360f3b6176485a333256b9bcd48700fc755fef51c8e7e67c4b63e3ac", - "sha256:7e53db173370dea832190870e975a1e09c86a879b613948f09eb49324218c14d", - "sha256:7febc3094125fc126a7f6fb1f420d0da639f3f32cb15c8ff0dc3997c4549f51a", - "sha256:80907d3faa55dc5434a16579952ac6da800935cd98d14dbd62f6f042c7f5e839", - "sha256:86defa8d248c3fa029da68ce61fe735432b047e32179883bdb1e79ed9bb8195e", - "sha256:8ac4f9ead4bbd0bc8ab2d318f97d85147167a488be0e08814a37eb2f439d5cf6", - "sha256:93530900d14c37a46ce3d6c9e6fd35dbe5f5601bf6b3a5c325c7bffc030344d9", - "sha256:9eeb77214afae972a00dee47382d2591abe77bdae166bda672fb1e24702a3860", - "sha256:b5f4dfe950ff0479f1f00eda09c18798d4f49b98f4e2006d644b3301682ebdca", - "sha256:c3391bd8e6de35f6f1140e50aaeb3e2b3d6a9012536ca23ab0d9c35ec18c8a91", - "sha256:c880eba5175f4307129784eca96f4e70b88e57aa3f680aeba3bab0e980b0f37d", - "sha256:cecfefa17042941f94ab54f769c8ce0fe14beff2694e9ac684176a2535bf9714", - "sha256:e40211b4923ba5a6dc9769eab704bdb3fbb58d56c5b336d30996c24fcf12aadb", - "sha256:efc8ad4e6fc4f1752ebfb58aefece8b4e3c4cae940b0994d43649bdfce8d0d4f" + "sha256:0c327cac00f082013c7c9fb6c46b7cc9fa3c288ca702c74773968173bda421bf", + "sha256:0d2a6a598847c46e3e321a7aef8af1436f11c27f1254933746304ff014664d84", + "sha256:227ec057cd32a41c6651701abc0328135e472ed450f47c2766f23267b792a88e", + "sha256:22892cc830d8b2c89ea60148227631bb96a7da0c1b722f2aac8824b1b7c0b6b8", + "sha256:392cb88b597247177172e02da6b7a63deeff1937fa6fec3bbf902ebd75d97ec7", + "sha256:3be3ca726e1572517d2bef99a818378bbcf7d7799d5372a46c79c29eb8d166c1", + "sha256:573eb7128cbca75f9157dcde974781209463ce56b5804983e11a1c462f0f4e88", + "sha256:580afc7b7216deeb87a098ef0674d6ee34ab55993140838b14c9b83312b37b86", + "sha256:5a70187954ba7292c7876734183e810b728b4f3965fbe571421cb2434d279179", + "sha256:73801ac9736741f220e20435f84ecec75ed70eda90f781a148f1bad546963d81", + "sha256:7d208c21e47940369accfc9e85f0de7693d9a5d843c2509b3846b2db170dfd20", + "sha256:8254962e6ba1f4d2090c44daf50a547cd5f0bf446dc658a8e5f8156cae0d8548", + "sha256:88417bff20162f635f24f849ab182b092697922088b477a7abd6664ddd82291d", + "sha256:a48e74dad1fb349f3dc1d449ed88e0017d792997a7ad2ec9587ed17405667e6d", + "sha256:b948e09fe5fb18517d99994184854ebd50b57248736fd4c720ad540560174ec5", + "sha256:c707f7afd813478e2019ae32a7c49cd932dd60ab2d2a93e796f68236b7e1fbf1", + "sha256:d38e6031e113b7421db1de0c1b1f7739564a88f1684c6b89234fbf6c11b75147", + "sha256:d3977f0e276f6f5bf245c403156673db103283266601405376f075c849a0b936", + "sha256:da6a0ff8f1016ccc7477e6339e1d50ce5f59b88905585f77193ebd5068f1e797", + "sha256:e270c04f4d9b5671ebcc792b3ba5d4488bf7c42c3c241a3748e2599776f29696", + "sha256:e886098619d3815e0ad5790c973afeee2c0e6e04b4da90b88e6bd06e2a0b1b72", + "sha256:ec3b055ff8f1dce8e6ef28f626e0972981475173d7973d63f271b29c8a2897da", + "sha256:fba1e91467c65fe64a82c689dc6cf58151158993b13eb7a7f3f4b7f395636723" ], "markers": "python_version >= '3.7'", - "version": "==41.0.4" + "version": "==41.0.5" }, "deprecated": { "hashes": [ @@ -378,19 +383,21 @@ }, "django": { "hashes": [ - "sha256:5e5c1c9548ffb7796b4a8a4782e9a2e5a3df3615259fc1bfd3ebc73b646146c1", - "sha256:b6b2b5cae821077f137dc4dade696a1c2aa292f892eca28fa8d7bfdf2608ddd4" + "sha256:8e0f1c2c2786b5c0e39fe1afce24c926040fad47c8ea8ad30aaf1188df29fc41", + "sha256:e1d37c51ad26186de355cbcec16613ebdabfa9689bbade9c538835205a8abbe9" ], "index": "pypi", - "version": "==4.2.5" + "markers": "python_version >= '3.8'", + "version": "==4.2.7" }, "django-cors-headers": { "hashes": [ - "sha256:9ada212b0e2efd4a5e339360ffc869cb21ac5605e810afe69f7308e577ea5bde", - "sha256:f9749c6410fe738278bc2b6ef17f05195bc7b251693c035752d8257026af024f" + "sha256:25aabc94d4837678c1edf442c7f68a5f5fd151f6767b0e0b01c61a2179d02711", + "sha256:bd36c7aea0d070e462f3383f0dc9ef717e5fdc2b10a99c98c285f16da84ffba2" ], "index": "pypi", - "version": "==4.2.0" + "markers": "python_version >= '3.8'", + "version": "==4.3.0" }, "django-email-tools": { "hashes": [ @@ -398,6 +405,7 @@ "sha256:2d14ab510dcb3f9b46865f6f55dcc171ff49b2e0406b5cf7a66efd58ee670aac" ], "index": "pypi", + "markers": "python_version >= '3.6'", "version": "==0.1.1" }, "django-oauth-toolkit": { @@ -413,11 +421,11 @@ "phonenumbers" ], "hashes": [ - "sha256:4eaab35fe9a163046dc3a47188771385c56a788e0e11b7bbcc662e1e6b7b9104", - "sha256:63721dbdc7424cd594a08d80f550e790cf6e7c903cbc0fb4dd9d86baac8b8c51" + "sha256:16778f2717ea2aecc6178beb0d6bc431c78c6a8b0474e1fa8face040efeb6e9e", + "sha256:20c7c5c449e33eed5fd45ef8d3dc668faabaeff3277eddd1892b262d686ba381" ], - "index": "pypi", - "version": "==7.1.0" + "markers": "python_version >= '3.8'", + "version": "==7.2.0" }, "django-runtime-options": { "hashes": [ @@ -425,15 +433,17 @@ "sha256:edb34dc27d5558cda19caf8650b93b2fec4753f9955a545bf75f2785bbf40e55" ], "index": "pypi", + "markers": "python_version >= '3.6'", "version": "==0.1.3" }, "django-storages": { "hashes": [ - "sha256:11280a883b13812df548f3cfe9c10280afc0d4727c8babdee369a75e71158f16", - "sha256:6c97e5faad829c923a1262206281742c484d76d43b332a196ddcc242b909c551" + "sha256:1db759346b52ada6c2efd9f23d8241ecf518813eb31db9e2589207174f58f6ad", + "sha256:51b36af28cc5813b98d5f3dfe7459af638d84428c8df4a03990c7d74d1bea4e5" ], "index": "pypi", - "version": "==1.14" + "markers": "python_version >= '3.7'", + "version": "==1.14.2" }, "djangorestframework": { "hashes": [ @@ -441,15 +451,17 @@ "sha256:eb63f58c9f218e1a7d064d17a70751f528ed4e1d35547fdade9aaf4cd103fd08" ], "index": "pypi", + "markers": "python_version >= '3.6'", "version": "==3.14.0" }, "djangorestframework-api-key": { "hashes": [ - "sha256:c2fa61280069acd8dc0e9dd1840e0e1934a2a85631069326f4d1e3a91ca9aa9a", - "sha256:eed94f383e96ca8f9f9e4182406fe28b5585629d0039f65cbb7e6e254778f674" + "sha256:b9443cd864e43caebdd330224f9309957b38128267fbc9dc1ba2f3fa1c8414d0", + "sha256:f18cdfa45aaea10fd4daaebffa60481ce4002c9b9ef6c551ef1fc21dadf28845" ], "index": "pypi", - "version": "==2.3.0" + "markers": "python_version >= '3.8'", + "version": "==3.0.0" }, "frozenlist": { "hashes": [ @@ -539,6 +551,7 @@ "sha256:2c1dc51cf8e38ddf324795dfe9426dee9dd46caf47f535ccbc18781fba810b8d" ], "index": "pypi", + "markers": "python_version >= '3.6'", "version": "==1.5.0" }, "lxml": { @@ -637,6 +650,7 @@ "sha256:fe4bda6bd4340caa6e5cf95e73f8fea5c4bfc55763dd42f1b50a94c1b4a2fbd4" ], "index": "pypi", + "markers": "python_version >= '2.7' and python_version not in '3.0, 3.1, 3.2, 3.3, 3.4'", "version": "==4.9.3" }, "multidict": { @@ -727,96 +741,107 @@ "markers": "python_version >= '3.6'", "version": "==3.2.2" }, + "packaging": { + "hashes": [ + "sha256:048fb0e9405036518eaaf48a55953c750c11e1a1b68e0dd1a9d62ed0c092cfc5", + "sha256:8c491190033a9af7e1d931d0b5dacc2ef47509b34dd0de67ed209b5203fc88c7" + ], + "markers": "python_version >= '3.7'", + "version": "==23.2" + }, "phonenumbers": { "hashes": [ - "sha256:053adc72e6cbd8921c70eaef199c18b8ae8d58d3debc5e084a6801d095a84326", - "sha256:c7cff118aeab60986aaddf81df5c39300dd62caed7a2d20747b60117b9659b38" + "sha256:7abc66f38d92c3b9e827d597b5d590283ca3b05288d9fadea8bc0d6c8ad73c06", + "sha256:7dd66c57da00c0f373de83074e78d66a0801381cface4d010cfe07be2fa77fe5" ], - "version": "==8.13.21" + "version": "==8.13.24" }, "pillow": { "hashes": [ - "sha256:0462b1496505a3462d0f35dc1c4d7b54069747d65d00ef48e736acda2c8cbdff", - "sha256:186f7e04248103482ea6354af6d5bcedb62941ee08f7f788a1c7707bc720c66f", - "sha256:19e9adb3f22d4c416e7cd79b01375b17159d6990003633ff1d8377e21b7f1b21", - "sha256:28444cb6ad49726127d6b340217f0627abc8732f1194fd5352dec5e6a0105635", - "sha256:2872f2d7846cf39b3dbff64bc1104cc48c76145854256451d33c5faa55c04d1a", - "sha256:2cc6b86ece42a11f16f55fe8903595eff2b25e0358dec635d0a701ac9586588f", - "sha256:2d7e91b4379f7a76b31c2dda84ab9e20c6220488e50f7822e59dac36b0cd92b1", - "sha256:2fa6dd2661838c66f1a5473f3b49ab610c98a128fc08afbe81b91a1f0bf8c51d", - "sha256:32bec7423cdf25c9038fef614a853c9d25c07590e1a870ed471f47fb80b244db", - "sha256:3855447d98cced8670aaa63683808df905e956f00348732448b5a6df67ee5849", - "sha256:3a04359f308ebee571a3127fdb1bd01f88ba6f6fb6d087f8dd2e0d9bff43f2a7", - "sha256:3a0d3e54ab1df9df51b914b2233cf779a5a10dfd1ce339d0421748232cea9876", - "sha256:44e7e4587392953e5e251190a964675f61e4dae88d1e6edbe9f36d6243547ff3", - "sha256:459307cacdd4138edee3875bbe22a2492519e060660eaf378ba3b405d1c66317", - "sha256:4ce90f8a24e1c15465048959f1e94309dfef93af272633e8f37361b824532e91", - "sha256:50bd5f1ebafe9362ad622072a1d2f5850ecfa44303531ff14353a4059113b12d", - "sha256:522ff4ac3aaf839242c6f4e5b406634bfea002469656ae8358644fc6c4856a3b", - "sha256:552912dbca585b74d75279a7570dd29fa43b6d93594abb494ebb31ac19ace6bd", - "sha256:5d6c9049c6274c1bb565021367431ad04481ebb54872edecfcd6088d27edd6ed", - "sha256:697a06bdcedd473b35e50a7e7506b1d8ceb832dc238a336bd6f4f5aa91a4b500", - "sha256:71671503e3015da1b50bd18951e2f9daf5b6ffe36d16f1eb2c45711a301521a7", - "sha256:723bd25051454cea9990203405fa6b74e043ea76d4968166dfd2569b0210886a", - "sha256:764d2c0daf9c4d40ad12fbc0abd5da3af7f8aa11daf87e4fa1b834000f4b6b0a", - "sha256:787bb0169d2385a798888e1122c980c6eff26bf941a8ea79747d35d8f9210ca0", - "sha256:7f771e7219ff04b79e231d099c0a28ed83aa82af91fd5fa9fdb28f5b8d5addaf", - "sha256:847e8d1017c741c735d3cd1883fa7b03ded4f825a6e5fcb9378fd813edee995f", - "sha256:84efb46e8d881bb06b35d1d541aa87f574b58e87f781cbba8d200daa835b42e1", - "sha256:898f1d306298ff40dc1b9ca24824f0488f6f039bc0e25cfb549d3195ffa17088", - "sha256:8b451d6ead6e3500b6ce5c7916a43d8d8d25ad74b9102a629baccc0808c54971", - "sha256:8f06be50669087250f319b706decf69ca71fdecd829091a37cc89398ca4dc17a", - "sha256:92a23b0431941a33242b1f0ce6c88a952e09feeea9af4e8be48236a68ffe2205", - "sha256:93139acd8109edcdeffd85e3af8ae7d88b258b3a1e13a038f542b79b6d255c54", - "sha256:98533fd7fa764e5f85eebe56c8e4094db912ccbe6fbf3a58778d543cadd0db08", - "sha256:9f665d1e6474af9f9da5e86c2a3a2d2d6204e04d5af9c06b9d42afa6ebde3f21", - "sha256:b059ac2c4c7a97daafa7dc850b43b2d3667def858a4f112d1aa082e5c3d6cf7d", - "sha256:b1be1c872b9b5fcc229adeadbeb51422a9633abd847c0ff87dc4ef9bb184ae08", - "sha256:b7cf63d2c6928b51d35dfdbda6f2c1fddbe51a6bc4a9d4ee6ea0e11670dd981e", - "sha256:bc2e3069569ea9dbe88d6b8ea38f439a6aad8f6e7a6283a38edf61ddefb3a9bf", - "sha256:bcf1207e2f2385a576832af02702de104be71301c2696d0012b1b93fe34aaa5b", - "sha256:ca26ba5767888c84bf5a0c1a32f069e8204ce8c21d00a49c90dabeba00ce0145", - "sha256:cbe68deb8580462ca0d9eb56a81912f59eb4542e1ef8f987405e35a0179f4ea2", - "sha256:d6caf3cd38449ec3cd8a68b375e0c6fe4b6fd04edb6c9766b55ef84a6e8ddf2d", - "sha256:d72967b06be9300fed5cfbc8b5bafceec48bf7cdc7dab66b1d2549035287191d", - "sha256:d889b53ae2f030f756e61a7bff13684dcd77e9af8b10c6048fb2c559d6ed6eaf", - "sha256:de596695a75496deb3b499c8c4f8e60376e0516e1a774e7bc046f0f48cd620ad", - "sha256:e6a90167bcca1216606223a05e2cf991bb25b14695c518bc65639463d7db722d", - "sha256:ed2d9c0704f2dc4fa980b99d565c0c9a543fe5101c25b3d60488b8ba80f0cce1", - "sha256:ee7810cf7c83fa227ba9125de6084e5e8b08c59038a7b2c9045ef4dde61663b4", - "sha256:f0b4b06da13275bc02adfeb82643c4a6385bd08d26f03068c2796f60d125f6f2", - "sha256:f11c9102c56ffb9ca87134bd025a43d2aba3f1155f508eff88f694b33a9c6d19", - "sha256:f5bb289bb835f9fe1a1e9300d011eef4d69661bb9b34d5e196e5e82c4cb09b37", - "sha256:f6d3d4c905e26354e8f9d82548475c46d8e0889538cb0657aa9c6f0872a37aa4", - "sha256:fcb59711009b0168d6ee0bd8fb5eb259c4ab1717b2f538bbf36bacf207ef7a68", - "sha256:fd2a5403a75b54661182b75ec6132437a181209b901446ee5724b589af8edef1" + "sha256:00f438bb841382b15d7deb9a05cc946ee0f2c352653c7aa659e75e592f6fa17d", + "sha256:0248f86b3ea061e67817c47ecbe82c23f9dd5d5226200eb9090b3873d3ca32de", + "sha256:04f6f6149f266a100374ca3cc368b67fb27c4af9f1cc8cb6306d849dcdf12616", + "sha256:062a1610e3bc258bff2328ec43f34244fcec972ee0717200cb1425214fe5b839", + "sha256:0a026c188be3b443916179f5d04548092e253beb0c3e2ee0a4e2cdad72f66099", + "sha256:0f7c276c05a9767e877a0b4c5050c8bee6a6d960d7f0c11ebda6b99746068c2a", + "sha256:1a8413794b4ad9719346cd9306118450b7b00d9a15846451549314a58ac42219", + "sha256:1ab05f3db77e98f93964697c8efc49c7954b08dd61cff526b7f2531a22410106", + "sha256:1c3ac5423c8c1da5928aa12c6e258921956757d976405e9467c5f39d1d577a4b", + "sha256:1c41d960babf951e01a49c9746f92c5a7e0d939d1652d7ba30f6b3090f27e412", + "sha256:1fafabe50a6977ac70dfe829b2d5735fd54e190ab55259ec8aea4aaea412fa0b", + "sha256:1fb29c07478e6c06a46b867e43b0bcdb241b44cc52be9bc25ce5944eed4648e7", + "sha256:24fadc71218ad2b8ffe437b54876c9382b4a29e030a05a9879f615091f42ffc2", + "sha256:2cdc65a46e74514ce742c2013cd4a2d12e8553e3a2563c64879f7c7e4d28bce7", + "sha256:2ef6721c97894a7aa77723740a09547197533146fba8355e86d6d9a4a1056b14", + "sha256:3b834f4b16173e5b92ab6566f0473bfb09f939ba14b23b8da1f54fa63e4b623f", + "sha256:3d929a19f5469b3f4df33a3df2983db070ebb2088a1e145e18facbc28cae5b27", + "sha256:41f67248d92a5e0a2076d3517d8d4b1e41a97e2df10eb8f93106c89107f38b57", + "sha256:47e5bf85b80abc03be7455c95b6d6e4896a62f6541c1f2ce77a7d2bb832af262", + "sha256:4d0152565c6aa6ebbfb1e5d8624140a440f2b99bf7afaafbdbf6430426497f28", + "sha256:50d08cd0a2ecd2a8657bd3d82c71efd5a58edb04d9308185d66c3a5a5bed9610", + "sha256:61f1a9d247317fa08a308daaa8ee7b3f760ab1809ca2da14ecc88ae4257d6172", + "sha256:6932a7652464746fcb484f7fc3618e6503d2066d853f68a4bd97193a3996e273", + "sha256:7a7e3daa202beb61821c06d2517428e8e7c1aab08943e92ec9e5755c2fc9ba5e", + "sha256:7dbaa3c7de82ef37e7708521be41db5565004258ca76945ad74a8e998c30af8d", + "sha256:7df5608bc38bd37ef585ae9c38c9cd46d7c81498f086915b0f97255ea60c2818", + "sha256:806abdd8249ba3953c33742506fe414880bad78ac25cc9a9b1c6ae97bedd573f", + "sha256:883f216eac8712b83a63f41b76ddfb7b2afab1b74abbb413c5df6680f071a6b9", + "sha256:912e3812a1dbbc834da2b32299b124b5ddcb664ed354916fd1ed6f193f0e2d01", + "sha256:937bdc5a7f5343d1c97dc98149a0be7eb9704e937fe3dc7140e229ae4fc572a7", + "sha256:9882a7451c680c12f232a422730f986a1fcd808da0fd428f08b671237237d651", + "sha256:9a92109192b360634a4489c0c756364c0c3a2992906752165ecb50544c251312", + "sha256:9d7bc666bd8c5a4225e7ac71f2f9d12466ec555e89092728ea0f5c0c2422ea80", + "sha256:a5f63b5a68daedc54c7c3464508d8c12075e56dcfbd42f8c1bf40169061ae666", + "sha256:a646e48de237d860c36e0db37ecaecaa3619e6f3e9d5319e527ccbc8151df061", + "sha256:a89b8312d51715b510a4fe9fc13686283f376cfd5abca8cd1c65e4c76e21081b", + "sha256:a92386125e9ee90381c3369f57a2a50fa9e6aa8b1cf1d9c4b200d41a7dd8e992", + "sha256:ae88931f93214777c7a3aa0a8f92a683f83ecde27f65a45f95f22d289a69e593", + "sha256:afc8eef765d948543a4775f00b7b8c079b3321d6b675dde0d02afa2ee23000b4", + "sha256:b0eb01ca85b2361b09480784a7931fc648ed8b7836f01fb9241141b968feb1db", + "sha256:b1c25762197144e211efb5f4e8ad656f36c8d214d390585d1d21281f46d556ba", + "sha256:b4005fee46ed9be0b8fb42be0c20e79411533d1fd58edabebc0dd24626882cfd", + "sha256:b920e4d028f6442bea9a75b7491c063f0b9a3972520731ed26c83e254302eb1e", + "sha256:baada14941c83079bf84c037e2d8b7506ce201e92e3d2fa0d1303507a8538212", + "sha256:bb40c011447712d2e19cc261c82655f75f32cb724788df315ed992a4d65696bb", + "sha256:c0949b55eb607898e28eaccb525ab104b2d86542a85c74baf3a6dc24002edec2", + "sha256:c9aeea7b63edb7884b031a35305629a7593272b54f429a9869a4f63a1bf04c34", + "sha256:cfe96560c6ce2f4c07d6647af2d0f3c54cc33289894ebd88cfbb3bcd5391e256", + "sha256:d27b5997bdd2eb9fb199982bb7eb6164db0426904020dc38c10203187ae2ff2f", + "sha256:d921bc90b1defa55c9917ca6b6b71430e4286fc9e44c55ead78ca1a9f9eba5f2", + "sha256:e6bf8de6c36ed96c86ea3b6e1d5273c53f46ef518a062464cd7ef5dd2cf92e38", + "sha256:eaed6977fa73408b7b8a24e8b14e59e1668cfc0f4c40193ea7ced8e210adf996", + "sha256:fa1d323703cfdac2036af05191b969b910d8f115cf53093125e4058f62012c9a", + "sha256:fe1e26e1ffc38be097f0ba1d0d07fcade2bcfd1d023cda5b29935ae8052bd793" ], "index": "pypi", - "version": "==10.0.1" + "markers": "python_version >= '3.8'", + "version": "==10.1.0" }, "psycopg2": { "hashes": [ - "sha256:1a6a2d609bce44f78af4556bea0c62a5e7f05c23e5ea9c599e07678995609084", - "sha256:44d93a0109dfdf22fe399b419bcd7fa589d86895d3931b01fb321d74dadc68f1", - "sha256:8275abf628c6dc7ec834ea63f6f3846bf33518907a2b9b693d41fd063767a866", - "sha256:91e81a8333a0037babfc9fe6d11e997a9d4dac0f38c43074886b0d9dead94fe9", - "sha256:b22ed9c66da2589a664e0f1ca2465c29b75aaab36fa209d4fb916025fb9119e5", - "sha256:b6bd7d9d3a7a63faae6edf365f0ed0e9b0a1aaf1da3ca146e6b043fb3eb5d723", - "sha256:c7949770cafbd2f12cecc97dea410c514368908a103acf519f2a346134caa4d5", - "sha256:d1210fcf99aae6f728812d1d2240afc1dc44b9e6cba526a06fb8134f969957c2", - "sha256:d5c5297e2fbc8068d4255f1e606bfc9291f06f91ec31b2a0d4c536210ac5c0a2", - "sha256:e9b04cbef584310a1ac0f0d55bb623ca3244c87c51187645432e342de9ae81a8", - "sha256:f00cc35bd7119f1fed17b85bd1007855194dde2cbd8de01ab8ebb17487440ad8" + "sha256:121081ea2e76729acfb0673ff33755e8703d45e926e416cb59bae3a86c6a4981", + "sha256:38a8dcc6856f569068b47de286b472b7c473ac7977243593a288ebce0dc89516", + "sha256:426f9f29bde126913a20a96ff8ce7d73fd8a216cfb323b1f04da402d452853c3", + "sha256:5e0d98cade4f0e0304d7d6f25bbfbc5bd186e07b38eac65379309c4ca3193efa", + "sha256:7e2dacf8b009a1c1e843b5213a87f7c544b2b042476ed7755be813eaf4e8347a", + "sha256:a7653d00b732afb6fc597e29c50ad28087dcb4fbfb28e86092277a559ae4e693", + "sha256:ade01303ccf7ae12c356a5e10911c9e1c51136003a9a1d92f7aa9d010fb98372", + "sha256:bac58c024c9922c23550af2a581998624d6e02350f4ae9c5f0bc642c633a2d5e", + "sha256:c92811b2d4c9b6ea0285942b2e7cac98a59e166d59c588fe5cfe1eda58e72d59", + "sha256:d1454bde93fb1e224166811694d600e746430c006fbb031ea06ecc2ea41bf156", + "sha256:d735786acc7dd25815e89cc4ad529a43af779db2e25aa7c626de864127e5a024", + "sha256:de80739447af31525feddeb8effd640782cf5998e1a4e9192ebdf829717e3913", + "sha256:ff432630e510709564c01dafdbe996cb552e0b9f3f065eb89bdce5bd31fabf4c" ], "index": "pypi", - "version": "==2.9.7" + "markers": "python_version >= '3.7'", + "version": "==2.9.9" }, "pycparser": { "hashes": [ "sha256:8ee45429555515e1f6b185e78100aea234072576aa43ab53aefcae078162fca9", "sha256:e644fdec12f7872f86c58ff790da456218b10f863970249516d60a5eaca77206" ], - "markers": "python_version >= '2.7' and python_version not in '3.0, 3.1, 3.2, 3.3'", "version": "==2.21" }, "pyjwt": { @@ -896,6 +921,7 @@ "sha256:fd66fc5d0da6d9815ba2cebeb4205f95818ff4b79c3ebe268e75d961704af52f" ], "index": "pypi", + "markers": "python_version >= '3.6'", "version": "==6.0.1" }, "requests": { @@ -904,6 +930,7 @@ "sha256:942c5a758f98d790eaed1a29cb6eefc7ffb0d1cf7af05c3d2791656dbd6ad1e1" ], "index": "pypi", + "markers": "python_version >= '3.7'", "version": "==2.31.0" }, "s3transfer": { @@ -916,11 +943,11 @@ }, "sentry-sdk": { "hashes": [ - "sha256:64a7141005fb775b9db298a30de93e3b83e0ddd1232dc6f36eb38aebc1553291", - "sha256:6de2e88304873484207fed836388e422aeff000609b104c802749fd89d56ba5b" + "sha256:76dd087f38062ac6c1e30ed6feb533ee0037ff9e709974802db7b5dbf2e5db21", + "sha256:e5d0d2b25931d88fa10986da59d941ac6037f742ab6ff2fce4143a27981d60c3" ], "index": "pypi", - "version": "==1.31.0" + "version": "==1.34.0" }, "shortener": { "hashes": [ @@ -928,6 +955,7 @@ "sha256:b40d1309ae8cfea6132b8f10ff1d5e3e44675989f817305943cf97b492e09f72" ], "index": "pypi", + "markers": "python_version >= '3.5'", "version": "==0.2.1" }, "six": { @@ -956,11 +984,12 @@ }, "twilio": { "hashes": [ - "sha256:d2f71060575432f73ed73f7cfc33259c53c96b92aa969d2910dacc8da1d1a5d9", - "sha256:e711b5ea89694cb58a55a6b69f6190ea4c8499a1d6d68eb6a03c9840bb78fbb3" + "sha256:1eb04af92f3e70fcc87a2fd30617f53784e34045d054e4ae3dc9cfe7bdf1e692", + "sha256:3bf2def228ceaa7519f4d6e58b2e3c9cb5d865af02b4618239e52c9d9e75e29d" ], "index": "pypi", - "version": "==8.9.0" + "markers": "python_full_version >= '3.7.0'", + "version": "==8.10.0" }, "typing-extensions": { "hashes": [ @@ -976,22 +1005,23 @@ "sha256:830c08b8d99bdd312ea4ead05994a38e8936266f84b9a7878232db50b044e02e" ], "index": "pypi", + "markers": "python_version >= '3.6'", "version": "==4.1.1" }, "urllib3": { "hashes": [ - "sha256:8d36afa7616d8ab714608411b4a3b13e58f463aee519024578e062e141dce20f", - "sha256:8f135f6502756bde6b2a9b28989df5fbe87c9970cecaa69041edcce7f0589b14" + "sha256:c97dfde1f7bd43a71c8d2a58e369e9b2bf692d1334ea9f9cae55add7d0dd0f84", + "sha256:fdb6d215c776278489906c2f8916e6e7d4f5a9b602ccbcfdf7f016fc8da0596e" ], - "markers": "python_version >= '3.6'", - "version": "==1.26.16" + "markers": "python_version >= '3.7'", + "version": "==2.0.7" }, "uwsgi": { "hashes": [ - "sha256:4cc4727258671ac5fa17ab422155e9aaef8a2008ebb86e4404b66deaae965db2" + "sha256:0cafda0c16f921db7fe42cfaf81b167cf884ee17350efbdd87d1ecece2d7de37" ], "index": "pypi", - "version": "==2.0.22" + "version": "==2.0.23" }, "wrapt": { "hashes": [ @@ -1166,11 +1196,28 @@ }, "black": { "hashes": [ - "sha256:380f1b5da05e5a1429225676655dddb96f5ae8c75bdf91e53d798871b902a115", - "sha256:7de4cfc7eb6b710de325712d40125689101d21d25283eed7e9998722cf10eb91" + "sha256:037e9b4664cafda5f025a1728c50a9e9aedb99a759c89f760bd83730e76ba884", + "sha256:1b917a2aa020ca600483a7b340c165970b26e9029067f019e3755b56e8dd5916", + "sha256:1f8ce316753428ff68749c65a5f7844631aa18c8679dfd3ca9dc1a289979c258", + "sha256:33d40f5b06be80c1bbce17b173cda17994fbad096ce60eb22054da021bf933d1", + "sha256:3f157a8945a7b2d424da3335f7ace89c14a3b0625e6593d21139c2d8214d55ce", + "sha256:5ed45ac9a613fb52dad3b61c8dea2ec9510bf3108d4db88422bacc7d1ba1243d", + "sha256:6d23d7822140e3fef190734216cefb262521789367fbdc0b3f22af6744058982", + "sha256:7670242e90dc129c539e9ca17665e39a146a761e681805c54fbd86015c7c84f7", + "sha256:7b4d10b0f016616a0d93d24a448100adf1699712fb7a4efd0e2c32bbb219b173", + "sha256:7cb5936e686e782fddb1c73f8aa6f459e1ad38a6a7b0e54b403f1f05a1507ee9", + "sha256:7d56124b7a61d092cb52cce34182a5280e160e6aff3137172a68c2c2c4b76bcb", + "sha256:840015166dbdfbc47992871325799fd2dc0dcf9395e401ada6d88fe11498abad", + "sha256:9c74de4c77b849e6359c6f01987e94873c707098322b91490d24296f66d067dc", + "sha256:b15b75fc53a2fbcac8a87d3e20f69874d161beef13954747e053bca7a1ce53a0", + "sha256:cfcce6f0a384d0da692119f2d72d79ed07c7159879d0bb1bb32d2e443382bf3a", + "sha256:d431e6739f727bb2e0495df64a6c7a5310758e87505f5f8cde9ff6c0f2d7e4fe", + "sha256:e293e4c2f4a992b980032bbd62df07c1bcff82d6964d6c9496f2cd726e246ace", + "sha256:ec3f8e6234c4e46ff9e16d9ae96f4ef69fa328bb4ad08198c8cee45bb1f08c69" ], "index": "pypi", - "version": "==21.9b0" + "markers": "python_version >= '3.8'", + "version": "==23.10.1" }, "click": { "hashes": [ @@ -1182,11 +1229,12 @@ }, "django": { "hashes": [ - "sha256:5e5c1c9548ffb7796b4a8a4782e9a2e5a3df3615259fc1bfd3ebc73b646146c1", - "sha256:b6b2b5cae821077f137dc4dade696a1c2aa292f892eca28fa8d7bfdf2608ddd4" + "sha256:8e0f1c2c2786b5c0e39fe1afce24c926040fad47c8ea8ad30aaf1188df29fc41", + "sha256:e1d37c51ad26186de355cbcec16613ebdabfa9689bbade9c538835205a8abbe9" ], "index": "pypi", - "version": "==4.2.5" + "markers": "python_version >= '3.8'", + "version": "==4.2.7" }, "django-debug-toolbar": { "hashes": [ @@ -1194,6 +1242,7 @@ "sha256:bc7fdaafafcdedefcc67a4a5ad9dac96efd6e41db15bc74d402a54a2ba4854dc" ], "index": "pypi", + "markers": "python_version >= '3.8'", "version": "==4.2.0" }, "django-extensions": { @@ -1202,6 +1251,7 @@ "sha256:9600b7562f79a92cbf1fde6403c04fee314608fefbb595502e34383ae8203401" ], "index": "pypi", + "markers": "python_version >= '3.6'", "version": "==3.2.3" }, "flake8": { @@ -1210,14 +1260,17 @@ "sha256:ffdfce58ea94c6580c77888a86506937f9a1a227dfcd15f245d694ae20a6b6e5" ], "index": "pypi", + "markers": "python_full_version >= '3.8.1'", "version": "==6.1.0" }, "flake8-absolute-import": { "hashes": [ - "sha256:d24f189bca52ffc0d13e8046606ea42d22a9ad9d409bf39e52b93493cf2ffd2c" + "sha256:b72142db999ec5e0ac4f4ac57fb8776a2959d07346c4d3742c446f206d45fcef", + "sha256:fcb734ac5a9639fa4ffbc6242ae9d6e9d8063f9cd078d6d218597ee883a99d48" ], "index": "pypi", - "version": "==1.0.0.1" + "markers": "python_version >= '3.6'", + "version": "==1.0.0.2" }, "flake8-isort": { "hashes": [ @@ -1225,6 +1278,7 @@ "sha256:8c4ab431d87780d0c8336e9614e50ef11201bc848ef64ca017532dec39d4bf49" ], "index": "pypi", + "markers": "python_version >= '3.7'", "version": "==5.0.3" }, "flake8-quotes": { @@ -1240,6 +1294,7 @@ "sha256:6e811fcb295968434526407adb8796944f1988c5b65e8139058f2014cbe100fd" ], "index": "pypi", + "markers": "python_version >= '2.7' and python_version not in '3.0, 3.1, 3.2, 3.3'", "version": "==4.3.21" }, "lxml": { @@ -1338,6 +1393,7 @@ "sha256:fe4bda6bd4340caa6e5cf95e73f8fea5c4bfc55763dd42f1b50a94c1b4a2fbd4" ], "index": "pypi", + "markers": "python_version >= '2.7' and python_version not in '3.0, 3.1, 3.2, 3.3, 3.4'", "version": "==4.9.3" }, "mccabe": { @@ -1356,6 +1412,14 @@ "markers": "python_version >= '3.5'", "version": "==1.0.0" }, + "packaging": { + "hashes": [ + "sha256:048fb0e9405036518eaaf48a55953c750c11e1a1b68e0dd1a9d62ed0c092cfc5", + "sha256:8c491190033a9af7e1d931d0b5dacc2ef47509b34dd0de67ed209b5203fc88c7" + ], + "markers": "python_version >= '3.7'", + "version": "==23.2" + }, "pathspec": { "hashes": [ "sha256:1d6ed233af05e679efb96b1851550ea95bbb64b7c490b0f5aa52996c11e92a20", @@ -1366,19 +1430,19 @@ }, "platformdirs": { "hashes": [ - "sha256:b45696dab2d7cc691a3226759c0d3b00c47c8b6e293d96f6436f733303f77f6d", - "sha256:d7c24979f292f916dc9cbf8648319032f551ea8c49a4c9bf2fb556a02070ec1d" + "sha256:cf8ee52a3afdb965072dcc652433e0c7e3e40cf5ea1477cd4b3b1d2eb75495b3", + "sha256:e9d171d00af68be50e9202731309c4e658fd8bc76f55c11c7dd760d023bda68e" ], "markers": "python_version >= '3.7'", - "version": "==3.10.0" + "version": "==3.11.0" }, "pycodestyle": { "hashes": [ - "sha256:259bcc17857d8a8b3b4a2327324b79e5f020a13c16074670f9c8c8f872ea76d0", - "sha256:5d1013ba8dc7895b548be5afb05740ca82454fd899971563d2ef625d090326f8" + "sha256:41ba0e7afc9752dfb53ced5489e89f8186be00e599e712660695b7a75ff2663f", + "sha256:44fe31000b2d866f2e41841b18528a505fbd7fef9017b04eff4e2648a0fadc67" ], "markers": "python_version >= '3.8'", - "version": "==2.11.0" + "version": "==2.11.1" }, "pyflakes": { "hashes": [ @@ -1388,100 +1452,6 @@ "markers": "python_version >= '3.8'", "version": "==3.1.0" }, - "regex": { - "hashes": [ - "sha256:0085da0f6c6393428bf0d9c08d8b1874d805bb55e17cb1dfa5ddb7cfb11140bf", - "sha256:06c57e14ac723b04458df5956cfb7e2d9caa6e9d353c0b4c7d5d54fcb1325c46", - "sha256:09b7f4c66aa9d1522b06e31a54f15581c37286237208df1345108fcf4e050c18", - "sha256:0c59122ceccb905a941fb23b087b8eafc5290bf983ebcb14d2301febcbe199c7", - "sha256:1005c60ed7037be0d9dea1f9c53cc42f836188227366370867222bda4c3c6bd7", - "sha256:14898830f0a0eb67cae2bbbc787c1a7d6e34ecc06fbd39d3af5fe29a4468e2c9", - "sha256:14dc6f2d88192a67d708341f3085df6a4f5a0c7b03dec08d763ca2cd86e9f559", - "sha256:1e7d84d64c84ad97bf06f3c8cb5e48941f135ace28f450d86af6b6512f1c9a71", - "sha256:2162ae2eb8b079622176a81b65d486ba50b888271302190870b8cc488587d280", - "sha256:22283c769a7b01c8ac355d5be0715bf6929b6267619505e289f792b01304d898", - "sha256:239c3c2a339d3b3ddd51c2daef10874410917cd2b998f043c13e2084cb191684", - "sha256:293352710172239bf579c90a9864d0df57340b6fd21272345222fb6371bf82b3", - "sha256:2ae54a338191e1356253e7883d9d19f8679b6143703086245fb14d1f20196be9", - "sha256:2e73e5243af12d9cd6a9d6a45a43570dbe2e5b1cdfc862f5ae2b031e44dd95a8", - "sha256:2e9216e0d2cdce7dbc9be48cb3eacb962740a09b011a116fd7af8c832ab116ca", - "sha256:3026cbcf11d79095a32d9a13bbc572a458727bd5b1ca332df4a79faecd45281c", - "sha256:3611576aff55918af2697410ff0293d6071b7e00f4b09e005d614686ac4cd57c", - "sha256:3ae646c35cb9f820491760ac62c25b6d6b496757fda2d51be429e0e7b67ae0ab", - "sha256:3b8e6ea6be6d64104d8e9afc34c151926f8182f84e7ac290a93925c0db004bfd", - "sha256:3d370ff652323c5307d9c8e4c62efd1956fb08051b0e9210212bc51168b4ff56", - "sha256:3f7454aa427b8ab9101f3787eb178057c5250478e39b99540cfc2b889c7d0586", - "sha256:40f029d73b10fac448c73d6eb33d57b34607f40116e9f6e9f0d32e9229b147d7", - "sha256:423adfa872b4908843ac3e7a30f957f5d5282944b81ca0a3b8a7ccbbfaa06103", - "sha256:4873ef92e03a4309b3ccd8281454801b291b689f6ad45ef8c3658b6fa761d7ac", - "sha256:48c640b99213643d141550326f34f0502fedb1798adb3c9eb79650b1ecb2f177", - "sha256:4ae594c66f4a7e1ea67232a0846649a7c94c188d6c071ac0210c3e86a5f92109", - "sha256:4b694430b3f00eb02c594ff5a16db30e054c1b9589a043fe9174584c6efa8033", - "sha256:51d8ea2a3a1a8fe4f67de21b8b93757005213e8ac3917567872f2865185fa7fb", - "sha256:54de2619f5ea58474f2ac211ceea6b615af2d7e4306220d4f3fe690c91988a61", - "sha256:551ad543fa19e94943c5b2cebc54c73353ffff08228ee5f3376bd27b3d5b9800", - "sha256:5543c055d8ec7801901e1193a51570643d6a6ab8751b1f7dd9af71af467538bb", - "sha256:5cd9cd7170459b9223c5e592ac036e0704bee765706445c353d96f2890e816c8", - "sha256:5ec4b3f0aebbbe2fc0134ee30a791af522a92ad9f164858805a77442d7d18570", - "sha256:67ecd894e56a0c6108ec5ab1d8fa8418ec0cff45844a855966b875d1039a2e34", - "sha256:6ab2ed84bf0137927846b37e882745a827458689eb969028af8032b1b3dac78e", - "sha256:704f63b774218207b8ccc6c47fcef5340741e5d839d11d606f70af93ee78e4d4", - "sha256:7098c524ba9f20717a56a8d551d2ed491ea89cbf37e540759ed3b776a4f8d6eb", - "sha256:7aed90a72fc3654fba9bc4b7f851571dcc368120432ad68b226bd593f3f6c0b7", - "sha256:7ce606c14bb195b0e5108544b540e2c5faed6843367e4ab3deb5c6aa5e681208", - "sha256:7eb95fe8222932c10d4436e7a6f7c99991e3fdd9f36c949eff16a69246dee2dc", - "sha256:80b80b889cb767cc47f31d2b2f3dec2db8126fbcd0cff31b3925b4dc6609dcdb", - "sha256:82cd0a69cd28f6cc3789cc6adeb1027f79526b1ab50b1f6062bbc3a0ccb2dbc3", - "sha256:83215147121e15d5f3a45d99abeed9cf1fe16869d5c233b08c56cdf75f43a504", - "sha256:88900f521c645f784260a8d346e12a1590f79e96403971241e64c3a265c8ecdb", - "sha256:91129ff1bb0619bc1f4ad19485718cc623a2dc433dff95baadbf89405c7f6b57", - "sha256:920974009fb37b20d32afcdf0227a2e707eb83fe418713f7a8b7de038b870d0b", - "sha256:9233ac249b354c54146e392e8a451e465dd2d967fc773690811d3a8c240ac601", - "sha256:941460db8fe3bd613db52f05259c9336f5a47ccae7d7def44cc277184030a116", - "sha256:942f8b1f3b223638b02df7df79140646c03938d488fbfb771824f3d05fc083a8", - "sha256:964b16dcc10c79a4a2be9f1273fcc2684a9eedb3906439720598029a797b46e6", - "sha256:9691a549c19c22d26a4f3b948071e93517bdf86e41b81d8c6ac8a964bb71e5a6", - "sha256:96979d753b1dc3b2169003e1854dc67bfc86edf93c01e84757927f810b8c3c93", - "sha256:987b9ac04d0b38ef4f89fbc035e84a7efad9cdd5f1e29024f9289182c8d99e09", - "sha256:988631b9d78b546e284478c2ec15c8a85960e262e247b35ca5eaf7ee22f6050a", - "sha256:9a96edd79661e93327cfeac4edec72a4046e14550a1d22aa0dd2e3ca52aec921", - "sha256:9b7408511fca48a82a119d78a77c2f5eb1b22fe88b0d2450ed0756d194fe7a9a", - "sha256:9dd6082f4e2aec9b6a0927202c85bc1b09dcab113f97265127c1dc20e2e32495", - "sha256:a2ad5add903eb7cdde2b7c64aaca405f3957ab34f16594d2b78d53b8b1a6a7d6", - "sha256:a8c65c17aed7e15a0c824cdc63a6b104dfc530f6fa8cb6ac51c437af52b481c7", - "sha256:aadf28046e77a72f30dcc1ab185639e8de7f4104b8cb5c6dfa5d8ed860e57236", - "sha256:b076da1ed19dc37788f6a934c60adf97bd02c7eea461b73730513921a85d4235", - "sha256:b2aeab3895d778155054abea5238d0eb9a72e9242bd4b43f42fd911ef9a13470", - "sha256:b82edc98d107cbc7357da7a5a695901b47d6eb0420e587256ba3ad24b80b7d0b", - "sha256:b8a0ccc8f2698f120e9e5742f4b38dc944c38744d4bdfc427616f3a163dd9de5", - "sha256:b993b6f524d1e274a5062488a43e3f9f8764ee9745ccd8e8193df743dbe5ee61", - "sha256:bb34d1605f96a245fc39790a117ac1bac8de84ab7691637b26ab2c5efb8f228c", - "sha256:bd3366aceedf274f765a3a4bc95d6cd97b130d1dda524d8f25225d14123c01db", - "sha256:c12f6f67495ea05c3d542d119d270007090bad5b843f642d418eb601ec0fa7be", - "sha256:c662a4cbdd6280ee56f841f14620787215a171c4e2d1744c9528bed8f5816c96", - "sha256:c884d1a59e69e03b93cf0dfee8794c63d7de0ee8f7ffb76e5f75be8131b6400a", - "sha256:ca339088839582d01654e6f83a637a4b8194d0960477b9769d2ff2cfa0fa36d2", - "sha256:cd2b6c5dfe0929b6c23dde9624483380b170b6e34ed79054ad131b20203a1a63", - "sha256:ce0f9fbe7d295f9922c0424a3637b88c6c472b75eafeaff6f910494a1fa719ef", - "sha256:cf0633e4a1b667bfe0bb10b5e53fe0d5f34a6243ea2530eb342491f1adf4f739", - "sha256:cf9273e96f3ee2ac89ffcb17627a78f78e7516b08f94dc435844ae72576a276e", - "sha256:d909b5a3fff619dc7e48b6b1bedc2f30ec43033ba7af32f936c10839e81b9217", - "sha256:d9b6627408021452dcd0d2cdf8da0534e19d93d070bfa8b6b4176f99711e7f90", - "sha256:de35342190deb7b866ad6ba5cbcccb2d22c0487ee0cbb251efef0843d705f0d4", - "sha256:e51c80c168074faa793685656c38eb7a06cbad7774c8cbc3ea05552d615393d8", - "sha256:e6bd1e9b95bc5614a7a9c9c44fde9539cba1c823b43a9f7bc11266446dd568e3", - "sha256:e7a9aaa5a1267125eef22cef3b63484c3241aaec6f48949b366d26c7250e0357", - "sha256:e951d1a8e9963ea51efd7f150450803e3b95db5939f994ad3d5edac2b6f6e2b4", - "sha256:e9941a4ada58f6218694f382e43fdd256e97615db9da135e77359da257a7168b", - "sha256:f0640913d2c1044d97e30d7c41728195fc37e54d190c5385eacb52115127b882", - "sha256:f0ccf3e01afeb412a1a9993049cb160d0352dba635bbca7762b2dc722aa5742a", - "sha256:f2181c20ef18747d5f4a7ea513e09ea03bdd50884a11ce46066bb90fe4213675", - "sha256:f2200e00b62568cfd920127782c61bc1c546062a879cdc741cfcc6976668dfcf", - "sha256:fcbdc5f2b0f1cd0f6a56cdb46fe41d2cce1e644e3b68832f3eeebc5fb0f7712e" - ], - "markers": "python_version >= '3.6'", - "version": "==2023.8.8" - }, "sqlparse": { "hashes": [ "sha256:5430a4fe2ac7d0f93e66f1efc6e1338a41884b7ddf2a350cedd20ccc4d9d28f3", @@ -1492,19 +1462,20 @@ }, "tblib": { "hashes": [ - "sha256:9100bfa016b047d5b980d66e7efed952fbd20bd85b56110aaf473cb97d18709a", - "sha256:a6df30f272c08bf8be66e0775fad862005d950a6b8449b94f7c788731d70ecd7" + "sha256:80a6c77e59b55e83911e1e607c649836a69c103963c5f28a46cbeef44acf8129", + "sha256:93622790a0a29e04f0346458face1e144dc4d32f493714c6c3dff82a4adb77e6" ], "index": "pypi", - "version": "==2.0.0" + "markers": "python_version >= '3.8'", + "version": "==3.0.0" }, "tomli": { "hashes": [ - "sha256:05b6166bff487dc068d322585c7ea4ef78deed501cc124060e0f238e89a9231f", - "sha256:e3069e4be3ead9668e21cb9b074cd948f7b3113fd9c8bba083f48247aab8b11c" + "sha256:939de3e7a6161af0c887ef91b7d41a53e7c5a1ca976325f429cb46ea9bc30ecc", + "sha256:de526c12914f0c550d15924c62d72abc48d6fe7364aa87328337a31007fe8a4f" ], - "markers": "python_version >= '3.6'", - "version": "==1.2.3" + "markers": "python_version < '3.11'", + "version": "==2.0.1" }, "typing-extensions": { "hashes": [ @@ -1520,6 +1491,7 @@ "sha256:f3d7402e5b3ac72a5ee3149278339db1a8f932ee405f48bcb9c681372f2717d5" ], "index": "pypi", + "markers": "python_version >= '3.7'", "version": "==3.2.0" } } diff --git a/backend/Platform/settings/base.py b/backend/Platform/settings/base.py index b9d3fa67..72183df1 100644 --- a/backend/Platform/settings/base.py +++ b/backend/Platform/settings/base.py @@ -24,9 +24,7 @@ # See https://docs.djangoproject.com/en/2.1/howto/deployment/checklist/ # SECURITY WARNING: keep the secret key used in production secret! -SECRET_KEY = os.environ.get( - "SECRET_KEY", "o7ql0!vuk0%rgrh9p2bihq#pege$qqlm@zo#8&t==%&za33m*2" -) +SECRET_KEY = os.environ.get("SECRET_KEY", "o7ql0!vuk0%rgrh9p2bihq#pege$qqlm@zo#8&t==%&za33m*2") IDENTITY_RSA_PRIVATE_KEY = os.environ.get( "IDENTITY_RSA_PRIVATE_KEY", @@ -114,9 +112,7 @@ # https://docs.djangoproject.com/en/2.1/ref/settings/#databases DATABASES = { - "default": dj_database_url.config( - default="sqlite:///" + os.path.join(BASE_DIR, "db.sqlite3") - ) + "default": dj_database_url.config(default="sqlite:///" + os.path.join(BASE_DIR, "db.sqlite3")) } # Set default PK type @@ -126,9 +122,7 @@ # https://docs.djangoproject.com/en/2.1/ref/settings/#auth-password-validators AUTH_PASSWORD_VALIDATORS = [ - { - "NAME": "django.contrib.auth.password_validation.UserAttributeSimilarityValidator" - }, + {"NAME": "django.contrib.auth.password_validation.UserAttributeSimilarityValidator"}, {"NAME": "django.contrib.auth.password_validation.MinimumLengthValidator"}, {"NAME": "django.contrib.auth.password_validation.CommonPasswordValidator"}, {"NAME": "django.contrib.auth.password_validation.NumericPasswordValidator"}, diff --git a/backend/accounts/admin.py b/backend/accounts/admin.py index c7f10797..a1a39dad 100644 --- a/backend/accounts/admin.py +++ b/backend/accounts/admin.py @@ -98,9 +98,7 @@ class LabsAdminSite(admin.AdminSite): def login(self, request, extra_context=None): if not request.user.is_authenticated: - return redirect( - reverse("accounts:login") + "?next=" + request.GET.get("next") - ) + return redirect(reverse("accounts:login") + "?next=" + request.GET.get("next")) return super().login(request, extra_context) diff --git a/backend/accounts/backends.py b/backend/accounts/backends.py index 899ca74a..26a52246 100644 --- a/backend/accounts/backends.py +++ b/backend/accounts/backends.py @@ -30,7 +30,7 @@ def get_email(self, pennid): return None return response[0]["email"] - except (requests.exceptions.RequestException): + except requests.exceptions.RequestException: return None def authenticate(self, request, remote_user, shibboleth_attributes): @@ -70,9 +70,7 @@ def authenticate(self, request, remote_user, shibboleth_attributes): # Update groups with every log in user.groups.clear() for affiliation_name in shibboleth_attributes["affiliation"]: - if ( - affiliation_name - ): # Some users don't have any affiliation somehow ¯\_(ツ)_/¯ + if affiliation_name: # Some users don't have any affiliation somehow ¯\_(ツ)_/¯ group, _ = Group.objects.get_or_create(name=affiliation_name) user.groups.add(group) diff --git a/backend/accounts/migrations/0001_initial.py b/backend/accounts/migrations/0001_initial.py index cc8a5001..0e8065ab 100644 --- a/backend/accounts/migrations/0001_initial.py +++ b/backend/accounts/migrations/0001_initial.py @@ -11,7 +11,6 @@ class Migration(migrations.Migration): - initial = True dependencies = [("auth", "0011_update_proxy_permissions")] @@ -23,9 +22,7 @@ class Migration(migrations.Migration): ("password", models.CharField(max_length=128, verbose_name="password")), ( "last_login", - models.DateTimeField( - blank=True, null=True, verbose_name="last login" - ), + models.DateTimeField(blank=True, null=True, verbose_name="last login"), ), ( "is_superuser", @@ -38,35 +35,25 @@ class Migration(migrations.Migration): ( "username", models.CharField( - error_messages={ - "unique": "A user with that username already exists." - }, + error_messages={"unique": "A user with that username already exists."}, help_text="Required. 150 characters or fewer. Letters, digits and @/./+/-/_ only.", max_length=150, unique=True, - validators=[ - django.contrib.auth.validators.UnicodeUsernameValidator() - ], + validators=[django.contrib.auth.validators.UnicodeUsernameValidator()], verbose_name="username", ), ), ( "first_name", - models.CharField( - blank=True, max_length=30, verbose_name="first name" - ), + models.CharField(blank=True, max_length=30, verbose_name="first name"), ), ( "last_name", - models.CharField( - blank=True, max_length=150, verbose_name="last name" - ), + models.CharField(blank=True, max_length=150, verbose_name="last name"), ), ( "email", - models.EmailField( - blank=True, max_length=254, verbose_name="email address" - ), + models.EmailField(blank=True, max_length=254, verbose_name="email address"), ), ( "is_staff", diff --git a/backend/accounts/migrations/0002_auto_20200213_1711.py b/backend/accounts/migrations/0002_auto_20200213_1711.py index 740f3816..936d4574 100644 --- a/backend/accounts/migrations/0002_auto_20200213_1711.py +++ b/backend/accounts/migrations/0002_auto_20200213_1711.py @@ -22,9 +22,7 @@ def copy_permissions(apps, schema_editor): ContentType = apps.get_model("contenttypes", "ContentType") for user in User.objects.all(): for product_permission in user.product_permission.all(): - content_type = ContentType.objects.get( - app_label="accounts", model="user" - ) + content_type = ContentType.objects.get(app_label="accounts", model="user") perm, _ = Permission.objects.get_or_create( codename=product_permission.id, name=product_permission.name, @@ -35,7 +33,6 @@ def copy_permissions(apps, schema_editor): class Migration(migrations.Migration): - dependencies = [("accounts", "0001_initial")] operations = [ diff --git a/backend/accounts/migrations/0003_auto_20210918_2041.py b/backend/accounts/migrations/0003_auto_20210918_2041.py index ebf58f52..bd2977a2 100644 --- a/backend/accounts/migrations/0003_auto_20210918_2041.py +++ b/backend/accounts/migrations/0003_auto_20210918_2041.py @@ -32,7 +32,6 @@ def create_email_objects(apps, schema_editor): class Migration(migrations.Migration): - dependencies = [ ("accounts", "0002_auto_20200213_1711"), ] @@ -114,9 +113,7 @@ class Migration(migrations.Migration): migrations.AlterField( model_name="user", name="first_name", - field=models.CharField( - blank=True, max_length=150, verbose_name="first name" - ), + field=models.CharField(blank=True, max_length=150, verbose_name="first name"), ), migrations.CreateModel( name="PhoneNumber", diff --git a/backend/accounts/migrations/0004_user_profile_pic.py b/backend/accounts/migrations/0004_user_profile_pic.py index 244d5e92..3a203f7a 100644 --- a/backend/accounts/migrations/0004_user_profile_pic.py +++ b/backend/accounts/migrations/0004_user_profile_pic.py @@ -5,7 +5,6 @@ class Migration(migrations.Migration): - dependencies = [ ("accounts", "0003_auto_20210918_2041"), ] diff --git a/backend/accounts/migrations/0005_privacyresource_privacysetting.py b/backend/accounts/migrations/0005_privacyresource_privacysetting.py index f63a9439..b5ce7e07 100644 --- a/backend/accounts/migrations/0005_privacyresource_privacysetting.py +++ b/backend/accounts/migrations/0005_privacyresource_privacysetting.py @@ -6,7 +6,6 @@ class Migration(migrations.Migration): - dependencies = [ ("accounts", "0004_user_profile_pic"), ] diff --git a/backend/accounts/mixins.py b/backend/accounts/mixins.py index 51ac6ff1..c518eac1 100644 --- a/backend/accounts/mixins.py +++ b/backend/accounts/mixins.py @@ -23,22 +23,12 @@ def _lookup_item(self, model, field_name, item, mode=None): return model.objects.get(**item) except ObjectDoesNotExist: raise serializers.ValidationError( - { - field_name: [ - "The object with these values does not exist: {}".format( - item - ) - ] - }, + {field_name: ["The object with these values does not exist: {}".format(item)]}, code="invalid", ) except MultipleObjectsReturned: raise serializers.ValidationError( - { - field_name: [ - "Multiple objects exist with these values: {}".format(item) - ] - } + {field_name: ["Multiple objects exist with these values: {}".format(item)]} ) def save(self): @@ -75,9 +65,7 @@ def save(self): for item in items: # adds item to list - m2m_lists[field_name].append( - self._lookup_item(model, field_name, item, mode) - ) + m2m_lists[field_name].append(self._lookup_item(model, field_name, item, mode)) else: m2m["many"] = False # handles if it's a 1:1 field @@ -85,9 +73,7 @@ def save(self): model = field.Meta.model item = self.validated_data.pop(field_name, None) # creates/gets objects associaated with list and creates list of objects - m2m_lists[field_name] = self._lookup_item( - model, field_name, item, mode - ) + m2m_lists[field_name] = self._lookup_item(model, field_name, item, mode) else: # handles if it's accidentally added (e.g. Integer field, character field, etc.) ignore_fields.add(field_name) diff --git a/backend/accounts/models.py b/backend/accounts/models.py index e4032246..b3a183df 100644 --- a/backend/accounts/models.py +++ b/backend/accounts/models.py @@ -63,9 +63,7 @@ class User(AbstractUser): pennid = models.IntegerField(primary_key=True) uuid = models.UUIDField(unique=True, default=uuid.uuid4, editable=False) preferred_name = models.CharField(max_length=225, blank=True) - profile_pic = models.ImageField( - upload_to=get_user_image_filepath, blank=True, null=True - ) + profile_pic = models.ImageField(upload_to=get_user_image_filepath, blank=True, null=True) VERIFICATION_EXPIRATION_MINUTES = 10 @@ -90,9 +88,7 @@ class Student(models.Model): ) major = models.ManyToManyField(Major, blank=True) school = models.ManyToManyField(School, blank=True) - graduation_year = models.PositiveIntegerField( - validators=[MinValueValidator(1740)], null=True - ) + graduation_year = models.PositiveIntegerField(validators=[MinValueValidator(1740)], null=True) def __str__(self): return self.user.username @@ -108,9 +104,7 @@ def ensure_student_object(sender, instance, created, **kwargs): class Email(models.Model): - user = models.ForeignKey( - get_user_model(), related_name="emails", on_delete=models.CASCADE - ) + user = models.ForeignKey(get_user_model(), related_name="emails", on_delete=models.CASCADE) value = models.EmailField(unique=True) primary = models.BooleanField(default=False) verification_code = models.CharField(max_length=6, blank=True, null=True) @@ -152,9 +146,7 @@ def add_privacy_resource(sender, instance, created, **kwargs): to true. """ users = User.objects.all() - settings = [ - PrivacySetting(user=user, resource=instance, enabled=True) for user in users - ] + settings = [PrivacySetting(user=user, resource=instance, enabled=True) for user in users] # Bulk creating for all User objects PrivacySetting.objects.bulk_create(settings, ignore_conflicts=True) @@ -163,9 +155,7 @@ class PrivacySetting(models.Model): user = models.ForeignKey( get_user_model(), related_name="privacy_setting", on_delete=models.CASCADE ) - resource = models.ForeignKey( - PrivacyResource, related_name="resource", on_delete=models.CASCADE - ) + resource = models.ForeignKey(PrivacyResource, related_name="resource", on_delete=models.CASCADE) enabled = models.BooleanField(default=True) @@ -181,7 +171,6 @@ def load_privacy_settings(sender, instance, created, **kwargs): if not instance.privacy_setting.exists(): resources = PrivacyResource.objects.all() settings = [ - PrivacySetting(user=instance, resource=resource, enabled=True) - for resource in resources + PrivacySetting(user=instance, resource=resource, enabled=True) for resource in resources ] PrivacySetting.objects.bulk_create(settings, ignore_conflicts=True) diff --git a/backend/accounts/serializers.py b/backend/accounts/serializers.py index 7570cfb6..69c38bdb 100644 --- a/backend/accounts/serializers.py +++ b/backend/accounts/serializers.py @@ -62,9 +62,7 @@ def create(self, validated_data): instance = super().create(validated_data) instance.verified = False instance.primary = False - instance.verification_code = get_random_string( - length=6, allowed_chars="1234567890" - ) + instance.verification_code = get_random_string(length=6, allowed_chars="1234567890") # timestamp is set by django instance.save() sendSMSVerification(instance.value, instance.verification_code) @@ -75,37 +73,24 @@ def update(self, instance, validated_data): elapsed_time = timezone.now() - instance.verification_timestamp if ( validated_data["verification_code"] == instance.verification_code - and elapsed_time.total_seconds() - < User.VERIFICATION_EXPIRATION_MINUTES * 60 + and elapsed_time.total_seconds() < User.VERIFICATION_EXPIRATION_MINUTES * 60 ): - if ( - self.context["request"] - .user.phone_numbers.filter(verified=True) - .count() - == 0 - ): + if self.context["request"].user.phone_numbers.filter(verified=True).count() == 0: instance.primary = True instance.verified = True - elif ( - elapsed_time.total_seconds() - >= User.VERIFICATION_EXPIRATION_MINUTES * 60 - ): + elif elapsed_time.total_seconds() >= User.VERIFICATION_EXPIRATION_MINUTES * 60: raise serializers.ValidationError( detail={"detail": "Verification code has expired"} ) else: - raise serializers.ValidationError( - detail={"detail": "Incorrect verification code"} - ) + raise serializers.ValidationError(detail={"detail": "Incorrect verification code"}) if "primary" in validated_data and validated_data["primary"]: if instance.verified: self.context["request"].user.phone_numbers.all().update(primary=False) instance.primary = True else: raise serializers.ValidationError( - detail={ - "detail": "Must verify point of contact before marking as primary" - } + detail={"detail": "Must verify point of contact before marking as primary"} ) instance.save() return instance @@ -122,9 +107,7 @@ def create(self, validated_data): instance = super().create(validated_data) instance.verified = False instance.primary = False - instance.verification_code = get_random_string( - length=6, allowed_chars="1234567890" - ) + instance.verification_code = get_random_string(length=6, allowed_chars="1234567890") # timestamp is set by django instance.save() sendEmailVerification(instance.value, instance.verification_code) @@ -135,35 +118,24 @@ def update(self, instance, validated_data): elapsed_time = timezone.now() - instance.verification_timestamp if ( validated_data["verification_code"] == instance.verification_code - and elapsed_time.total_seconds() - < User.VERIFICATION_EXPIRATION_MINUTES * 60 + and elapsed_time.total_seconds() < User.VERIFICATION_EXPIRATION_MINUTES * 60 ): - if ( - self.context["request"].user.emails.filter(verified=True).count() - == 0 - ): + if self.context["request"].user.emails.filter(verified=True).count() == 0: instance.primary = True instance.verified = True - elif ( - elapsed_time.total_seconds() - >= User.VERIFICATION_EXPIRATION_MINUTES * 60 - ): + elif elapsed_time.total_seconds() >= User.VERIFICATION_EXPIRATION_MINUTES * 60: raise serializers.ValidationError( detail={"detail": "Verification code has expired"} ) else: - raise serializers.ValidationError( - detail={"detail": "Incorrect verification code"} - ) + raise serializers.ValidationError(detail={"detail": "Incorrect verification code"}) if "primary" in validated_data and validated_data["primary"]: if instance.verified: self.context["request"].user.emails.all().update(primary=False) instance.primary = True else: raise serializers.ValidationError( - detail={ - "detail": "Must verify point of contact before marking as primary" - } + detail={"detail": "Must verify point of contact before marking as primary"} ) instance.save() return instance diff --git a/backend/accounts/update_majors.py b/backend/accounts/update_majors.py index 7d206e09..99aa4b0f 100644 --- a/backend/accounts/update_majors.py +++ b/backend/accounts/update_majors.py @@ -34,9 +34,7 @@ def update_all_majors(): listed_majors = set() # iterate through all list tags with "item" in the class (all programs) - for program in soup.find_all( - "li", class_=lambda value: value and value.startswith("item ") - ): + for program in soup.find_all("li", class_=lambda value: value and value.startswith("item ")): curr_filter_list = program.attrs["class"] # check if entry meets relevant desired and excluded filter criteria if not contains_filters( @@ -60,9 +58,7 @@ def update_all_majors(): curr_degree_type = Major.DEGREE_PROFESSIONAL # create new major entry if it does not already exist - Major.objects.update_or_create( - name=major_name, defaults={"degree_type": curr_degree_type} - ) + Major.objects.update_or_create(name=major_name, defaults={"degree_type": curr_degree_type}) # keep track of found majors listed_majors.add(major_name) diff --git a/backend/accounts/views.py b/backend/accounts/views.py index 50f8acd4..3447e652 100644 --- a/backend/accounts/views.py +++ b/backend/accounts/views.py @@ -50,9 +50,7 @@ def image_upload_helper(request, user, keyword, field): keyword: the key corresponding to the image file in the request body field: the name of the User model field to which the file is saved """ - if keyword not in request.data or not isinstance( - request.data[keyword], UploadedFile - ): + if keyword not in request.data or not isinstance(request.data[keyword], UploadedFile): return Response( {"detail": "No image file was uploaded!"}, status=status.HTTP_400_BAD_REQUEST, @@ -99,9 +97,7 @@ def get(self, request): "last_name": last_name, "affiliation": affiliation, } - user = auth.authenticate( - remote_user=pennid, shibboleth_attributes=shibboleth_attributes - ) + user = auth.authenticate(remote_user=pennid, shibboleth_attributes=shibboleth_attributes) if user: auth.login(request, user) return redirect(request.GET.get("next", "/")) @@ -116,9 +112,7 @@ class LogoutView(View): def get(self, request): auth.logout(request) - return redirect( - "/Shibboleth.sso/Logout?return=https://idp.pennkey.upenn.edu/logout" - ) + return redirect("/Shibboleth.sso/Logout?return=https://idp.pennkey.upenn.edu/logout") class DevLoginView(View): @@ -128,9 +122,7 @@ class DevLoginView(View): """ def get(self, request): - user_objects = ( - get_user_model().objects.filter(~Q(username="admin")).order_by("pennid") - ) + user_objects = get_user_model().objects.filter(~Q(username="admin")).order_by("pennid") serialized_data = UserSerializer(user_objects, many=True).data return render(request, "accounts/devlogin.html", {"user_data": serialized_data}) @@ -402,9 +394,7 @@ def resend_verification(self, request, pk=None): obj = self.get_object() elapsed_time = timezone.now() - obj.verification_timestamp if elapsed_time.total_seconds() > User.VERIFICATION_EXPIRATION_MINUTES * 60: - obj.verification_code = get_random_string( - length=6, allowed_chars="1234567890" - ) + obj.verification_code = get_random_string(length=6, allowed_chars="1234567890") obj.verification_timestamp = timezone.now() sendSMSVerification(obj.value, obj.verification_code) obj.save() @@ -444,9 +434,7 @@ def get_queryset(self): def destroy(self, request, *args, **kwargs): is_primary = self.get_object().primary if is_primary and self.get_queryset().filter(verified=True).count() < 2: - return Response( - {"detail": "You can't delete the only verified email"}, status=405 - ) + return Response({"detail": "You can't delete the only verified email"}, status=405) self.get_object().delete() next_email = self.get_queryset().filter(verified=True).first() @@ -460,9 +448,7 @@ def resend_verification(self, request, pk=None): obj = self.get_object() elapsed_time = timezone.now() - obj.verification_timestamp if elapsed_time.total_seconds() > User.VERIFICATION_EXPIRATION_MINUTES * 60: - obj.verification_code = get_random_string( - length=6, allowed_chars="1234567890" - ) + obj.verification_code = get_random_string(length=6, allowed_chars="1234567890") obj.verification_timestamp = timezone.now() sendEmailVerification(obj.value, obj.verification_code) obj.save() @@ -513,9 +499,7 @@ class ProductAdminView(APIView): def post(self, request, format=None): # Revoke all existing admin permissions content_type = ContentType.objects.get(app_label="accounts", model="user") - perms = Permission.objects.filter( - content_type=content_type, codename__endswith="_admin" - ) + perms = Permission.objects.filter(content_type=content_type, codename__endswith="_admin") for perm in perms: perm.user_set.clear() User.objects.filter(Q(is_superuser=True) | Q(is_staff=True)).update( @@ -548,9 +532,7 @@ def post(self, request, format=None): return Response({"detail": "success"}) -class PrivacySettingView( - generics.GenericAPIView, mixins.ListModelMixin, mixins.UpdateModelMixin -): +class PrivacySettingView(generics.GenericAPIView, mixins.ListModelMixin, mixins.UpdateModelMixin): serializer_class = PrivacySettingSerializer permission_classes = [IsAuthenticated] diff --git a/backend/identity/utils.py b/backend/identity/utils.py index 7179266c..4e0858fa 100644 --- a/backend/identity/utils.py +++ b/backend/identity/utils.py @@ -36,8 +36,6 @@ def mint_refresh_jwt(key: jwk.JWK, urn: str) -> jwt.JWT: - no exp claim because refresh JWTs do not expire """ now = time.time() - token = jwt.JWT( - header={"alg": SIGNING_ALG}, claims={"sub": urn, "use": "refresh", "iat": now} - ) + token = jwt.JWT(header={"alg": SIGNING_ALG}, claims={"sub": urn, "use": "refresh", "iat": now}) token.make_signed_token(key) return token diff --git a/backend/identity/views.py b/backend/identity/views.py index 5265c318..be9a4220 100644 --- a/backend/identity/views.py +++ b/backend/identity/views.py @@ -68,11 +68,7 @@ class JwksInfoView(View): # building out JWKS view at init time so we don't have to recalculate it for each request def __init__(self, **kwargs): - data = { - "keys": [ - {"alg": SIGNING_ALG, "use": "sig", "kid": ID_PRIVATE_KEY.thumbprint()} - ] - } + data = {"keys": [{"alg": SIGNING_ALG, "use": "sig", "kid": ID_PRIVATE_KEY.thumbprint()}]} data["keys"][0].update(json.loads(ID_PRIVATE_KEY.export_public())) response = JsonResponse(data) response["Access-Control-Allow-Origin"] = "*" diff --git a/backend/tests/accounts/test_admin.py b/backend/tests/accounts/test_admin.py index 191b9c66..b99c43c6 100644 --- a/backend/tests/accounts/test_admin.py +++ b/backend/tests/accounts/test_admin.py @@ -22,20 +22,14 @@ def test_username(self): self.assertEqual(self.student_admin.username(self.student), self.user.username) def test_first_name(self): - self.assertEqual( - self.student_admin.first_name(self.student), self.user.first_name - ) + self.assertEqual(self.student_admin.first_name(self.student), self.user.first_name) def test_last_name(self): - self.assertEqual( - self.student_admin.last_name(self.student), self.user.last_name - ) + self.assertEqual(self.student_admin.last_name(self.student), self.user.last_name) class LabsAdminTestCase(TestCase): - check = ( - os.environ.get("DJANGO_SETTINGS_MODULE", "") == "Platform.settings.development" - ) + check = os.environ.get("DJANGO_SETTINGS_MODULE", "") == "Platform.settings.development" @skipIf(check, "This test doesn't matter in development") def test_admin_not_logged_in(self): diff --git a/backend/tests/accounts/test_backends.py b/backend/tests/accounts/test_backends.py index 17531c3f..6078e3a3 100644 --- a/backend/tests/accounts/test_backends.py +++ b/backend/tests/accounts/test_backends.py @@ -19,17 +19,13 @@ def setUp(self): } def test_invalid_remote_user(self): - user = auth.authenticate( - remote_user=-1, shibboleth_attributes=self.shibboleth_attributes - ) + user = auth.authenticate(remote_user=-1, shibboleth_attributes=self.shibboleth_attributes) self.assertIsNone(user) @patch("accounts.backends.ShibbolethRemoteUserBackend.get_email") def test_empty_shibboleth_attributes(self, mock_get_email): mock_get_email.return_value = None - user = auth.authenticate( - remote_user=1, shibboleth_attributes=self.shibboleth_attributes - ) + user = auth.authenticate(remote_user=1, shibboleth_attributes=self.shibboleth_attributes) self.assertEqual(user.pennid, 1) self.assertEqual(user.first_name, "") self.assertEqual(user.emails.count(), 1) @@ -41,9 +37,7 @@ def test_empty_shibboleth_attributes(self, mock_get_email): @patch("accounts.backends.ShibbolethRemoteUserBackend.get_email") def test_create_user(self, mock_get_email): mock_get_email.return_value = None - auth.authenticate( - remote_user=1, shibboleth_attributes=self.shibboleth_attributes - ) + auth.authenticate(remote_user=1, shibboleth_attributes=self.shibboleth_attributes) self.assertEqual(len(get_user_model().objects.all()), 1) user = get_user_model().objects.all()[0] self.assertEqual(user.pennid, 1) @@ -64,9 +58,7 @@ def test_create_user_with_attributes(self, mock_get_email): self.assertEqual(user.first_name, "test") self.assertEqual(user.last_name, "user") self.assertEqual(user.groups.get(name="student"), student_affiliation) - self.assertEqual( - user.groups.get(name="member"), Group.objects.get(name="member") - ) + self.assertEqual(user.groups.get(name="member"), Group.objects.get(name="member")) self.assertEqual(len(user.groups.all()), 2) self.assertEqual(len(Group.objects.all()), 2) @@ -91,9 +83,7 @@ def test_login_user(self, mock_get_email): student = get_user_model().objects.create_user( pennid=1, username="student", password="secret" ) - user = auth.authenticate( - remote_user=1, shibboleth_attributes=self.shibboleth_attributes - ) + user = auth.authenticate(remote_user=1, shibboleth_attributes=self.shibboleth_attributes) self.assertEqual(user, student) @patch("accounts.backends.ShibbolethRemoteUserBackend.get_email") diff --git a/backend/tests/accounts/test_serializers.py b/backend/tests/accounts/test_serializers.py index 221280f9..ec5773c2 100644 --- a/backend/tests/accounts/test_serializers.py +++ b/backend/tests/accounts/test_serializers.py @@ -46,9 +46,7 @@ def test_active_major(self): class MajorSerializerTestCase(TestCase): def setUp(self): - self.major_active = Major.objects.create( - name="Test Active Major", is_active=True - ) + self.major_active = Major.objects.create(name="Test Active Major", is_active=True) self.major_inactive = Major.objects.create( name="Test Inactive Major", degree_type="PHD", is_active=False ) @@ -75,9 +73,7 @@ def test_inactive_major(self): class StudentSerializerTestCase(TestCase): def setUp(self): - self.date = pytz.timezone("America/New_York").localize( - datetime.datetime(2019, 1, 1) - ) + self.date = pytz.timezone("America/New_York").localize(datetime.datetime(2019, 1, 1)) self.user = get_user_model().objects.create_user( pennid=1, username="student", @@ -86,9 +82,7 @@ def setUp(self): last_name="Last", email="test@test.com", ) - self.active_major_1 = Major.objects.create( - name="Test Active Major", is_active=True - ) + self.active_major_1 = Major.objects.create(name="Test Active Major", is_active=True) self.active_major_2 = Major.objects.create( name="Test Active Major 2", degree_type="PHD", is_active=True ) @@ -164,9 +158,7 @@ def test_remove_school(self): class UserSerializerTestCase(TestCase): def setUp(self): - self.date = pytz.timezone("America/New_York").localize( - datetime.datetime(2019, 1, 1) - ) + self.date = pytz.timezone("America/New_York").localize(datetime.datetime(2019, 1, 1)) self.user = get_user_model().objects.create_user( pennid=1, username="student", @@ -217,9 +209,7 @@ def test_preferred_same_as_first(self): class UserSearchSerializerTestCase(TestCase): def setUp(self): - self.date = pytz.timezone("America/New_York").localize( - datetime.datetime(2019, 1, 1) - ) + self.date = pytz.timezone("America/New_York").localize(datetime.datetime(2019, 1, 1)) self.user = get_user_model().objects.create_user( pennid=1, username="student", @@ -261,9 +251,7 @@ def test_str_preferred_name_provided(self): # student serializer info / test using nested serializer editing class StudentSerializerTestCaseOLD(TestCase): def setUp(self): - self.date = pytz.timezone("America/New_York").localize( - datetime.datetime(2019, 1, 1) - ) + self.date = pytz.timezone("America/New_York").localize(datetime.datetime(2019, 1, 1)) self.user = get_user_model().objects.create_user( pennid=1, username="student", @@ -337,9 +325,7 @@ def test_create(self): "verified": True, "verification_code": "000000", } - serializer = PhoneNumberSerializer( - data=data, context={"request": FakeRequest(self.user)} - ) + serializer = PhoneNumberSerializer(data=data, context={"request": FakeRequest(self.user)}) self.assertTrue(serializer.is_valid(raise_exception=True)) phone_number = serializer.save() self.assertEqual(phone_number.user, self.user) @@ -355,9 +341,7 @@ def test_create_same_phone(self): "verified": True, "verification_code": "000000", } - serializer = PhoneNumberSerializer( - data=data, context={"request": FakeRequest(self.user)} - ) + serializer = PhoneNumberSerializer(data=data, context={"request": FakeRequest(self.user)}) with self.assertRaises(serializers.ValidationError): serializer.is_valid(raise_exception=True) @@ -419,9 +403,7 @@ def test_verification_timeout(self): "verified": True, "verification_code": "000000", } - serializer = PhoneNumberSerializer( - data=data, context={"request": FakeRequest(self.user)} - ) + serializer = PhoneNumberSerializer(data=data, context={"request": FakeRequest(self.user)}) self.assertTrue(serializer.is_valid(raise_exception=True)) phone_number = serializer.save() @@ -470,9 +452,7 @@ def test_create(self): "verified": True, "verification_code": "000000", } - serializer = EmailSerializer( - data=data, context={"request": FakeRequest(self.user)} - ) + serializer = EmailSerializer(data=data, context={"request": FakeRequest(self.user)}) self.assertTrue(serializer.is_valid()) email = serializer.save() self.assertEqual(email.user, self.user) @@ -538,9 +518,7 @@ def test_verification_timeout(self): "verified": True, "verification_code": "000000", } - serializer = EmailSerializer( - data=data, context={"request": FakeRequest(self.user)} - ) + serializer = EmailSerializer(data=data, context={"request": FakeRequest(self.user)}) self.assertTrue(serializer.is_valid(raise_exception=True)) email = serializer.save() @@ -549,9 +527,7 @@ def test_verification_timeout(self): ) email.verification_code = "000000" data = {"value": "test@example.com", "verification_code": "000000"} - serializer = EmailSerializer( - email, data=data, context={"request": FakeRequest(self.user)} - ) + serializer = EmailSerializer(email, data=data, context={"request": FakeRequest(self.user)}) if serializer.is_valid(raise_exception=True): with self.assertRaises(serializers.ValidationError): serializer.save() diff --git a/backend/tests/accounts/test_verification.py b/backend/tests/accounts/test_verification.py index 3acd9a21..bde71ff3 100644 --- a/backend/tests/accounts/test_verification.py +++ b/backend/tests/accounts/test_verification.py @@ -13,13 +13,9 @@ def test_(self, mock_send_email): mock_send_email.assert_called() self.assertEqual(1, len(mock_send_email.mock_calls)) expected = {"verification_code": "000000"} - self.assertEqual( - "emails/email_verification.html", mock_send_email.call_args[0][0] - ) + self.assertEqual("emails/email_verification.html", mock_send_email.call_args[0][0]) self.assertEqual(expected, mock_send_email.call_args[0][1]) - self.assertEqual( - "Penn Labs email verification", mock_send_email.call_args[0][2] - ) + self.assertEqual("Penn Labs email verification", mock_send_email.call_args[0][2]) self.assertEqual("+15555555555", mock_send_email.call_args[0][3]) @@ -35,9 +31,7 @@ def test_invalid_client(self, mock_sentry): @patch("accounts.verification.capture_message") @patch("accounts.verification.Client") def test_rest_exception(self, mock_client, mock_sentry): - mock_client.return_value.messages.create.side_effect = TwilioRestException( - "", "" - ) + mock_client.return_value.messages.create.side_effect = TwilioRestException("", "") sendSMSVerification("+15555555555", "000000") mock_sentry.assert_called() self.assertEqual(1, len(mock_sentry.mock_calls)) diff --git a/backend/tests/accounts/test_views.py b/backend/tests/accounts/test_views.py index 3a1aeeb1..02d12fc9 100644 --- a/backend/tests/accounts/test_views.py +++ b/backend/tests/accounts/test_views.py @@ -69,13 +69,8 @@ def test_valid_shibboleth(self): "HTTP_SN": "user-hyphenated", "HTTP_MAIL": "test@student.edu", } - params = ( - reverse("accounts:authorize") - + "?client_id=abc123&response_type=code&state=abc" - ) - response = self.client.get( - reverse("accounts:login") + "?next=" + quote(params), **headers - ) + params = reverse("accounts:authorize") + "?client_id=abc123&response_type=code&state=abc" + response = self.client.get(reverse("accounts:login") + "?next=" + quote(params), **headers) base_url = "/accounts/authorize/" sample_response = base_url + "?client_id=abc123&response_type=code&state=abc" self.assertRedirects(response, sample_response, fetch_redirect_response=False) @@ -91,22 +86,16 @@ def setUp(self): reload_urlconf() def test_logged_in_user(self): - get_user_model().objects.create_user( - pennid=1, username="user", password="secret" - ) + get_user_model().objects.create_user(pennid=1, username="user", password="secret") self.client.login(username="user", password="secret") response = self.client.get(reverse("accounts:logout")) self.assertNotIn("_auth_user_id", self.client.session) - sample_response = ( - "/Shibboleth.sso/Logout?return=https://idp.pennkey.upenn.edu/logout" - ) + sample_response = "/Shibboleth.sso/Logout?return=https://idp.pennkey.upenn.edu/logout" self.assertRedirects(response, sample_response, fetch_redirect_response=False) def test_guest_user(self): response = self.client.get(reverse("accounts:logout")) - sample_response = ( - "/Shibboleth.sso/Logout?return=https://idp.pennkey.upenn.edu/logout" - ) + sample_response = "/Shibboleth.sso/Logout?return=https://idp.pennkey.upenn.edu/logout" self.assertRedirects(response, sample_response, fetch_redirect_response=False) @@ -141,9 +130,7 @@ def setUp(self): reload_urlconf() def test_logout_user(self): - get_user_model().objects.create_user( - pennid=1, username="user", password="secret" - ) + get_user_model().objects.create_user(pennid=1, username="user", password="secret") self.client.login(username="user", password="secret") response = self.client.get(reverse("accounts:logout")) self.assertNotIn("_auth_user_id", self.client.session) @@ -171,9 +158,7 @@ def setUp(self): self.resource_server_user = self.UserModel.objects.create_user( pennid=1, username="resource_server" ) - self.test_user = self.UserModel.objects.create_user( - pennid=2, username="bar_user" - ) + self.test_user = self.UserModel.objects.create_user(pennid=2, username="bar_user") self.application = self.Application( name="Test Application", @@ -209,9 +194,7 @@ def setUp(self): ) def test_view_post_valid_token(self): - auth_headers = { - "HTTP_AUTHORIZATION": "Bearer " + self.resource_server_token.token - } + auth_headers = {"HTTP_AUTHORIZATION": "Bearer " + self.resource_server_token.token} response = self.client.post( reverse("accounts:introspect"), {"token": self.valid_token.token}, @@ -233,9 +216,7 @@ def test_view_post_valid_token(self): ) def test_view_post_invalid_token(self): - auth_headers = { - "HTTP_AUTHORIZATION": "Bearer " + self.resource_server_token.token - } + auth_headers = {"HTTP_AUTHORIZATION": "Bearer " + self.resource_server_token.token} response = self.client.post( reverse("accounts:introspect"), {"token": self.invalid_token.token}, @@ -248,9 +229,7 @@ def test_view_post_invalid_token(self): self.assertDictEqual(content, {"active": False}) def test_view_post_notexisting_token(self): - auth_headers = { - "HTTP_AUTHORIZATION": "Bearer " + self.resource_server_token.token - } + auth_headers = {"HTTP_AUTHORIZATION": "Bearer " + self.resource_server_token.token} response = self.client.post( reverse("accounts:introspect"), {"token": "kaudawelsch"}, **auth_headers ) @@ -283,9 +262,7 @@ def setUp(self): self.auth_headers = {"HTTP_AUTHORIZATION": f"Bearer {self.token}"} def test_short_query(self): - response = self.client.get( - reverse("accounts:search") + "?q=t", **self.auth_headers - ) + response = self.client.get(reverse("accounts:search") + "?q=t", **self.auth_headers) self.assertFalse(response.json()) self.assertNotIn(UserSearchSerializer(self.user1).data, response.json()) self.assertNotIn(UserSearchSerializer(self.user2).data, response.json()) @@ -298,23 +275,17 @@ def test_full_name(self): self.assertIn(UserSearchSerializer(self.user2).data, response.json()) def test_exact_pennkey_user1(self): - response = self.client.get( - reverse("accounts:search") + "?q=test1", **self.auth_headers - ) + response = self.client.get(reverse("accounts:search") + "?q=test1", **self.auth_headers) self.assertIn(UserSearchSerializer(self.user1).data, response.json()) self.assertNotIn(UserSearchSerializer(self.user2).data, response.json()) def test_exact_pennkey_user2(self): - response = self.client.get( - reverse("accounts:search") + "?q=test2", **self.auth_headers - ) + response = self.client.get(reverse("accounts:search") + "?q=test2", **self.auth_headers) self.assertNotIn(UserSearchSerializer(self.user1).data, response.json()) self.assertIn(UserSearchSerializer(self.user2).data, response.json()) def test_first_name(self): - response = self.client.get( - reverse("accounts:search") + "?q=tes", **self.auth_headers - ) + response = self.client.get(reverse("accounts:search") + "?q=tes", **self.auth_headers) self.assertIn(UserSearchSerializer(self.user1).data, response.json()) self.assertIn(UserSearchSerializer(self.user2).data, response.json()) @@ -330,15 +301,9 @@ def setUp(self): email="test@test.com", ) - Major.objects.create( - name="Test Active Major", is_active=True, degree_type="BACHELORS" - ) - Major.objects.create( - name="Test Active Major 2", degree_type="PHD", is_active=True - ) - Major.objects.create( - name="Test Active Major 3", degree_type="PROFESSIONAL", is_active=True - ) + Major.objects.create(name="Test Active Major", is_active=True, degree_type="BACHELORS") + Major.objects.create(name="Test Active Major 2", degree_type="PHD", is_active=True) + Major.objects.create(name="Test Active Major 3", degree_type="PROFESSIONAL", is_active=True) School.objects.create(name="Test School") School.objects.create(name="Test School 2") @@ -369,9 +334,7 @@ def test_update_major(self): def test_update_school(self): self.client.force_authenticate(user=self.user) - update_data = { - "student": {"school": [{"name": "Test School"}, {"name": "Test School 2"}]} - } + update_data = {"student": {"school": [{"name": "Test School"}, {"name": "Test School 2"}]}} response = self.client.patch(reverse("accounts:me"), update_data, format="json") @@ -448,17 +411,13 @@ def setUp(self): def test_find_user(self): self.client.force_authenticate(user=self.user1) - resp = self.client.get( - reverse("accounts:user", kwargs={"username": "student2"}) - ) + resp = self.client.get(reverse("accounts:user", kwargs={"username": "student2"})) self.assertEqual(resp.status_code, 200, resp.content) self.assertEqual(2, resp.json()["pennid"]) def test_find_user_not_found(self): self.client.force_authenticate(user=self.user1) - resp = self.client.get( - reverse("accounts:user", kwargs={"username": "doesnt_exist"}) - ) + resp = self.client.get(reverse("accounts:user", kwargs={"username": "doesnt_exist"})) self.assertEqual(resp.status_code, 404, resp.content) @@ -529,9 +488,7 @@ def test_profile_pic_upload_too_large(self): reverse("accounts:me-pfp-upload"), { "profile_pic": open( - os.path.join( - os.getcwd(), "tests", "accounts", "test_pfp_large.png" - ), + os.path.join(os.getcwd(), "tests", "accounts", "test_pfp_large.png"), "rb", ) }, @@ -581,19 +538,11 @@ def test_profile_pic_upload_no_user(self): class MajorViewTestCase(TestCase): def setUp(self): - self.major_active_1 = Major.objects.create( - name="Test Active Major", is_active=True - ) - self.major_active_2 = Major.objects.create( - name="Test Active Major 2", is_active=True - ) + self.major_active_1 = Major.objects.create(name="Test Active Major", is_active=True) + self.major_active_2 = Major.objects.create(name="Test Active Major 2", is_active=True) - self.major_inactive_1 = Major.objects.create( - name="Test Inactive Major", is_active=False - ) - self.major_inactive_2 = Major.objects.create( - name="Test Inactive Major 2", is_active=False - ) + self.major_inactive_1 = Major.objects.create(name="Test Inactive Major", is_active=False) + self.major_inactive_2 = Major.objects.create(name="Test Inactive Major 2", is_active=False) self.client = APIClient() self.serializer_active_1 = MajorSerializer(self.major_active_1) @@ -699,24 +648,18 @@ def test_destroy_only_number(self): def test_resend_verification_fail(self): self.client.force_authenticate(user=self.user) response = self.client.post( - reverse( - "accounts:me-phonenumber-resend-verification", args=[self.number1.id] - ) + reverse("accounts:me-phonenumber-resend-verification", args=[self.number1.id]) ) self.assertEqual(400, response.status_code) def test_resend_verification_success(self): # Mark verification code as expired - self.number1.verification_timestamp = timezone.now() - datetime.timedelta( - days=1 - ) + self.number1.verification_timestamp = timezone.now() - datetime.timedelta(days=1) self.number1.save() self.client.force_authenticate(user=self.user) response = self.client.post( - reverse( - "accounts:me-phonenumber-resend-verification", args=[self.number1.id] - ) + reverse("accounts:me-phonenumber-resend-verification", args=[self.number1.id]) ) self.assertEqual(200, response.status_code) @@ -761,9 +704,7 @@ def test_get_queryset(self): def test_destroy_nonprimary(self): self.client.force_authenticate(user=self.user) - response = self.client.delete( - reverse("accounts:me-email-detail", args=[self.email2.id]) - ) + response = self.client.delete(reverse("accounts:me-email-detail", args=[self.email2.id])) self.email1.refresh_from_db() self.email3.refresh_from_db() self.assertTrue(self.email1.primary) @@ -774,9 +715,7 @@ def test_destroy_nonprimary(self): def test_destroy_primary(self): self.client.force_authenticate(user=self.user) - response = self.client.delete( - reverse("accounts:me-email-detail", args=[self.email1.id]) - ) + response = self.client.delete(reverse("accounts:me-email-detail", args=[self.email1.id])) self.email2.refresh_from_db() self.email3.refresh_from_db() self.assertFalse(self.email2.primary) @@ -787,9 +726,7 @@ def test_destroy_primary(self): def test_destroy_only_verified_email(self): self.client.force_authenticate(user=self.user2) - response = self.client.delete( - reverse("accounts:me-email-detail", args=[self.email4.id]) - ) + response = self.client.delete(reverse("accounts:me-email-detail", args=[self.email4.id])) self.email4.refresh_from_db() self.email5.refresh_from_db() self.assertTrue(self.email4.primary) @@ -936,18 +873,14 @@ def test_list_settings(self): # Assert the list is exactly all of user_1's settings with correct fields self.assertEqual( json.loads(response.content), - self.serializer( - PrivacySetting.objects.filter(user=self.user_1), many=True - ).data, + self.serializer(PrivacySetting.objects.filter(user=self.user_1), many=True).data, ) # Assert the list is exactly all of user_2's settings with correct fields self.client.force_authenticate(user=self.user_2) response = self.client.get(reverse("accounts:privacy")) self.assertEqual( json.loads(response.content), - self.serializer( - PrivacySetting.objects.filter(user=self.user_2), many=True - ).data, + self.serializer(PrivacySetting.objects.filter(user=self.user_2), many=True).data, ) def test_update_settings(self): @@ -961,9 +894,7 @@ def test_update_settings(self): format="json", ) test_setting_1 = PrivacySetting.objects.get(id=test_id_1) - self.assertEqual( - json.loads(response.content), self.serializer(test_setting_1).data - ) + self.assertEqual(json.loads(response.content), self.serializer(test_setting_1).data) self.assertFalse(test_setting_1.enabled) # Assert after updating, setting remains to true (settings default to true) @@ -976,7 +907,5 @@ def test_update_settings(self): format="json", ) test_setting_2 = PrivacySetting.objects.get(id=test_id_2) - self.assertEqual( - json.loads(response.content), self.serializer(test_setting_2).data - ) + self.assertEqual(json.loads(response.content), self.serializer(test_setting_2).data) self.assertTrue(test_setting_2.enabled) diff --git a/backend/tests/identity/test_views.py b/backend/tests/identity/test_views.py index 32c38f80..d040b23c 100644 --- a/backend/tests/identity/test_views.py +++ b/backend/tests/identity/test_views.py @@ -18,9 +18,7 @@ def setUp(self): self.client = Client() self.Application = get_application_model() self.UserModel = get_user_model() - self.test_user = self.UserModel.objects.create_user( - pennid=2, username="bar_user" - ) + self.test_user = self.UserModel.objects.create_user(pennid=2, username="bar_user") self.application = self.Application( name="Test Application", @@ -33,9 +31,7 @@ def setUp(self): def test_valid_attest(self): app = self.application - auth_encoded = base64.b64encode( - f"{app.client_id}:{app.client_secret}".encode("utf-8") - ) + auth_encoded = base64.b64encode(f"{app.client_id}:{app.client_secret}".encode("utf-8")) auth_headers = { "HTTP_AUTHORIZATION": f"Basic {auth_encoded.decode('utf-8')}", } @@ -141,9 +137,7 @@ def test_refresh_with_access(self): def test_refresh_no_use(self): now = time.time() - token = jwt.JWT( - header={"alg": SIGNING_ALG}, claims={"sub": self.urn, "iat": now} - ) + token = jwt.JWT(header={"alg": SIGNING_ALG}, claims={"sub": self.urn, "iat": now}) token.make_signed_token(self.key) auth_headers = { "HTTP_AUTHORIZATION": f"Bearer {token.serialize()}",