diff --git a/Pipfile.lock b/Pipfile.lock index a9392467..8af15a70 100644 --- a/Pipfile.lock +++ b/Pipfile.lock @@ -135,11 +135,11 @@ }, "async-timeout": { "hashes": [ - "sha256:2163e1640ddb52b7a8c80d0a67a08587e5d245cc9c553a74a847056bc2976b15", - "sha256:8ca1e4fcf50d07413d66d1a5e416e42cfdf5851c981d679a09851a6853383b3c" + "sha256:4640d96be84d82d02ed59ea2b7105a0f7b33abe8703703cd0ab0bf87c427522f", + "sha256:7405140ff1230c310e51dc27b3145b9092d659ce68ff733fb0cefe3ee42be028" ], - "markers": "python_version >= '3.6'", - "version": "==4.0.2" + "markers": "python_version >= '3.7'", + "version": "==4.0.3" }, "attrs": { "hashes": [ @@ -159,11 +159,11 @@ }, "certifi": { "hashes": [ - "sha256:0f0d56dc5a6ad56fd4ba36484d6cc34451e1c6548c61daad8c320169f91eddc7", - "sha256:c6c2e98f5c7869efca1f8916fed228dd91539f9f1b444c314c06eef02980c716" + "sha256:539cc1d13202e33ca466e88b2807e29f4c13049d6d87031a3c110744495cb082", + "sha256:92d6037539857d8206b8f6ae472e8b77db8058fec5937a1ef3f54304089edbb9" ], "markers": "python_version >= '3.6'", - "version": "==2023.5.7" + "version": "==2023.7.22" }, "cffi": { "hashes": [ @@ -244,108 +244,99 @@ }, "cryptography": { "hashes": [ - "sha256:0ddaee209d1cf1f180f1efa338a68c4621154de0afaef92b89486f5f96047c55", - "sha256:14754bcdae909d66ff24b7b5f166d69340ccc6cb15731670435efd5719294895", - "sha256:344c6de9f8bda3c425b3a41b319522ba3208551b70c2ae00099c205f0d9fd3be", - "sha256:34d405ea69a8b34566ba3dfb0521379b210ea5d560fafedf9f800a9a94a41928", - "sha256:3680248309d340fda9611498a5319b0193a8dbdb73586a1acf8109d06f25b92d", - "sha256:3c5ef25d060c80d6d9f7f9892e1d41bb1c79b78ce74805b8cb4aa373cb7d5ec8", - "sha256:4ab14d567f7bbe7f1cdff1c53d5324ed4d3fc8bd17c481b395db224fb405c237", - "sha256:5c1f7293c31ebc72163a9a0df246f890d65f66b4a40d9ec80081969ba8c78cc9", - "sha256:6b71f64beeea341c9b4f963b48ee3b62d62d57ba93eb120e1196b31dc1025e78", - "sha256:7d92f0248d38faa411d17f4107fc0bce0c42cae0b0ba5415505df72d751bf62d", - "sha256:8362565b3835ceacf4dc8f3b56471a2289cf51ac80946f9087e66dc283a810e0", - "sha256:84a165379cb9d411d58ed739e4af3396e544eac190805a54ba2e0322feb55c46", - "sha256:88ff107f211ea696455ea8d911389f6d2b276aabf3231bf72c8853d22db755c5", - "sha256:9f65e842cb02550fac96536edb1d17f24c0a338fd84eaf582be25926e993dde4", - "sha256:a4fc68d1c5b951cfb72dfd54702afdbbf0fb7acdc9b7dc4301bbf2225a27714d", - "sha256:b7f2f5c525a642cecad24ee8670443ba27ac1fab81bba4cc24c7b6b41f2d0c75", - "sha256:b846d59a8d5a9ba87e2c3d757ca019fa576793e8758174d3868aecb88d6fc8eb", - "sha256:bf8fc66012ca857d62f6a347007e166ed59c0bc150cefa49f28376ebe7d992a2", - "sha256:f5d0bf9b252f30a31664b6f64432b4730bb7038339bd18b1fafe129cfc2be9be" + "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" ], "index": "pypi", - "version": "==41.0.0" + "version": "==41.0.4" }, "frozenlist": { "hashes": [ - "sha256:008a054b75d77c995ea26629ab3a0c0d7281341f2fa7e1e85fa6153ae29ae99c", - "sha256:02c9ac843e3390826a265e331105efeab489ffaf4dd86384595ee8ce6d35ae7f", - "sha256:034a5c08d36649591be1cbb10e09da9f531034acfe29275fc5454a3b101ce41a", - "sha256:05cdb16d09a0832eedf770cb7bd1fe57d8cf4eaf5aced29c4e41e3f20b30a784", - "sha256:0693c609e9742c66ba4870bcee1ad5ff35462d5ffec18710b4ac89337ff16e27", - "sha256:0771aed7f596c7d73444c847a1c16288937ef988dc04fb9f7be4b2aa91db609d", - "sha256:0af2e7c87d35b38732e810befb9d797a99279cbb85374d42ea61c1e9d23094b3", - "sha256:14143ae966a6229350021384870458e4777d1eae4c28d1a7aa47f24d030e6678", - "sha256:180c00c66bde6146a860cbb81b54ee0df350d2daf13ca85b275123bbf85de18a", - "sha256:1841e200fdafc3d51f974d9d377c079a0694a8f06de2e67b48150328d66d5483", - "sha256:23d16d9f477bb55b6154654e0e74557040575d9d19fe78a161bd33d7d76808e8", - "sha256:2b07ae0c1edaa0a36339ec6cce700f51b14a3fc6545fdd32930d2c83917332cf", - "sha256:2c926450857408e42f0bbc295e84395722ce74bae69a3b2aa2a65fe22cb14b99", - "sha256:2e24900aa13212e75e5b366cb9065e78bbf3893d4baab6052d1aca10d46d944c", - "sha256:303e04d422e9b911a09ad499b0368dc551e8c3cd15293c99160c7f1f07b59a48", - "sha256:352bd4c8c72d508778cf05ab491f6ef36149f4d0cb3c56b1b4302852255d05d5", - "sha256:3843f84a6c465a36559161e6c59dce2f2ac10943040c2fd021cfb70d58c4ad56", - "sha256:394c9c242113bfb4b9aa36e2b80a05ffa163a30691c7b5a29eba82e937895d5e", - "sha256:3bbdf44855ed8f0fbcd102ef05ec3012d6a4fd7c7562403f76ce6a52aeffb2b1", - "sha256:40de71985e9042ca00b7953c4f41eabc3dc514a2d1ff534027f091bc74416401", - "sha256:41fe21dc74ad3a779c3d73a2786bdf622ea81234bdd4faf90b8b03cad0c2c0b4", - "sha256:47df36a9fe24054b950bbc2db630d508cca3aa27ed0566c0baf661225e52c18e", - "sha256:4ea42116ceb6bb16dbb7d526e242cb6747b08b7710d9782aa3d6732bd8d27649", - "sha256:58bcc55721e8a90b88332d6cd441261ebb22342e238296bb330968952fbb3a6a", - "sha256:5c11e43016b9024240212d2a65043b70ed8dfd3b52678a1271972702d990ac6d", - "sha256:5cf820485f1b4c91e0417ea0afd41ce5cf5965011b3c22c400f6d144296ccbc0", - "sha256:5d8860749e813a6f65bad8285a0520607c9500caa23fea6ee407e63debcdbef6", - "sha256:6327eb8e419f7d9c38f333cde41b9ae348bec26d840927332f17e887a8dcb70d", - "sha256:65a5e4d3aa679610ac6e3569e865425b23b372277f89b5ef06cf2cdaf1ebf22b", - "sha256:66080ec69883597e4d026f2f71a231a1ee9887835902dbe6b6467d5a89216cf6", - "sha256:783263a4eaad7c49983fe4b2e7b53fa9770c136c270d2d4bbb6d2192bf4d9caf", - "sha256:7f44e24fa70f6fbc74aeec3e971f60a14dde85da364aa87f15d1be94ae75aeef", - "sha256:7fdfc24dcfce5b48109867c13b4cb15e4660e7bd7661741a391f821f23dfdca7", - "sha256:810860bb4bdce7557bc0febb84bbd88198b9dbc2022d8eebe5b3590b2ad6c842", - "sha256:841ea19b43d438a80b4de62ac6ab21cfe6827bb8a9dc62b896acc88eaf9cecba", - "sha256:84610c1502b2461255b4c9b7d5e9c48052601a8957cd0aea6ec7a7a1e1fb9420", - "sha256:899c5e1928eec13fd6f6d8dc51be23f0d09c5281e40d9cf4273d188d9feeaf9b", - "sha256:8bae29d60768bfa8fb92244b74502b18fae55a80eac13c88eb0b496d4268fd2d", - "sha256:8df3de3a9ab8325f94f646609a66cbeeede263910c5c0de0101079ad541af332", - "sha256:8fa3c6e3305aa1146b59a09b32b2e04074945ffcfb2f0931836d103a2c38f936", - "sha256:924620eef691990dfb56dc4709f280f40baee568c794b5c1885800c3ecc69816", - "sha256:9309869032abb23d196cb4e4db574232abe8b8be1339026f489eeb34a4acfd91", - "sha256:9545a33965d0d377b0bc823dcabf26980e77f1b6a7caa368a365a9497fb09420", - "sha256:9ac5995f2b408017b0be26d4a1d7c61bce106ff3d9e3324374d66b5964325448", - "sha256:9bbbcedd75acdfecf2159663b87f1bb5cfc80e7cd99f7ddd9d66eb98b14a8411", - "sha256:a4ae8135b11652b08a8baf07631d3ebfe65a4c87909dbef5fa0cdde440444ee4", - "sha256:a6394d7dadd3cfe3f4b3b186e54d5d8504d44f2d58dcc89d693698e8b7132b32", - "sha256:a97b4fe50b5890d36300820abd305694cb865ddb7885049587a5678215782a6b", - "sha256:ae4dc05c465a08a866b7a1baf360747078b362e6a6dbeb0c57f234db0ef88ae0", - "sha256:b1c63e8d377d039ac769cd0926558bb7068a1f7abb0f003e3717ee003ad85530", - "sha256:b1e2c1185858d7e10ff045c496bbf90ae752c28b365fef2c09cf0fa309291669", - "sha256:b4395e2f8d83fbe0c627b2b696acce67868793d7d9750e90e39592b3626691b7", - "sha256:b756072364347cb6aa5b60f9bc18e94b2f79632de3b0190253ad770c5df17db1", - "sha256:ba64dc2b3b7b158c6660d49cdb1d872d1d0bf4e42043ad8d5006099479a194e5", - "sha256:bed331fe18f58d844d39ceb398b77d6ac0b010d571cba8267c2e7165806b00ce", - "sha256:c188512b43542b1e91cadc3c6c915a82a5eb95929134faf7fd109f14f9892ce4", - "sha256:c21b9aa40e08e4f63a2f92ff3748e6b6c84d717d033c7b3438dd3123ee18f70e", - "sha256:ca713d4af15bae6e5d79b15c10c8522859a9a89d3b361a50b817c98c2fb402a2", - "sha256:cd4210baef299717db0a600d7a3cac81d46ef0e007f88c9335db79f8979c0d3d", - "sha256:cfe33efc9cb900a4c46f91a5ceba26d6df370ffddd9ca386eb1d4f0ad97b9ea9", - "sha256:d5cd3ab21acbdb414bb6c31958d7b06b85eeb40f66463c264a9b343a4e238642", - "sha256:dfbac4c2dfcc082fcf8d942d1e49b6aa0766c19d3358bd86e2000bf0fa4a9cf0", - "sha256:e235688f42b36be2b6b06fc37ac2126a73b75fb8d6bc66dd632aa35286238703", - "sha256:eb82dbba47a8318e75f679690190c10a5e1f447fbf9df41cbc4c3afd726d88cb", - "sha256:ebb86518203e12e96af765ee89034a1dbb0c3c65052d1b0c19bbbd6af8a145e1", - "sha256:ee78feb9d293c323b59a6f2dd441b63339a30edf35abcb51187d2fc26e696d13", - "sha256:eedab4c310c0299961ac285591acd53dc6723a1ebd90a57207c71f6e0c2153ab", - "sha256:efa568b885bca461f7c7b9e032655c0c143d305bf01c30caf6db2854a4532b38", - "sha256:efce6ae830831ab6a22b9b4091d411698145cb9b8fc869e1397ccf4b4b6455cb", - "sha256:f163d2fd041c630fed01bc48d28c3ed4a3b003c00acd396900e11ee5316b56bb", - "sha256:f20380df709d91525e4bee04746ba612a4df0972c1b8f8e1e8af997e678c7b81", - "sha256:f30f1928162e189091cf4d9da2eac617bfe78ef907a761614ff577ef4edfb3c8", - "sha256:f470c92737afa7d4c3aacc001e335062d582053d4dbe73cda126f2d7031068dd", - "sha256:ff8bf625fe85e119553b5383ba0fb6aa3d0ec2ae980295aaefa552374926b3f4" - ], - "markers": "python_version >= '3.7'", - "version": "==1.3.3" + "sha256:007df07a6e3eb3e33e9a1fe6a9db7af152bbd8a185f9aaa6ece10a3529e3e1c6", + "sha256:008eb8b31b3ea6896da16c38c1b136cb9fec9e249e77f6211d479db79a4eaf01", + "sha256:09163bdf0b2907454042edb19f887c6d33806adc71fbd54afc14908bfdc22251", + "sha256:0c7c1b47859ee2cac3846fde1c1dc0f15da6cec5a0e5c72d101e0f83dcb67ff9", + "sha256:0e5c8764c7829343d919cc2dfc587a8db01c4f70a4ebbc49abde5d4b158b007b", + "sha256:10ff5faaa22786315ef57097a279b833ecab1a0bfb07d604c9cbb1c4cdc2ed87", + "sha256:17ae5cd0f333f94f2e03aaf140bb762c64783935cc764ff9c82dff626089bebf", + "sha256:19488c57c12d4e8095a922f328df3f179c820c212940a498623ed39160bc3c2f", + "sha256:1a0848b52815006ea6596c395f87449f693dc419061cc21e970f139d466dc0a0", + "sha256:1e78fb68cf9c1a6aa4a9a12e960a5c9dfbdb89b3695197aa7064705662515de2", + "sha256:261b9f5d17cac914531331ff1b1d452125bf5daa05faf73b71d935485b0c510b", + "sha256:2b8bcf994563466db019fab287ff390fffbfdb4f905fc77bc1c1d604b1c689cc", + "sha256:38461d02d66de17455072c9ba981d35f1d2a73024bee7790ac2f9e361ef1cd0c", + "sha256:490132667476f6781b4c9458298b0c1cddf237488abd228b0b3650e5ecba7467", + "sha256:491e014f5c43656da08958808588cc6c016847b4360e327a62cb308c791bd2d9", + "sha256:515e1abc578dd3b275d6a5114030b1330ba044ffba03f94091842852f806f1c1", + "sha256:556de4430ce324c836789fa4560ca62d1591d2538b8ceb0b4f68fb7b2384a27a", + "sha256:5833593c25ac59ede40ed4de6d67eb42928cca97f26feea219f21d0ed0959b79", + "sha256:6221d84d463fb110bdd7619b69cb43878a11d51cbb9394ae3105d082d5199167", + "sha256:6918d49b1f90821e93069682c06ffde41829c346c66b721e65a5c62b4bab0300", + "sha256:6c38721585f285203e4b4132a352eb3daa19121a035f3182e08e437cface44bf", + "sha256:71932b597f9895f011f47f17d6428252fc728ba2ae6024e13c3398a087c2cdea", + "sha256:7211ef110a9194b6042449431e08c4d80c0481e5891e58d429df5899690511c2", + "sha256:764226ceef3125e53ea2cb275000e309c0aa5464d43bd72abd661e27fffc26ab", + "sha256:7645a8e814a3ee34a89c4a372011dcd817964ce8cb273c8ed6119d706e9613e3", + "sha256:76d4711f6f6d08551a7e9ef28c722f4a50dd0fc204c56b4bcd95c6cc05ce6fbb", + "sha256:7f4f399d28478d1f604c2ff9119907af9726aed73680e5ed1ca634d377abb087", + "sha256:88f7bc0fcca81f985f78dd0fa68d2c75abf8272b1f5c323ea4a01a4d7a614efc", + "sha256:8d0edd6b1c7fb94922bf569c9b092ee187a83f03fb1a63076e7774b60f9481a8", + "sha256:901289d524fdd571be1c7be054f48b1f88ce8dddcbdf1ec698b27d4b8b9e5d62", + "sha256:93ea75c050c5bb3d98016b4ba2497851eadf0ac154d88a67d7a6816206f6fa7f", + "sha256:981b9ab5a0a3178ff413bca62526bb784249421c24ad7381e39d67981be2c326", + "sha256:9ac08e601308e41eb533f232dbf6b7e4cea762f9f84f6357136eed926c15d12c", + "sha256:a02eb8ab2b8f200179b5f62b59757685ae9987996ae549ccf30f983f40602431", + "sha256:a0c6da9aee33ff0b1a451e867da0c1f47408112b3391dd43133838339e410963", + "sha256:a6c8097e01886188e5be3e6b14e94ab365f384736aa1fca6a0b9e35bd4a30bc7", + "sha256:aa384489fefeb62321b238e64c07ef48398fe80f9e1e6afeff22e140e0850eef", + "sha256:ad2a9eb6d9839ae241701d0918f54c51365a51407fd80f6b8289e2dfca977cc3", + "sha256:b206646d176a007466358aa21d85cd8600a415c67c9bd15403336c331a10d956", + "sha256:b826d97e4276750beca7c8f0f1a4938892697a6bcd8ec8217b3312dad6982781", + "sha256:b89ac9768b82205936771f8d2eb3ce88503b1556324c9f903e7156669f521472", + "sha256:bd7bd3b3830247580de99c99ea2a01416dfc3c34471ca1298bccabf86d0ff4dc", + "sha256:bdf1847068c362f16b353163391210269e4f0569a3c166bc6a9f74ccbfc7e839", + "sha256:c11b0746f5d946fecf750428a95f3e9ebe792c1ee3b1e96eeba145dc631a9672", + "sha256:c5374b80521d3d3f2ec5572e05adc94601985cc526fb276d0c8574a6d749f1b3", + "sha256:ca265542ca427bf97aed183c1676e2a9c66942e822b14dc6e5f42e038f92a503", + "sha256:ce31ae3e19f3c902de379cf1323d90c649425b86de7bbdf82871b8a2a0615f3d", + "sha256:ceb6ec0a10c65540421e20ebd29083c50e6d1143278746a4ef6bcf6153171eb8", + "sha256:d081f13b095d74b67d550de04df1c756831f3b83dc9881c38985834387487f1b", + "sha256:d5655a942f5f5d2c9ed93d72148226d75369b4f6952680211972a33e59b1dfdc", + "sha256:d5a32087d720c608f42caed0ef36d2b3ea61a9d09ee59a5142d6070da9041b8f", + "sha256:d6484756b12f40003c6128bfcc3fa9f0d49a687e171186c2d85ec82e3758c559", + "sha256:dd65632acaf0d47608190a71bfe46b209719bf2beb59507db08ccdbe712f969b", + "sha256:de343e75f40e972bae1ef6090267f8260c1446a1695e77096db6cfa25e759a95", + "sha256:e29cda763f752553fa14c68fb2195150bfab22b352572cb36c43c47bedba70eb", + "sha256:e41f3de4df3e80de75845d3e743b3f1c4c8613c3997a912dbf0229fc61a8b963", + "sha256:e66d2a64d44d50d2543405fb183a21f76b3b5fd16f130f5c99187c3fb4e64919", + "sha256:e74b0506fa5aa5598ac6a975a12aa8928cbb58e1f5ac8360792ef15de1aa848f", + "sha256:f0ed05f5079c708fe74bf9027e95125334b6978bf07fd5ab923e9e55e5fbb9d3", + "sha256:f61e2dc5ad442c52b4887f1fdc112f97caeff4d9e6ebe78879364ac59f1663e1", + "sha256:fec520865f42e5c7f050c2a79038897b1c7d1595e907a9e08e3353293ffc948e" + ], + "markers": "python_version >= '3.8'", + "version": "==1.4.0" }, "hsds": { "editable": true, @@ -641,10 +632,6 @@ "index": "pypi", "version": "==0.3.0" }, - "sanitized-package": { - "editable": true, - "path": "." - }, "simplejson": { "hashes": [ "sha256:04e31fa6ac8e326480703fb6ded1488bfa6f1d3f760d32e29dbf66d0838982ce", diff --git a/hsds/datanode_lib.py b/hsds/datanode_lib.py index 2cf8138a..267551c2 100644 --- a/hsds/datanode_lib.py +++ b/hsds/datanode_lib.py @@ -878,7 +878,7 @@ async def get_chunk_bytes( log.warn(msg) raise HTTPBadRequest(reason=msg) - # number of bytes in the hd5 chunk + # number of bytes in the hdf5 chunk h5_size = np.prod(hyper_dims) * item_size log.debug(f"h5 chunk size: {h5_size}") diff --git a/hsds/link_sn.py b/hsds/link_sn.py index bbabd402..dd823b20 100755 --- a/hsds/link_sn.py +++ b/hsds/link_sn.py @@ -593,6 +593,21 @@ async def POST_Links(request): log.warn(msg) raise HTTPBadRequest(reason=msg) + if follow_links and titles: + msg = "titles list can not be used with follow_links" + log.warn(msg) + raise HTTPBadRequest(reason=msg) + + if limit and titles: + msg = "Limit parameter can not be used with titles list" + log.warn(msg) + raise HTTPBadRequest(reason=msg) + + if create_order and titles: + msg = "CreateOrder parameter can not be used with titles" + log.warn(msg) + raise HTTPBadRequest(reason=msg) + # construct an item list from titles and group_ids items = {} if group_ids is None: diff --git a/hsds/util/s3Client.py b/hsds/util/s3Client.py index f2ddd7cc..0d3d692e 100644 --- a/hsds/util/s3Client.py +++ b/hsds/util/s3Client.py @@ -145,7 +145,7 @@ def _get_client_kwargs(self): kwargs["endpoint_url"] = self._s3_gateway kwargs["use_ssl"] = self._use_ssl kwargs["config"] = self._aio_config - log.debug(f"s3 kwargs: {kwargs}") + # log.debug(f"s3 kwargs: {kwargs}") return kwargs def _renewToken(self): diff --git a/tests/integ/helper.py b/tests/integ/helper.py index dd5d125e..2dbe34f7 100644 --- a/tests/integ/helper.py +++ b/tests/integ/helper.py @@ -271,4 +271,6 @@ def getLink(domain, grp_id, title): raise KeyError(f"expected link key in {rspJson}") link_json = rspJson["link"] + session.close() + return link_json diff --git a/tests/integ/link_test.py b/tests/integ/link_test.py index 4a14bda3..03bcf002 100755 --- a/tests/integ/link_test.py +++ b/tests/integ/link_test.py @@ -1354,6 +1354,14 @@ def testPostLinkMultiple(self): else: self.assertTrue(False) # unexpected + # try follow_links with titles. Should return a 400 + params = {"follow_links": 1} + grp_ids = [root_id, ] + titles = ["dset1.1.1", "dset1.1.2", "dset2.1", "dset2.2"] + payload = {"grp_ids": grp_ids, "titles": titles} + rsp = self.session.post(req, data=json.dumps(payload), params=params, headers=headers) + self.assertEqual(rsp.status_code, 400) # titles not allowed with follow_links + def testPostLinksGroupList(self): domain = self.base_domain + "/testPostLinksGroupList.h5" helper.setupDomain(domain) diff --git a/tools/link_mod.py b/tools/link_mod.py index 6ae7e0aa..17db7691 100755 --- a/tools/link_mod.py +++ b/tools/link_mod.py @@ -44,52 +44,80 @@ def printUsage(): sys.exit() +def getFileUri(dset_json): + # older format used "layout" key to store file_uri. + # newer ones use "creationProperties" + # return whichever one has a file_uri or None if neither do + + if "creationProperties" in dset_json: + cpl = dset_json["creationProperties"] + if "layout" in cpl: + cpl_layout = cpl["layout"] + if "file_uri" in cpl_layout: + return cpl_layout["file_uri"] + # not found under cpl + if "layout" in dset_json: + layout = dset_json["layout"] + if "file_uri" in layout: + return layout["file_uri"] + + # no found in either + return None + + +def setFileUri(dset_json, file_uri): + if "creationProperties" in dset_json: + cpl = dset_json["creationProperties"] + if "layout" in cpl: + cpl_layout = cpl["layout"] + if "file_uri" in cpl_layout: + cpl_layout["file_uri"] = file_uri + log.info(f"updated creationProperties layout with {file_uri}") + return + # not found under cpl + if "layout" in dset_json: + layout = dset_json["layout"] + if "file_uri" in layout: + layout["file_uri"] = file_uri + log.info(f"updated dset layout with {file_uri}") + return + + # no found in either + log.warning("expected to find file_uri for update") + + async def checkDataset(app, dset_key): log.info(f"checkDataset for key: {dset_key}") dset_json = await getStorJSONObj(app, dset_key) + log.debug(f"get dset_json: {dset_json}") dset_id = dset_json["id"] prefix_old = app["prefix_old"] prefix_new = app["prefix_new"] do_update = app["do_update"] - indirect_dataset_keys = app["indirect_dataset_keys"] app["dataset_count"] += 1 log.info(f"checkDataset for id: {dset_id}") - if "layout" not in dset_json: - log.info("no layout found") - return - layout_json = dset_json["layout"] - if "class" not in layout_json: - log.warn(f"no class found in layout for id: {dset_id}") + file_uri = getFileUri(dset_json) + + if not file_uri: + log.debug(f"no file_uri for {dset_key}") return - layout_class = layout_json["class"] - log.info(f"got layout_class: {layout_class}") - if layout_class in ("H5D_CONTIGUOUS_REF", "H5D_CHUNKED_REF"): - if "file_uri" not in layout_json: - log.warn( - f"Expected to find key 'file_uri' in layout_json for id: {dset_id}" - ) - return - file_uri = layout_json["file_uri"] - if file_uri.startswith(prefix_old): - prefix_len = len(prefix_old) - new_file_uri = prefix_new + file_uri[prefix_len:] - log.info(f"replacing uri: {file_uri} with {new_file_uri}") - app["matched_dset_uri"] += 1 - if do_update: - # update the dataset json - layout_json["file_uri"] = new_file_uri - dset_json["layout"] = layout_json - # write back to storage - try: - await putStorJSONObj(app, dset_key, dset_json) - log.info(f"dataset {dset_id} updated") - except Exception as e: - log.error(f"get exception writing dataset json: {e}") - elif layout_class == "H5D_CHUNKED_REF_INDIRECT": - # add to list to be scanned later - indirect_dataset_keys += dset_key[: -len(".dataset.json")] - else: - log.info(f"skipping check for layout_class: {layout_class}") + + log.debug(f"got file_uri: {file_uri}") + + if file_uri.startswith(prefix_old): + prefix_len = len(prefix_old) + new_file_uri = prefix_new + file_uri[prefix_len:] + log.info(f"replacing uri: {file_uri} with {new_file_uri}") + app["matched_dset_uri"] += 1 + if do_update: + setFileUri(dset_json, new_file_uri) + + # write back to storage + try: + await putStorJSONObj(app, dset_key, dset_json) + log.info(f"dataset {dset_id} updated") + except Exception as e: + log.error(f"get exception writing dataset json: {e}") async def getKeysCallback(app, s3keys): @@ -104,16 +132,11 @@ async def getKeysCallback(app, s3keys): raise ValueError("Invalid getKeysCallback") prefix = app["root_prefix"] - prefix_len = len(prefix) for s3key in s3keys: if not s3key.startswith(prefix): log.error(f"Unexpected key {s3key} for prefix: {prefix}") raise ValueError("invalid s3key for getKeysCallback") - if not s3key.endswith(".dataset.json"): - log.info(f"got unexpected key {s3key}, ignoring") - continue - dset_key = prefix + s3key[prefix_len:] - log.info(f"getKeys - :{dset_key}") + dset_key = s3key + ".dataset.json" await checkDataset(app, dset_key) log.info("getKeysCallback complete") @@ -126,36 +149,30 @@ async def run_scan(app, rootid, update=False): if not root_key.endswith("/.group.json"): raise ValueError("unexpected root key") root_prefix = root_key[: -(len(".group.json"))] + root_prefix += "d/" + log.info(f"getting s3 keys with prefix: {root_prefix}") app["root_prefix"] = root_prefix try: await getStorKeys( app, prefix=root_prefix, - suffix=".dataset.json", + deliminator="/", include_stats=False, callback=getKeysCallback, ) except ClientError as ce: log.error(f"removeKeys - getS3Keys faiiled: {ce}") except HTTPNotFound: - log.warn( - f"getStorKeys - HTTPNotFound error for getStorKeys with prefix: {root_prefix}" - ) + msg = f"getStorKeys - HTTPNotFound error for getStorKeys with prefix: {root_prefix}" + log.warn(msg) except HTTPInternalServerError: - log.error( - f"getStorKeys - HTTPInternalServerError for getStorKeys with prefix: {root_prefix}" - ) + msg = f"getStorKeys - HTTPInternalServerError for getStorKeys with prefix: {root_prefix}" + log.error(msg) except Exception as e: - log.error( - f"getStorKeys - Unexpected Exception for getStorKeys with prefix: {root_prefix}: {e}" - ) - - # update all chunks for datasets with H5D_CHUNKED_REF_INDIRECT layout - indirect_dataset_keys = app["indirect_dataset_keys"] - for prefix in indirect_dataset_keys: - log.info(f"got inidirect prefix: {prefix}") - # TBD... + msg = "getStorKeys - Unexpected Exception for getStorKeys with prefix: " + msg += f"{root_prefix}: {e}" + log.error(msg) await releaseStorageClient(app) @@ -185,6 +202,10 @@ def main(): print("prefix_old and prefix_new or the same") sys.exit(1) + # setup log config + log_level = "WARN" # ERROR, WARN, INFO, or DEBUG + log.setLogConfig(log_level) + # we need to setup a asyncio loop to query s3 loop = asyncio.get_event_loop()