python3-Werkzeug-1.0.1-150300.3.8.1<>,ؤf:9 p9|LV]$eA(m=&^TM%L9LV[UJK.*".^fF WA)\.jM2GT/c0SПEPr(,}<1*+Fv&C?;z|Wi A+?/s|+_צRE䧯|;Lčwu+鬌uEV}CC4v`>D?d & UX\hl      x 0 14369:<|<<=G(=o8=x9=:?B"F7GLHI<XYZ[\ ]^bcndefluv wxyz?DLRCpython3-Werkzeug1.0.1150300.3.8.1The Swiss Army knife of Python web developmentWerkzeug started as simple collection of various utilities for WSGI applications and has become one of the most advanced WSGI utility modules. It includes a powerful debugger, full featured request and response objects, HTTP utilities to handle entity tags, cache control headers, HTTP dates, cookie handling, file uploads, a powerful URL routing system and a bunch of community contributed addon modules. Werkzeug is unicode aware and doesn't enforce a specific template engine, database adapter or anything else. It doesn't even enforce a specific way of handling requests and leaves all that up to the developer. It's most useful for end user applications which should work on as many server environments as possible (such as blogs, wikis, bulletin boards, etc.).f:9 h04-ch1d#MSUSE Linux Enterprise 15SUSE LLC BSD-3-Clausehttps://www.suse.com/Development/Languages/Pythonhttp://werkzeug.pocoo.org/linuxnoarchyj 3'3'%%kkMM@s@s44H^H^ s-s-$q$qYYxx8- G22]]!y!yH=H=p%AXQ2LObd5Wpc8#% Y Y--QQyy""2w% 4$qbh``qqrrTTZkZk11 - -  fl2 / ?6 A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤f:8f:8f:8f:8f:8f:8f:8^)f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8^V^V^V^Vf:8f:f:8f:8f:8f:8f:8f:8f:8f:8f:8^V^Vf:8]$N]$Nf:8]$N]$N]$N]$N]$N]$?^V^V^Vf:^V^Vf:8^Vf:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8^V^V^V^V^V^V^V^V^Vf:^V^V^V^V^Vf:8^Vf:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8f:8^V^Vf:^V^V^V^V^V^V^V^V^Vf:9^)^Vf:9]462b9e55f1719588fcf35879833c633761a3708957553fc407125bcb63b3a3cd1c0c78d7d450855cb51172f03d0241976ed172cd8cd78bb3b7cab7e55f93d7d201ba4719c80b6fe911b091a7c05124b64eeece964e09c058ef8f9805daca546bd9c6d8aeebd8865c4d7fcb357bbe36c80ed0e5c2934aaec4fd2548906b6a2116411ca3d958f0268424af08f01483a507c5e0debf6e9f436da951d017ed79c5acadbfb23e25ce8d32dbb433a5e5f429e6137ba0175aa1702843eb25000bdf640a230748ed6df0e9da9c399e395ff7d3b5434984c3dc489a1b09f8cf2b9ce267839720a41445e18cc2d67e16191e0ec2b9b3763b94134fbb448d751e6a6c5d550f9de44db529c27a689d033a1ff371a4ef1a4299fb6bdca54091627a03943b57ea8c3fc40d7292c1680b244d3fa5993fedcfb0b3ad887d734fe665de45b05b6709d5d14cfa94b54e65eb02e1a8ad4edfd5342f44ff0c06f31ee690aa64787925afdffb9ea6fcbd9c628b6f94ba7c9a1f045d8c9ad7b47d4b288b02e662780e84e28aeae88d0241c3f12afab111155c23d2cce84ecc62af8e2c7dda97c32e5b9ff8fd7a0de5bff0c0ceff5e1a7de948065ec6cbded5695d37c9e28a4096a3839914e14dd01a89161b956874f7c3ebd49a44eeea2bba9ad11b429cb616a24e665aedf8a88f91ddc6301f7a65ad1313eb6ef31bdfa8dc0a2a560c9f27ac96d1c39a96ef4623f234bbe75cc258e14e543f949f321d88e1dcd6763bebe48095888dba7de00ea0ac319685dde723dcade05fa4a62f5d9f7ef73c9c18a46d1acffb6c41c16ddab6b114b9495494bba9c56ca8ea9e8f7ff46e5107d6db75ef716a286a93ba6ddab6b114b9495494bba9c56ca8ea9e8f7ff46e5107d6db75ef716a286a93ba5fe191f4ce2d795d1ade9000f5533dbcb0a54c3b07533002d783d40c5f743be45191f7703865512a7dfec47b36bc9a8a6b18ac28675764b90e879c440cfc07332debc7229633f23eafa60a23d0e7c34014e19895c263f3c10519239b97337117177be25437fb71b9512979f4c58fd44b5f79d17c35428c0e90c33927d90739827f1079ef9e23e460367cd2cab186c92bf9c83e1a78c1512c6d2064ac10b285405e63ff39573e929137d80962940598af8fc892c1af43209fb9815faa81a0611ad0d0a924740e5a5e00bcd8f3afa48034f10ccb44f0e012a5aed9509aee0ee95c692315dd26981635707be7c9c0b63a576ec9c62c5d2aa02a1dc3a14e0c6966972577c6409789c685ea66fe93240fbe9f3095aa88a9218f5410c5691e828a0ff88070ad83eb26eb0c31be4e40e91c5626be5594c2fa6f9806f85ae632667cfd7d3d6b50c20a00e51f5efa01da608d968e2e6c9c51bbe473e92c4e78cfee132d0c4a816591c440d92dd16577e4a3b489c353ddcc85464ec0dcf4a3ec36ee8efdf7a98288c1ad485f591b8d9a5b330557bb1c6fa731b27c71946d3ce1ded426e0760a2e720616ff8c95471690a66fc7f5d91f1ed47b068bc61b986734d6319c65f4d60c09b25ff960611da55e478b6b2ada1e37865d39798a226a6e92a2a663ae8015e697b11824055c3e2075d07fa5a18602cc0ab13e7017c66056fbca6a11957f8126066813bf2dcf47fa52b19b30e3495ce2583f964f27e2c6adad18c71cb7807dd919c9665c4c458c7a0295b96631a1fe84af032ae8bec0e7d5c42e9c46a6252139102366804f6a84761f002c89eeb0d910e7dfd4078548166903a3861a79107fc866fbdf07b658f38b7fb3c1768427b33ce4608432361a640ea8a837218e5314617686d36805ba9e466c4bc6b8b3ef7816a3afb41a8feaaaeabcedb996b2f214617686d36805ba9e466c4bc6b8b3ef7816a3afb41a8feaaaeabcedb996b2f219b0923664b50f974397fcf9fd9dd85a8bc404bcec1b4d313bfdf8996f5fa2a2538592fd982abc05e6562bfa7a6f69dd4dd03e478eadc5a7e129a2902ffeead5add3b84fe0d5850551702a35217a64f0ab856e76c3103ccb2566cbe459615f6d299291c734f931d54f3330c7a85fef7e3243e228d98449dbca3d4c6b62665511ce3b9f4cdae143c06061219287eb15bba896debdcef56ce313d8fea89a1bc7e877fe00aa17b24ba7473158b075cd1dac5ae3b3aed9cd3e848f68167fe67e232b2379a0de8450d252f3974ea8128568a4dddb37b0ad20dbae51076a0dc9939c4b0289f139cc14d133cc1337ca175dfaf324942f11e0c44f8913e0c4006768dadb6469e4ff18f26378ba0509540fbdd52a17dd4efda443c71c29d7ac207963d9cf462578c987938adc7ce3324111d5e9ab5393a19878770aa73680b9f0f34bc352a71bdfc8abf15851923c18da511cf6df3b4d94fbc2b0139394cd7fa0720e80b44cc7883e40bd4be09d6887b12b37509fd42de41057195b9ddfb584748e122481a853b360bb89615bab6c1481565251b82346cfdf997a23f84751bf7966c21600e83452481d05cbe8866118fb2c26a4a209aa529a896024f5f8cd309f43bad3a2b47b3154d2a0d4426c1f6870b3a4291182d13839c7f12981f10ec57da4e200abf95a754796ac459262e0071353276d32b6aa016be97eb6c6dbb37eb0de235f51b7e36f5178037b326b96b15ff9d5a5368e396e313ce191993f7af21aa4e3388d3804da3bb28760caa96f32057b51de5bd327977c19800de3310a060cf9f95117948c2e85bcab33055edcffdc16a372ab31cbecff774cb2a877b970f5c972744c2f0015108d68627bd788d313f529c21ff4da2c2c42a5e1f3883acc83480f90026f16b1e915d796f3a28ff29eaaf48d5f4a2325ff3761b9d9ee6cbedc6c7dc360bf9a229269882c941ab8b3e2a71fd5efcfe8b00d8e014b8f5e7275d9de4579c80925e8ad7bd971391a8b1e98be8e87a6971919eb5b60c196485941c3c1df089afb8fa435169725238d54b6a1ad0294c4cc171a6f51e0e9d9f52c431a91e5211e1a780dec28a81d0a15e7cac7ea88e79188bc73fa840f60246b914ee545eb45e646819c0531380b2081f39181b8319316502752ac704c18887c3a96d791299d44819f6e8666f9ce3dd72ee4fd46f9cca7a8cc20d810f955410a9fb60196c6dd84d5e6871727a99b2e05c83be32d5ce9213ac6101bbf099618f788c4d27103d5cdda227c45445465449ba293887a1cb9dcb9d5256c78ee5b0737657697a85ced675136120e4980b07fafb7c55289d9447dfc2a055357b93edb460fbf36a8147bc01f32a5fa3d0777c265eba8fbefc51b3d301836763abd466060b9416747bbbb0dea91d82ede078008f0e8efc9c02f0255cdf9cfeeab1c6fca51afa4cf49e62ffa295455df214ad783c9788e7aa82944ab8ab115dbca510572e02fddc2e5b3f7f4fd393b801db7f293d6514ee169bc45919174d9f882311556e9deb66162f5461d7f5485668ebb2255b8935baa2b3347c58425b1a9144be0fa28afe3d1ede38f04eb7ff0aeb7d6ff58af412c8868094bae722938dae696f6abfc6bf215dff0fbc4eb7ff0aeb7d6ff58af412c8868094bae722938dae696f6abfc6bf215dff0fbc4118ce5cf98e4c62d5adaa87e5d34c1c38d5022faf040f9b3807bf63d2485c963118ce5cf98e4c62d5adaa87e5d34c1c38d5022faf040f9b3807bf63d2485c963b350c70d5454030459f694a5ef433414c0aedfe7b9b062e1de84d9f80ec24b3261afdb57c1cc710de6c57820d23d925920db2896b6e08633ee7b8898e5119b108c6bd6a9a3d3b909ef3614c803f439d484a726d3dddfaa54e3d69c0fb9d9d14aba74da0fa46c2267025b93093aa6b4a190b74831c8f0d0854134cb76042529ba96d2cf7ab3833217d9e7ebf0b1c39bd486b83d1b8ba25c26e9614b36a2c83cad0d761af89ca548242c95ca666669dbe3c922a972d01443fee79ff5cd900ad44a20d0a58d47432a3319304e2ceab919c4fbaed79184eff9e345ebfd7432e1ae1620d0a58d47432a3319304e2ceab919c4fbaed79184eff9e345ebfd7432e1ae162a9379d70d01d8da6e6f2aae12266e1289d1fa18196e497181f4c2107aaabca9c15c55a0a79fc6adabd91322f32e2b46d9baf1eb15b87eff30de7f8020f49ad1ffe2a83331ed7084874bba2e58a00eadaaa508ba6b761f3760e027ffc0e32e9f9518d374c9a0847899b99ad2eff509de065cfaf9458b38416c567e5d93cbc08022d4f0b962677e517cc4c4f5baa53f4f2d6bca1bb1f828de51fb24a9a529c6ccf01fecdb777a046ad4feae78809b26ea47026ce25b4d2aab5c2b22a0738dd17b2b9a19dc33d73b37598b45db6b9cd6ec294f3b1814baa5c7407bd8dbe016086cb0f4914caaad29254153237c7ebea33896ddabd71d38bbbaa60de0cf863fd57a8124a2bf548298ecb338cfe7ab565a642b713fffc2e4c783265ff8c972668b84ebe899ec229e5082d801e8682972db9a2e44e8b80b6f0bb3521f133699677f94f35d78f4ca6516aefe843e112b8b0aa7d9335d77a38d5f43e25581cda472790fca9edfb5dbb91c3885d49ce121ad8de2a6835d0747204c33906ee9397c9c8577189f64c5331227e9c1ee47c6b71b913abf491a65f10d17affb65354a479424616c77a4a8cb2a45f571c2015bbce31e9be0d86bfb1d07b478ef2517a6dd51513a4fcfa157fd6fc21bbac615fddc5c2c1ed78af96fa4204da8ae3e56a0c7fe585c4d2a06bf920ebcfdfbe5e2b980b2e9b0b40279481347ab0ed567ed9803ff62f386b54ae2eff08bccfdbe204ef5b80e2e59b569a22f0a99fea7677515e6500c4a4b8562a0a02617f6aff4473dcd0bc6ef55f510e9187cfc754d8724f63c838b26bfb352022f1122623def73559860e21ef5927a1ca5939ba3c0bad712401f88f10da0c7b3ab3d6b5cceb4d69cdb7f065c356836b342a89e6eaea21635c96ecb64439fdef60793dc1d24db1e264bc6f45ad1962c7d5f4e633a2ba47fbbf28de782177c0afadb61f5bd725a72220427a566bacf9abbf00cf8528492e7da1dd057f6d7ad1fff6fc06d0c9ecb9efce8a92e1f9497f6f7d0f8c3a03f06bca748b9bc5c8dc5ccf02ce4d5c569ce7504d99ab5d992e6d199da0fea0bb83a8c65ecc83d8f4c739543ef92fc2012574e5790f385e7ce9dc70f2aaf8a58095666513e5bd0d4399909f666c5708c6afeacd7e1281d79dbcb9374e7544db59cfcbb81aebafe9df3afa3d97981183b21006ccfc7c4efb7c2cd2d7d4e4ec58229d1f68743f6570d0c81113497eabec0876dbd90f2805a6d0ba9d6750df642926eec155aa5cef49d1a19ab88e25a361bdde0a40587bafe74085326d8230d636f80232f338370ff29bb11a1f17a203f0aa32416f1bdf96ea6f150f363fe3be89d7444b6eb80f462e36ade424a56814bf53679e53a48c9dbf72d5f63d8b43f41c457c9aa7f95729abdb1495cc7bbdb0b0bed1af8445a6d235edcc89b6b68b55d3609df1bc22a8117ff4262a09c5bd5d4a5867dddf961381fe3b2d7ce24c1236df89888c87bb992506f8e5b5165d451721162188087fbd1df4103388d3bff631329f7868a819e0824763a1c0003159f23c4cbfde3c89d6e43b3fcfe209c02e62180d4207cea2fa9509f81b6b09c75384a4d33a5bf8243d298c670383b9e34b686a9633de9ebfa07c189ae797095ab878d758ba0e91c9a2ee8d9250c7114e44060c6c7f24d2c03d7ab0e60996bc338043b22b19ce3989c77e0058408d4680bb97249b11e0ad47794cfc19c4e94ad887888214eb28c9397ca71cd94523013cc3849e39e85fe427fb4d12d44a3e3aefba2a4f8e7776eb65d720732aba6328f582709ddc9fbf2c565f9581c41ec0f8b454668e95df60b4595e922b9882c966b2d9556a677c6ceeb8d0ebbe023de67057091d0a6c6610f0f4c7bec59847f3f4f4ae33c9d1ffa1d8277dfd2d94c8be351cd20ef77e14d65f9e3083f0fd34dccabe99c6d57f2ed70dbab4ad68f3e69fa89a18706b5321db2695b495984efeaf5156801ae506a5693a9c6af74021c0b7c5cda62c48d284357d4778b894d50386ab80e3f808a86b55ea69b5963b0253c4967ca3e2017ada68589aadd871703da356343025337fc65c97b55a1c3cd5f62ad779cd45ac99c778722685eb60ddf0baeef692c63ff5c350dba473c717b5cc6da0a89787564c6bdbf9d089068374a77257f75bfddc02001ddeed9c1dcbe5cc5edc9f07206c3a3c70697f14ed9b5463b25791b40b3f8e685d9d2a9324cdb1ef2bf0383693b4b0baa06f5d2c4c97286727583b0c8d88f0893d5ed2560720141b1c6a83a463cdebce299ce3c4a24c243c449f9be3677d833bc9d38cc56fcd23aabfc4cc1bf76738a4eafd5df475d8243b907b20986454f383be6edc6e167776096febebd7672e8c6eec40c1bd57cf55b096bed3749649e9e18355b8713d04664693ce4dcd1c904f39188acfb197c57dc9d2607c2941752b6f8730f3111da6cce970e29e76b73c66706161cbd697cb58540b3f14a3927a0964b3eb53b9d3a516964af830af2408295b45fbfdad80b5708f662cd5e580260496e9e77430af5213b49dcee4105eb37bac10faf1be260408fe85d252b8e9df2e0979fc1e094437brootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootpython-Werkzeug-1.0.1-150300.3.8.1.src.rpmpython3-Werkzeugpython3-Werkzeug-doc@     python(abi)rpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PartialHardlinkSets)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)3.63.0.4-14.6.0-14.0.4-14.0-15.2-14.14.3f:dd_@^v^j$@]@]{]1]0_@\@Z4@Z%ZH@ZLZ*~YXX-WWڍ@V@V@Udaniel.garcia@suse.comdoreilly@suse.comdoreilly@suse.commmachova@suse.comarun@gmx.desteven.kowalik@suse.comtchvatal@suse.comtchvatal@suse.comadrian.glaubitz@suse.comtchvatal@suse.commimi.vx@gmail.comtoddrme2178@gmail.comaplanas@suse.comaplanas@suse.comarun@gmx.dearun@gmx.detbechtold@suse.comjmatejek@suse.comrjschwei@suse.comtoddrme2178@gmail.comtoddrme2178@gmail.comaplanas@suse.comaplanas@suse.comtbechtold@suse.com- Add CVE-2024-34069.patch, restrict debugger trusted hosts. (bsc#1223979, CVE-2024-34069, gh#pallets/werkzeug@3386395b24c7)- Add 0001-limit-the-maximum-number-of-multipart-form-parts.patch (bsc#1208283, CVE-2023-25577)- specfile: * stop pytest collecting test_serving.py to avoid python2 import cryptography error (bsc#1208283 comment 10)- Workaround pytest 6.2- specfile: * be more specific in %files section * add sortedcontainers for tests - update to version 1.0.1: * Make the argument to RequestRedirect.get_response optional. :issue:`1718` * Only allow a single access control allow origin value. :pr:`1723` * Fix crash when trying to parse a non-existent Content Security Policy header. :pr:`1731` * http_date zero fills years < 1000 to always output four digits. :issue:`1739` * Fix missing local variables in interactive debugger console. :issue:`1746` * Fix passing file-like objects like io.BytesIO to FileStorage.save. :issue:`1733`- Update to 1.0.0: * Drop support for Python 3.4. (#1478) * Remove code that issued deprecation warnings in version 0.15. (#1477) * Remove most top-level attributes provided by the werkzeug module in favor of direct imports. For example, instead of import werkzeug; werkzeug.url_quote, do from werkzeug.urls import url_quote. Install version 0.16 first to see deprecation warnings while upgrading. #2, #1640 * Added utils.invalidate_cached_property() to invalidate cached properties. (#1474) * Directive keys for the Set-Cookie response header are not ignored when parsing the Cookie request header. This allows cookies with names such as “expires” and “version”. (#1495) * Request cookies are parsed into a MultiDict to capture all values for cookies with the same key. cookies[key] returns the first value rather than the last. Use cookies.getlist(key) to get all values. parse_cookie also defaults to a MultiDict. #1562, #1458 * Add charset=utf-8 to an HTTP exception response’s CONTENT_TYPE header. (#1526) * The interactive debugger handles outer variables in nested scopes such as lambdas and comprehensions. #913, #1037, #1532 * The user agent for Opera 60 on Mac is correctly reported as “opera” instead of “chrome”. #1556 * The platform for Crosswalk on Android is correctly reported as “android” instead of “chromeos”. (#1572) * Issue a warning when the current server name does not match the configured server name. #760 * A configured server name with the default port for a scheme will match the current server name without the port if the current scheme matches. #1584 * InternalServerError has a original_exception attribute that frameworks can use to track the original cause of the error. #1590 * Headers are tested for equality independent of the header key case, such that X-Foo is the same as x-foo. #1605 * http.dump_cookie() accepts 'None' as a value for samesite. #1549 * set_cookie() accepts a samesite argument. #1705 * Support the Content Security Policy header through the Response.content_security_policy data structure. #1617 * LanguageAccept will fall back to matching “en” for “en-US” or “en-US” for “en” to better support clients or translations that only match at the primary language tag. #450, #1507 * MIMEAccept uses MIME parameters for specificity when matching. #458, #1574 * If the development server is started with an SSLContext configured to verify client certificates, the certificate in PEM format will be available as environ["SSL_CLIENT_CERT"]. #1469 * is_resource_modified will run for methods other than GET and HEAD, rather than always returning False. #409 * SharedDataMiddleware returns 404 rather than 500 when trying to access a directory instead of a file with the package loader. The dependency on setuptools and pkg_resources is removed. #1599 * Add a response.cache_control.immutable flag. Keep in mind that browser support for this Cache-Control header option is still experimental and may not be implemented. #1185 * Optional request log highlighting with the development server is handled by Click instead of termcolor. #1235 * Optional ad-hoc TLS support for the development server is handled by cryptography instead of pyOpenSSL. #1555 * FileStorage.save() supports pathlib and PEP 519 PathLike objects. #1653 * The debugger security pin is unique in containers managed by Podman. #1661 * Building a URL when host_matching is enabled takes into account the current host when there are duplicate endpoints with different hosts. #488 * The 429 TooManyRequests and 503 ServiceUnavailable HTTP exceptions takes a retry_after parameter to set the Retry-After header. #1657 * Map and Rule have a merge_slashes option to collapse multiple slashes into one, similar to how many HTTP servers behave. This is enabled by default. #1286, #1694 * Add HTTP 103, 208, 306, 425, 506, 508, and 511 to the list of status codes. #1678 * Add update, setlist, and setlistdefault methods to the Headers data structure. extend method can take MultiDict and kwargs. #1687, #1697 * The development server accepts paths that start with two slashes, rather than stripping off the first path segment. #491 * Add access control (Cross Origin Request Sharing, CORS) header properties to the Request and Response wrappers. #1699 * Accept values are no longer ordered alphabetically for equal quality tags. Instead the initial order is preserved. #1686 * Added Map.lock_class attribute for alternative implementations. #1702 * Support matching and building WebSocket rules in the routing system, for use by async frameworks. #1709 * Range requests that span an entire file respond with 206 instead of 200, to be more compliant with RFC 7233. This may help serving media to older browsers. #410, #1704 * The SharedDataMiddleware default fallback_mimetype is application/octet-stream. If a filename looks like a text mimetype, the utf-8 charset is added to it. This matches the behavior of BaseResponse and Flask’s send_file(). #1689 - Remove patch 0001_create_a_thread_to_reap_death_process.patch, not required - Add pytest-timeout to BuildRequires- Update to 0.16.0: * Deprecate most top-level attributes provided by the werkzeug module in favor of direct imports. The deprecated imports will be removed in version 1.0. - Rebase patch 0001_create_a_thread_to_reap_death_process.patch- Update to 0.15.6: * Work around a bug in pip that caused the reloader to fail on Windows when the script was an entry point. * ProxyFix trusts the X-Forwarded-Proto header by default. :issue:`1630`- Fix build on SLE-12 + Add python to BuildRequires for suse_version < 1500- Update to 0.15.5: * Fix a TypeError due to changes to ast.Module in Python 3.8. #1551 * Fix a C assertion failure in debug builds of some Python 2.7 releases. #1553- update to 0.15.4 (bsc#1145383, CVE-2019-14806) - refreshed 0001_create_a_thread_to_reap_death_process.patch - drop python-Werkzeug-doc package - last stable update with long Changelog -> please see CHANGELOG.rst- Make sure ssl is available - Avoid problem with bytecode being overwritten in tests- Allows Recommends and Suggest in Fedora- Recommends only for SUSE- specfile: * update copyright year - update to version 0.14.1: * Resolved a regression with status code handling in the integrated development server. - changes from version 0.14: * HTTP exceptions are now automatically caught by Request.application. * Added support for edge as browser. * Added support for platforms that lack SpooledTemporaryFile. * Add support for etag handling through if-match * Added support for the SameSite cookie attribute. * Added werkzeug.wsgi.ProxyMiddleware * Implemented has for NullCache * get_multi on cache clients now returns lists all the time. * Improved the watchdog observer shutdown for the reloader to not crash on exit on older Python versions. * Added support for filename* filename attributes according to RFC 2231 * Resolved an issue where machine ID for the reloader PIN was not read accurately on windows. * Added a workaround for syntax errors in init files in the reloader. * Added support for using the reloader with console scripts on windows. * The built-in HTTP server will no longer close a connection in cases where no HTTP body is expected (204, 204, HEAD requests etc.) * The EnvironHeaders object now skips over empty content type and lengths if they are set to falsy values. * Werkzeug will no longer send the content-length header on 1xx or 204/304 responses. * Cookie values are now also permitted to include slashes and equal signs without quoting. * Relaxed the regex for the routing converter arguments. * If cookies are sent without values they are now assumed to have an empty value and the parser accepts this. Previously this could have corrupted cookies that followed the value. * The test Client and EnvironBuilder now support mimetypes like the request object does. * Added support for static weights in URL rules. * Better handle some more complex reloader scenarios where sys.path contained non directory paths. * EnvironHeaders no longer raises weird errors if non string keys are passed to it.- specfile: * added CHANGES.rst and README.rst to %doc section - update to version 0.13: * Deprecate support for Python 2.6 and 3.3. CI tests will not run for these versions, and support will be dropped completely in the next version. (pallets/meta#24) * Raise TypeError when port is not an integer. (#1088) * Fully deprecate werkzeug.script. Use Click instead. (#1090) * response.age is parsed as a timedelta. Previously, it was incorrectly treated as a datetime. The header value is an integer number of seconds, not a date string. (#414) * Fix a bug in TypeConversionDict where errors are not propagated when using the converter. (#1102) * Authorization.qop is a string instead of a set, to comply with RFC 2617. (#984) * An exception is raised when an encoded cookie is larger than, by default, 4093 bytes. Browsers may silently ignore cookies larger than this. BaseResponse has a new attribute max_cookie_size and dump_cookie has a new argument max_size to configure this. (#780, [#1109]) * Fix a TypeError in werkzeug.contrib.lint.GuardedIterator.close. (#1116) * BaseResponse.calculate_content_length now correctly works for Unicode responses on Python 3. It first encodes using iter_encoded. (#705) * Secure cookie contrib works with string secret key on Python 3. (#1205) * Shared data middleware accepts a list instead of a dict of static locations to preserve lookup order. (#1197) * HTTP header values without encoding can contain single quotes. (#1208) * The built-in dev server supports receiving requests with chunked transfer encoding. (#1198)- update to 0.12.2: - Fix regression: Pull request ``#892`` prevented Werkzeug from correctly logging the IP of a remote client behind a reverse proxy, even when using `ProxyFix`. - Fix a bug in `safe_join` on Windows.- update for singlespec - update to 0.12.1 * deprecate werkzeug.script * Use `inspect.getfullargspec` internally when available as `inspect.getargspec` is gone in 3.6 * Added support for status code 451 and 423 * Improved the build error suggestions. In particular only if someone stringifies the error will the suggestions be calculated. * Added support for uWSGI's caching backend. * Fix a bug where iterating over a `FileStorage` would result in an infinite loop. * Datastructures now inherit from the relevant baseclasses from the `collections` module in the stdlib. See #794. * Add support for recognizing NetBSD, OpenBSD, FreeBSD, DragonFlyBSD platforms in the user agent string. * Recognize SeaMonkey browser name and version correctly * Recognize Baiduspider, and bingbot user agents * If `LocalProxy`'s wrapped object is a function, refer to it with __wrapped__ attribute. * The defaults of ``generate_password_hash`` have been changed to more secure ones, see pull request ``#753``. * Add support for encoding in options header parsing, see pull request ``#933``. * ``test.Client`` now properly handles Location headers with relative URLs, see pull request ``#879``. * When `HTTPException` is raised, it now prints the description, for easier debugging. * Werkzeug's dict-like datastructures now have ``view``-methods under Python 2, see pull request ``#968``. * Fix a bug in ``MultiPartParser`` when no ``stream_factory`` was provided during initialization, see pull request ``#973``. * Disable autocorrect and spellchecker in the debugger middleware's Python prompt, see pull request ``#994``. * Don't redirect to slash route when method doesn't match, see pull request ``#907``. * Fix a bug when using ``SharedDataMiddleware`` with frozen packages, see pull request ``#959``. * `Range` header parsing function fixed for invalid values ``#974``. * Add support for byte Range Requests, see pull request ``#978``. * Use modern cryptographic defaults in the dev servers ``#1004``. * the post() method of the test client now accept file object through the data parameter. * Color run_simple's terminal output based on HTTP codes ``#1013``. * Fix self-XSS in debugger console, see ``#1031``. * Fix IPython 5.x shell support, see ``#1033``.- Include in SLE 12 (FATE#320818, bsc#979331)- Fix download url.- update to version 0.11.11: * Fix JSONRequestMixin for Python3. See #731 * Fix broken string handling in test client when passing integers. See #852 * Fix a bug in "parse_options_header" where an invalid content type starting with comma or semi-colon would result in an invalid return value, see issue "#995". * Fix a bug in multidicts when passing empty lists as values, see issue "#979". * Fix a security issue that allows XSS on the Werkzeug debugger. See "#1001". - update to version 0.11.10: * Fixed a bug that occurs when running on Python 2.6 and using a broken locale. See pull request #912. * Fixed a crash when running the debugger on Google App Engine. See issue #925. * Fixed an issue with multipart parsing that could cause memory exhaustion. - Update to 0.11.9 - Corrected an issue that caused the debugger not to use the machine GUID on POSIX systems. - Corrected an Unicode error on Python 3 for the debugger's PIN usage. - Corrected the timestamp verification in the pin debug code. Without this fix the pin was remebered until too long. - update to version 0.11.8: * fixed a problem with the machine GUID detection code on OS X on Python 3. - changes from version 0.11.7: * fixed a regression on Python 3 for the debugger. - changes from version 0.11.6: * werkzeug.serving: Still show the client address on bad requests. * improved the PIN based protection for the debugger to make it harder to brute force via trying cookies. Please keep in mind that the debugger *is not intended for running on production environments* * increased the pin timeout to a week to make it less annoying for people which should decrease the change that users disable the pin check entirely. * werkzeug.serving: Fix broken HTTP_HOST when path starts with double slash. - update to version 0.11.5: * werkzeug.serving: Fix crash when attempting SSL connection to HTTP server. - update to version 0.11.4: * Fixed werkzeug.serving not working from -m flag. * Fixed incorrect weak etag handling. - Rebase 0001_create_a_thread_to_reap_death_process.patch - Split documentation into own subpackage to speed up build.- Add 0001_create_a_thread_to_reap_death_process.patch Fixes bsc#954591- update to 0.11.3: - Added reloader_paths option to run_simple and other functions in werkzeug.serving. This allows the user to completely override the Python module watching of Werkzeug with custom paths. - Many custom cached properties of Werkzeug’s classes are now subclasses of Python’s property type (issue #616). - bind_to_environ now doesn’t differentiate between implicit and explicit default port numbers in HTTP_HOST (pull request #204). - BuildErrors are now more informative. They come with a complete sentence as error message, and also provide suggestions (pull request #691). - Fix a bug in the user agent parser where Safari’s build number instead of version would be extracted (pull request #703). - Fixed issue where RedisCache set_many was broken for twemproxy, which doesn’t support the default MULTI command (pull request [#702]). - mimetype parameters on request and response classes are now always converted to lowercase. - Changed cache so that cache never expires if timeout is 0. This also fixes an issue with redis setex (issue #550) - Werkzeug now assumes UTF-8 as filesystem encoding on Unix if Python detected it as ASCII. - New optional has method on caches. - Fixed various bugs in parse_options_header (pull request #643). - If the reloader is enabled the server will now open the socket in the parent process if this is possible. This means that when the reloader kicks in the connection from client will wait instead of tearing down. This does not work on all Python versions. - Implemented PIN based authentication for the debugger. This can optionally be disabled but is discouraged. This change was necessary as it has been discovered that too many people run the debugger in production. - Devserver no longer requires SSL module to be installed. - Reloader: Correctly detect file changes made by moving temporary files over the original, which is e.g. the case with PyCharm (pull request #722). - Fix bool behavior of werkzeug.datastructures.ETags under Python 3 (issue #744).- update to 0.10.4: - Re-release of 0.10.3 with packaging artifacts manually removed. - Re-release of 0.10.2 without packaging artifacts. - Fixed issue where ``empty`` could break third-party libraries that relied on keyword arguments (pull request ``#675``) - Improved ``Rule.empty`` by providing a ```get_empty_kwargs`` to allow setting custom kwargs without having to override entire ``empty`` method. (pull request ``#675``) - Fixed ```extra_files``` parameter for reloader to not cause startup to crash when included in server params - Using `MultiDict` when building URLs is now not supported again. The behavior introduced several regressions. - Fix performance problems with stat-reloader (pull request ``#715``). - Fixed regression with multiple query values for URLs (pull request ``#667``). - Fix issues with eventlet's monkeypatching and the builtin server (pull request ``#663``). - Changed the error handling of and improved testsuite for the caches in ``contrib.cache``. - Fixed a bug on Python 3 when creating adhoc ssl contexts, due to `sys.maxint` not being defined. - Fixed a bug on Python 3, that caused :func:`~werkzeug.serving.make_ssl_devcert` to fail with an exception. - Added exceptions for 504 and 505. - Added support for ChromeOS detection. - Added UUID converter to the routing system. - Added message that explains how to quit the server. - Fixed a bug on Python 2, that caused ``len`` for :class:`werkzeug.datastructures.CombinedMultiDict` to crash. - Added support for stdlib pbkdf2 hmac if a compatible digest is found. - Ported testsuite to use ``py.test``. - Minor optimizations to various middlewares (pull requests ``#496`` and ``#571``). - Use stdlib ``ssl`` module instead of ``OpenSSL`` for the builtin server (issue ``#434``). This means that OpenSSL contexts are not supported anymore, but instead ``ssl.SSLContext`` from the stdlib. - Allow protocol-relative URLs when building external URLs. - Fixed Atom syndication to print time zone offset for tz-aware datetime objects (pull request ``#254``). - Improved reloader to track added files and to recover from broken sys.modules setups with syntax errors in packages. - ``cache.RedisCache`` now supports arbitrary ``**kwargs`` for the redis object. - ``werkzeug.test.Client`` now uses the original request method when resolving 307 redirects (pull request ``#556``). - ``werkzeug.datastructures.MIMEAccept`` now properly deals with mimetype parameters (pull request ``#205``). - ``werkzeug.datastructures.Accept`` now handles a quality of ``0`` as intolerable, as per RFC 2616 (pull request ``#536``). - ``werkzeug.urls.url_fix`` now properly encodes hostnames with ``idna`` encoding (issue ``#559``). It also doesn't crash on malformed URLs anymore (issue ``#582``). - ``werkzeug.routing.MapAdapter.match`` now recognizes the difference between the path ``/`` and an empty one (issue ``#360``). - The interactive debugger now tries to decode non-ascii filenames (issue ``#469``). - Increased default key size of generated SSL certificates to 1024 bits (issue ``#611``). - Added support for specifying a ``Response`` subclass to use when calling :func:`~werkzeug.utils.redirect`\ . - ``werkzeug.test.EnvironBuilder`` now doesn't use the request method anymore to guess the content type, and purely relies on the ``form``, ``files`` and ``input_stream`` properties (issue ``#620``). - Added Symbian to the user agent platform list. - Fixed make_conditional to respect automatically_set_content_length - Unset ``Content-Length`` when writing to response.stream (issue ``#451``) - ``wrappers.Request.method`` is now always uppercase, eliminating inconsistencies of the WSGI environment (issue ``647``). - ``routing.Rule.empty`` now works correctly with subclasses of ``Rule`` (pull request ``#645``). - Made map updating safe in light of concurrent updates. - Allow multiple values for the same field for url building (issue ``#658``). - Fix unicode problems in ``werkzeug.debug.tbtools``. - Fix Python 3-compatibility problems in ``werkzeug.posixemulation``. - Backport fix of fatal typo for ``ImmutableList`` (issue ``#492``). - Make creation of the cache dir for ``FileSystemCache`` atomic (issue ``#468``). - Use native strings for memcached keys to work with Python 3 client (issue ``#539``). - Fix charset detection for ``werkzeug.debug.tbtools.Frame`` objects (issues ``#547`` and ``#532``). - Fix ``AttributeError`` masking in ``werkzeug.utils.import_string`` (issue ``#182``). - Explicitly shut down server (issue ``#519``). - Fix timeouts greater than 2592000 being misinterpreted as UNIX timestamps in ``werkzeug.contrib.cache.MemcachedCache`` (issue ``#533``). - Fix bug where ``werkzeug.exceptions.abort`` would raise an arbitrary subclass of the expected class (issue ``#422``). - Fix broken ``jsrouting`` (due to removal of ``werkzeug.templates``) - ``werkzeug.urls.url_fix`` now doesn't crash on malformed URLs anymore, but returns them unmodified. This is a cheap workaround for ``#582``, the proper fix is included in version 0.10. - The repr of ``werkzeug.wrappers.Request`` doesn't crash on non-ASCII-values anymore (pull request ``#466``). - Fix bug in ``cache.RedisCache`` when combined with ``redis.StrictRedis`` object (pull request ``#583``). - The ``qop`` parameter for ``WWW-Authenticate`` headers is now always quoted, as required by RFC 2617 (issue ``#633``). - Fix bug in ``werkzeug.contrib.cache.SimpleCache`` with Python 3 where add/set may throw an exception when pruning old entries from the cache (pull request ``#651``).python3-Werkzeug-doch04-ch1d 1715091721  !"#$%&'()*+,,./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVVXXZ[\]^_``bcdefghijklmnopqrstuvwxyz{|}~1.0.1-150300.3.8.11.0.11.0.1  Werkzeug-1.0.1-py3.6.egg-infoPKG-INFOSOURCES.txtdependency_links.txtrequires.txttop_level.txtwerkzeug__init__.py__pycache____init__.cpython-36.opt-1.pyc__init__.cpython-36.pyc_compat.cpython-36.opt-1.pyc_compat.cpython-36.pyc_internal.cpython-36.opt-1.pyc_internal.cpython-36.pyc_reloader.cpython-36.opt-1.pyc_reloader.cpython-36.pycdatastructures.cpython-36.opt-1.pycdatastructures.cpython-36.pycexceptions.cpython-36.opt-1.pycexceptions.cpython-36.pycfilesystem.cpython-36.opt-1.pycfilesystem.cpython-36.pycformparser.cpython-36.opt-1.pycformparser.cpython-36.pychttp.cpython-36.opt-1.pychttp.cpython-36.pyclocal.cpython-36.opt-1.pyclocal.cpython-36.pycposixemulation.cpython-36.opt-1.pycposixemulation.cpython-36.pycrouting.cpython-36.opt-1.pycrouting.cpython-36.pycsecurity.cpython-36.opt-1.pycsecurity.cpython-36.pycserving.cpython-36.opt-1.pycserving.cpython-36.pyctest.cpython-36.opt-1.pyctest.cpython-36.pyctestapp.cpython-36.opt-1.pyctestapp.cpython-36.pycurls.cpython-36.opt-1.pycurls.cpython-36.pycuseragents.cpython-36.opt-1.pycuseragents.cpython-36.pycutils.cpython-36.opt-1.pycutils.cpython-36.pycwsgi.cpython-36.opt-1.pycwsgi.cpython-36.pyc_compat.py_internal.py_reloader.pydatastructures.pydebug__init__.py__pycache____init__.cpython-36.opt-1.pyc__init__.cpython-36.pycconsole.cpython-36.opt-1.pycconsole.cpython-36.pycrepr.cpython-36.opt-1.pycrepr.cpython-36.pyctbtools.cpython-36.opt-1.pyctbtools.cpython-36.pycconsole.pyrepr.pysharedFONT_LICENSEconsole.pngdebugger.jsjquery.jsless.pngmore.pngsource.pngstyle.cssubuntu.ttftbtools.pyexceptions.pyfilesystem.pyformparser.pyhttp.pylocal.pymiddleware__init__.py__pycache____init__.cpython-36.opt-1.pyc__init__.cpython-36.pycdispatcher.cpython-36.opt-1.pycdispatcher.cpython-36.pychttp_proxy.cpython-36.opt-1.pychttp_proxy.cpython-36.pyclint.cpython-36.opt-1.pyclint.cpython-36.pycprofiler.cpython-36.opt-1.pycprofiler.cpython-36.pycproxy_fix.cpython-36.opt-1.pycproxy_fix.cpython-36.pycshared_data.cpython-36.opt-1.pycshared_data.cpython-36.pycdispatcher.pyhttp_proxy.pylint.pyprofiler.pyproxy_fix.pyshared_data.pyposixemulation.pyrouting.pysecurity.pyserving.pytest.pytestapp.pyurls.pyuseragents.pyutils.pywrappers__init__.py__pycache____init__.cpython-36.opt-1.pyc__init__.cpython-36.pycaccept.cpython-36.opt-1.pycaccept.cpython-36.pycauth.cpython-36.opt-1.pycauth.cpython-36.pycbase_request.cpython-36.opt-1.pycbase_request.cpython-36.pycbase_response.cpython-36.opt-1.pycbase_response.cpython-36.pyccommon_descriptors.cpython-36.opt-1.pyccommon_descriptors.cpython-36.pyccors.cpython-36.opt-1.pyccors.cpython-36.pycetag.cpython-36.opt-1.pycetag.cpython-36.pycjson.cpython-36.opt-1.pycjson.cpython-36.pycrequest.cpython-36.opt-1.pycrequest.cpython-36.pycresponse.cpython-36.opt-1.pycresponse.cpython-36.pycuser_agent.cpython-36.opt-1.pycuser_agent.cpython-36.pycaccept.pyauth.pybase_request.pybase_response.pycommon_descriptors.pycors.pyetag.pyjson.pyrequest.pyresponse.pyuser_agent.pywsgi.pypython3-WerkzeugCHANGES.rstREADME.rstpython3-WerkzeugLICENSE.rst/usr/lib/python3.6/site-packages//usr/lib/python3.6/site-packages/Werkzeug-1.0.1-py3.6.egg-info//usr/lib/python3.6/site-packages/werkzeug//usr/lib/python3.6/site-packages/werkzeug/__pycache__//usr/lib/python3.6/site-packages/werkzeug/debug//usr/lib/python3.6/site-packages/werkzeug/debug/__pycache__//usr/lib/python3.6/site-packages/werkzeug/debug/shared//usr/lib/python3.6/site-packages/werkzeug/middleware//usr/lib/python3.6/site-packages/werkzeug/middleware/__pycache__//usr/lib/python3.6/site-packages/werkzeug/wrappers//usr/lib/python3.6/site-packages/werkzeug/wrappers/__pycache__//usr/share/doc/packages//usr/share/doc/packages/python3-Werkzeug//usr/share/licenses//usr/share/licenses/python3-Werkzeug/-fmessage-length=0 -grecord-gcc-switches -O2 -Wall -D_FORTIFY_SOURCE=2 -fstack-protector-strong -funwind-tables -fasynchronous-unwind-tables -fstack-clash-protection -gobs://build.suse.de/SUSE:Maintenance:33728/SUSE_SLE-15-SP3_Update/25cc7687f4c246d2141070e85150ca70-python-Werkzeug.SUSE_SLE-15-SP3_Updatedrpmxz5noarch-suse-linux   directoryPython script, ASCII text executableASCII textpython 3.6 byte-compiledPNG image data, 16 x 16, 8-bit/color RGBA, non-interlacedAlgol 68 source, ASCII textASCII text, with very long linesPNG image data, 11 x 11, 8-bit/color RGBA, non-interlacedUTF-8 Unicode textTrueType Font data, 16 tables, 1st "FFTM", 47 names, MacintoshPython script, UTF-8 Unicode text executable  !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~RRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRRQ%ե%X4z<python3-termcolorpython3-watchdogutf-80265f3076fdb476a3b181440cfa674bea65616714c289a4b45a5aec7e913f310?7zXZ !t/-T]"k%4Pa w6%5I&^o]jld|`)$-> a5{&j#JuMd =^"0gK#IMDJ D7 ƗpC.K.!y$cX7FB=u4G VBOUip|jP2VC<ɭi7q֭슼ruoWø Y2syU=-U-jgڻa]GEi:DO5R8^>kѬfmH2ADlSeF2?ꛔ"f¨NUJcmrnقkk}\{eE ±Ϻ^HKթ2wu<_m֋nCǙY6< . λ MW܌ O.7Ez`sO@l2sUx-텕S@h5ID*,Oi Wih$E;C BGwF+p|^8ӳKhX\pip䏫MR>RIaZmuIʚyLnR]{W0&zE5^ի" c+>B咯R|~UR[>zg)wXnk' U;,N 0*o q*gIbH!."fv%3&}\)?w _%Gep(.|K梪jZOvZk"^8sgkm5 `VI+p);R)g[A8/#M_{ t[`uj9]aT(=*4X%gE݌i&=A-GgY_ʖb9} ۜo9BA!gFnN s*f20.^:0:oBCf r.$s ݻ nk!xҔ:)mWw&Yzk/m7$+ʶ@~r2bR&S 3V !'җR80lL2Y7I* "SH6rMY} g3_X禶_,@(ާ1ٱFͦw6;̩S S&T%aFӸ>1˵ѵGKFc[4o~&BorCFx!HOn}I%m/I:]<JETc{23>שzðq% oA|A<EHҞI'&s IDNk `uO9tAP ҨFݥ=kbyAM펣]-Exʬ9y0EaJW'lw " = 8ATߜ9I(կBgJ\yo&L[P\x!`!o'mٻcFBH}'TuMg#2Z4{"q"K,[p =f6(ݢ٧Lسy0EŦK*r8Zp ba}㎘CK8@fύO2mT<l$&mʁ3dJQx2mg&>ֆx#VםKO;ٷBݧ4) aV~3OIfQa,+2QgJ-(liD czdrl8aԉR&Z-vϣV8jNtE_OXv9@8٢wo= bfstm6=R=d,7Hq(fO@"*0kWJ[,8_zO{盎_E@S.s]IJi5򵹳q(>~(*SU+BG{*g.l,| 8C+>/ tl[A֫;0UoPD*kfK#i(vPQg9!J++1R !GbwAo1rrcN̢)Eau*xV΍lvtfWLٜIGs>ߌVn]j\ݰMj8q5. |ϸ|&"^OEaqd-D7lHUE{~֯vhG9ұ8jFK+q}r!"Hdyʸ0Ab>fW ~LRZl Ϩ뵁yR|hZ3Ϲ_H:)-մ(ЇԈL Bs\fXQ'VNzϠ$(39>嫹/sY5{hvzd ٍ)/voKF>VU-潲k+O0B#7 q淵x$뻼qC6jd_{8[W@B/JUۦCl3^jT\k4T` q nt)V+Њ4ifT\@.K ϷC^@ڕj.WEBKn)G mܼ'PH͎ `mLDjGzL%g[IÍm"EQ,)yѣ^ }H=*'o'iD'(UQKtq=#~wS^YA?/YoB 3J@bǩ$pK5{ӝ+i }woWG",~Hv8Niu>Ad͙ul%#i=dQ[߷C{_뎰3@'1<\ ˔%w剗  M5i-%F2a 5\3آ;]8TiV&f@֬ !.nJ72n㰁_O;9:NXm SxAP BjT(I]NXnV{<3+He>v*=sU*ڃ7w$u#veh(5"#-hK H}?rNǴ%4Hp w//6r!F~uQ$`{?401 d~D4r3>O /n*@IMVS3ӛ]!(A [VB}Y;Y^ihM6mN\=SҾ^bb8b}kӼKzniFEhR._ ϤŔ,A+r0 NF:mꐋH[Ou[Bhl͟Կ(*b&󌭢>LOuEqtU"L)r.wWa;iԩW! _PT%[Pv YZ