diff --git a/exa,ple-data-kind70-and-20-only.csv b/exa,ple-data-kind70-and-20-only.csv new file mode 100644 index 0000000..2da1868 --- /dev/null +++ b/exa,ple-data-kind70-and-20-only.csv @@ -0,0 +1,33 @@ +"id","pubkey","created_at","kind","tags","content","sig","tagvalues" +"abf8c922dcd999c1b386711a3ff8326a004b1a1998a7fb21b90106a721361672","0403c86a1bb4cfbc34c8a493fbd1f0d158d42dd06d03eaa3720882a066d3a378",1739472685,20,"[[""alt"", ""List of pictures""], [""imeta"", ""url https://blossom.primal.net/dcb349b95d51f62c66fb6448d6c81ccdb1ce67742cfcc7344210d0e8d4a2e57f.jpg"", ""m image/jpeg"", ""alt "", ""x dcb349b95d51f62c66fb6448d6c81ccdb1ce67742cfcc7344210d0e8d4a2e57f"", ""size 121472"", ""dim 1600x1411"", ""blurhash ;8RypU-.*I9bvg_2Os-p?GLM%Lq[D*%zoJMyg3tQ8x%1t,NxxCRPS3oJV@t8t6a#RPs.X8bbs.ofXmoLZ%tQpIM{rrW;R*,CM|TextVYRktke.V@yXR+ZhxYT0W=r=WCW;=cIUTdx]Myent6a~af""], [""x"", ""dcb349b95d51f62c66fb6448d6c81ccdb1ce67742cfcc7344210d0e8d4a2e57f""], [""m"", ""image/jpeg""]]","","c4b140fac5b57b8b3bfa746e9eb122e6dad0760a1ed8fd0b9dfd1175164689aebd7116eabfe282b4d2ce2eb3a4ac7f0abf8378d883fd74d07d39aa6be96d828e","{dcb349b95d51f62c66fb6448d6c81ccdb1ce67742cfcc7344210d0e8d4a2e57f,image/jpeg}" +"f6fa387a80b75d0aa82f63bb7deb99a7ecdf98675d70ff6c198f7ed7933f751f","0403c86a1bb4cfbc34c8a493fbd1f0d158d42dd06d03eaa3720882a066d3a378",1739472719,20,"[[""alt"", ""List of pictures""], [""imeta"", ""url https://blossom.primal.net/d0bc6f4510b626432c9eaef7f4f6edae4b59621f5e6685ed59d7316235d211d7.jpg"", ""m image/jpeg"", ""alt "", ""x d0bc6f4510b626432c9eaef7f4f6edae4b59621f5e6685ed59d7316235d211d7"", ""size 151346"", ""dim 1224x1530"", ""blurhash _SF#2aIoADnOJ6R+S4X5M{spoyn%t7W;5kMy%2W:wgfkxFT0t7r?n+RkoeNG}GRjOrWBNtkCRkI.RPxGoyf5oLW;pHM|t7s.jZjZr@tlWWweoLRjs:WBn5VsbukWRjt7oe""], [""x"", ""d0bc6f4510b626432c9eaef7f4f6edae4b59621f5e6685ed59d7316235d211d7""], [""m"", ""image/jpeg""]]","","459e9076d6b32bf5088145696f951462732f9f59557402400207d488effbb271719a8c2b38bf99dbf7e6ff2c343b1fd4ee395e8ae69be53ffa86934947e4416a","{d0bc6f4510b626432c9eaef7f4f6edae4b59621f5e6685ed59d7316235d211d7,image/jpeg}" +"07efbd5250156d73f8d4d9a2972bcbe6421c14df8e21070714d51a5dfcaf29fe","5eb2c642d40a58795422121625be7fbe47e8901485a1a8bc01e1907b8aea0a9b",1739473425,20,"[[""imeta"", ""url https://relay.nostrverified.fyi/5bad360311bcd72debb11406dd354c8df211ab962579c21ce7698b7bd3f1223d.jpg"", ""x 5bad360311bcd72debb11406dd354c8df211ab962579c21ce7698b7bd3f1223d"", ""dim 1546x1024"", ""m image/jpeg"", ""blurhash gNE{nU~qofoft7j[t7~q-;t7t7xuofof-:ofjuoft7ofRjxuofayWBofj[fQt7ayWBWBofofof"", ""size 8382307""], [""x"", ""5bad360311bcd72debb11406dd354c8df211ab962579c21ce7698b7bd3f1223d""], [""m"", ""image/jpeg""], [""alt"", ""This is a image published via Olas.\nhttps://relay.nostrverified.fyi/5bad360311bcd72debb11406dd354c8df211ab962579c21ce7698b7bd3f1223d.jpg""], [""t"", ""Olas365""], [""t"", ""Olas""], [""t"", ""photography""], [""client"", ""olas"", ""31990:fa984bd7dbb282f07e16e7ae87b26a2a7b9b90b7246a44771f0cf5ae58018f52:1731850618505""]]","Park. #Olas365 #Olas #photography","d7d6cfb616d604dea018b2ae8c1f313d9b8339c30cce03aa1b169553f349e667dbea8cdf43fe84b2aab1c9ae94d25a741ee7014317b69aa4cfa30a846f98a1c3","{5bad360311bcd72debb11406dd354c8df211ab962579c21ce7698b7bd3f1223d,image/jpeg,Olas365,Olas,photography}" +"beb388f2199414b403f74151365217a0447672af9d30f70f6be7c7601c098f13","96246920aa53df6684e8e38f02410740df9128b7edc69692a5bc5f744ec1ed6c",1739474769,20,"[[""imeta"", ""url https://blossom.primal.net/be06312801df4762b82f01672c96b5549bf66c78112c13d80ac9ec205a9498b6.jpg"", ""x be06312801df4762b82f01672c96b5549bf66c78112c13d80ac9ec205a9498b6"", ""dim 768x1024"", ""m image/jpeg"", ""blurhash gUC=VYkXkDxZWVn%WV~AX9bcs:ayjZWVxuSikDfkj?jsayS$Siozj[jsoJayNyX9ozjuayoKj@"", ""size 3683943""], [""x"", ""be06312801df4762b82f01672c96b5549bf66c78112c13d80ac9ec205a9498b6""], [""m"", ""image/jpeg""], [""alt"", ""This is a image published via Olas.\nhttps://blossom.primal.net/be06312801df4762b82f01672c96b5549bf66c78112c13d80ac9ec205a9498b6.jpg""], [""client"", ""olas"", ""31990:fa984bd7dbb282f07e16e7ae87b26a2a7b9b90b7246a44771f0cf5ae58018f52:1731850618505""]]","Petersham Nurseries in Covent Garden - now an Italian restaurant called ‘The Petersham’. ","dca60eb4ceb110657c685146b3a94e3437e3fdadb6f3293024a605fc8bbfff0937fc8c92893ae9d385843714b5406b2b5ce475b31bb950f4abaed94bc734f915","{be06312801df4762b82f01672c96b5549bf66c78112c13d80ac9ec205a9498b6,image/jpeg}" +"fab72253e1faad79ba9f21e565c3b84cba22a93825be26173692d84cf8b659b8","96246920aa53df6684e8e38f02410740df9128b7edc69692a5bc5f744ec1ed6c",1739473484,20,"[[""imeta"", ""url https://blossom.primal.net/2e4c77b3c128448585b22c75aad2c499663a9dedc472f64700e161e86b221b15.jpg"", ""x 2e4c77b3c128448585b22c75aad2c499663a9dedc472f64700e161e86b221b15"", ""dim 768x1024"", ""m image/jpeg"", ""blurhash gGB}8.Mx}lIq}kbw-O?ZOFxDESaiT0ae?Goyw[t6M{oeR:%gs,aKt6WBRijYrqWWxtofRkfkWB"", ""size 3998502""], [""x"", ""2e4c77b3c128448585b22c75aad2c499663a9dedc472f64700e161e86b221b15""], [""m"", ""image/jpeg""], [""alt"", ""This is a image published via Olas.\nhttps://blossom.primal.net/2e4c77b3c128448585b22c75aad2c499663a9dedc472f64700e161e86b221b15.jpg""], [""client"", ""olas"", ""31990:fa984bd7dbb282f07e16e7ae87b26a2a7b9b90b7246a44771f0cf5ae58018f52:1731850618505""]]","Currently reading","a42b892942c8ce434537f69f5cfc33011be8c97b111001a2a63a298169de1d2f4447ed7dc9e41653bb3faedd25ba91aa9a94bf726d2d6273c2619bed09eced4f","{2e4c77b3c128448585b22c75aad2c499663a9dedc472f64700e161e86b221b15,image/jpeg}" +"f32484b9837cc114ccbf9e09fea6a9d2f5851455a352e49e1ad27de70fed620a","5eb2c642d40a58795422121625be7fbe47e8901485a1a8bc01e1907b8aea0a9b",1739473519,20,"[[""imeta"", ""url https://relay.nostrverified.fyi/238dde316565c2b01db8a398bbae3e3988c82e0e6d26e3ba6a3aeb0ee4ee57ee.jpg"", ""x 238dde316565c2b01db8a398bbae3e3988c82e0e6d26e3ba6a3aeb0ee4ee57ee"", ""dim 1546x1024"", ""m image/jpeg"", ""blurhash gBH21X?cM{I-5R}[V_?HT#xX$wSeohWGR4IoS%xujYaeofwGZ}JDN|xDV?xsROjYogj]oLRjax"", ""size 5181835""], [""x"", ""238dde316565c2b01db8a398bbae3e3988c82e0e6d26e3ba6a3aeb0ee4ee57ee""], [""m"", ""image/jpeg""], [""imeta"", ""url https://relay.nostrverified.fyi/ee7a4cb8cff138e71ed5c65a88a5fcdc05be78e94c19261e15964863d2ed2f83.jpg"", ""x ee7a4cb8cff138e71ed5c65a88a5fcdc05be78e94c19261e15964863d2ed2f83"", ""dim 1546x1024"", ""m image/jpeg"", ""blurhash gFGJ8FysotRj9*$-Sm?It9j]%LrpRnsEMwt7R:WYxCWBenxTk8NeX9kCV?R*RjjsWDfls:WUWA"", ""size 6482112""], [""x"", ""ee7a4cb8cff138e71ed5c65a88a5fcdc05be78e94c19261e15964863d2ed2f83""], [""imeta"", ""url https://relay.nostrverified.fyi/fe5599314e65ca305ba24e0efa9352ef180c12ecec3d45aa39c2fca918ded659.jpg"", ""x fe5599314e65ca305ba24e0efa9352ef180c12ecec3d45aa39c2fca918ded659"", ""dim 1546x1024"", ""m image/jpeg"", ""blurhash gTFGC0tSnks:kCt8j]?wgPWCngWBW?R*aMV{jZs:WBbIWBbKoNjwW?oeocoeRkogRkRjayjYt7"", ""size 5317816""], [""x"", ""fe5599314e65ca305ba24e0efa9352ef180c12ecec3d45aa39c2fca918ded659""], [""alt"", ""This is a image published via Olas.\nhttps://relay.nostrverified.fyi/238dde316565c2b01db8a398bbae3e3988c82e0e6d26e3ba6a3aeb0ee4ee57ee.jpg\nhttps://relay.nostrverified.fyi/ee7a4cb8cff138e71ed5c65a88a5fcdc05be78e94c19261e15964863d2ed2f83.jpg\nhttps://relay.nostrverified.fyi/fe5599314e65ca305ba24e0efa9352ef180c12ecec3d45aa39c2fca918ded659.jpg""], [""t"", ""Olas365""], [""t"", ""Olas""], [""t"", ""photography""], [""client"", ""olas"", ""31990:fa984bd7dbb282f07e16e7ae87b26a2a7b9b90b7246a44771f0cf5ae58018f52:1731850618505""]]"," #Olas365 #Olas #photography","43832e0e1de0041a0a6e7ca4134adc4331a1809c564c0b43fdd15743b7313c0440701367d291a61b3f91209f31ba0ea57ce0f5b944424c2f55340131ef112f21","{238dde316565c2b01db8a398bbae3e3988c82e0e6d26e3ba6a3aeb0ee4ee57ee,image/jpeg,ee7a4cb8cff138e71ed5c65a88a5fcdc05be78e94c19261e15964863d2ed2f83,fe5599314e65ca305ba24e0efa9352ef180c12ecec3d45aa39c2fca918ded659,Olas365,Olas,photography}" +"4e89719807db0b4c29d67a6ef39059ca9fb2937a59ecff0877b0866ae732da86","96246920aa53df6684e8e38f02410740df9128b7edc69692a5bc5f744ec1ed6c",1739474460,20,"[[""imeta"", ""url https://blossom.primal.net/fd252bb10cd5f6422ddc244616f86b70462feead7dc21ff3f8479467e18af822.jpg"", ""x fd252bb10cd5f6422ddc244616f86b70462feead7dc21ff3f8479467e18af822"", ""dim 768x1024"", ""m image/jpeg"", ""blurhash gLHe2aoKsS-p-ps:%M-SohjIadxaNHt6~WSvE1afWXRjWB?HxtRQe?RkR*t7o^s;M{Rjofoeax"", ""size 5207445""], [""x"", ""fd252bb10cd5f6422ddc244616f86b70462feead7dc21ff3f8479467e18af822""], [""m"", ""image/jpeg""], [""imeta"", ""url https://blossom.primal.net/caab47e5bac9e18b0639697846b8171bae7257400f761c616545589aa4d1b5cb.jpg"", ""x caab47e5bac9e18b0639697846b8171bae7257400f761c616545589aa4d1b5cb"", ""dim 768x1024"", ""m image/jpeg"", ""blurhash gOH^nl^OaJ-:t6Rjt7~BRjr;o#WBjsofkqNGM{ozs.jYofI[xZV@s.offjfkNdR+RjjtkDWVa#"", ""size 5276040""], [""x"", ""caab47e5bac9e18b0639697846b8171bae7257400f761c616545589aa4d1b5cb""], [""imeta"", ""url https://blossom.primal.net/c06cae891e66c6e1b311eb4676947137931830835ab118e7cfd520dcbc096aeb.jpg"", ""x c06cae891e66c6e1b311eb4676947137931830835ab118e7cfd520dcbc096aeb"", ""dim 768x1024"", ""m image/jpeg"", ""blurhash gFFq{$=~v~IUIo%KxuD}v}xctlShobae}]OqNGX5W=s:xZIXt6t2M|WTn,jvD*E2tQo#s.aes:"", ""size 5368665""], [""x"", ""c06cae891e66c6e1b311eb4676947137931830835ab118e7cfd520dcbc096aeb""], [""alt"", ""This is a image published via Olas.\nhttps://blossom.primal.net/fd252bb10cd5f6422ddc244616f86b70462feead7dc21ff3f8479467e18af822.jpg\nhttps://blossom.primal.net/caab47e5bac9e18b0639697846b8171bae7257400f761c616545589aa4d1b5cb.jpg\nhttps://blossom.primal.net/c06cae891e66c6e1b311eb4676947137931830835ab118e7cfd520dcbc096aeb.jpg""], [""client"", ""olas"", ""31990:fa984bd7dbb282f07e16e7ae87b26a2a7b9b90b7246a44771f0cf5ae58018f52:1731850618505""]]","Old photos from Petersham Nurseries in Covent Garden. It’s Now an Italian restaurant called ‘The Petersham’.","273594ee854d30824ad35010514b0e673c38015ff20905e440bdd2d6b6b088d61bc97fc66c9cfece05b80c0ec082697da49cc5f652f17f9220f0d1a711bfd088","{fd252bb10cd5f6422ddc244616f86b70462feead7dc21ff3f8479467e18af822,image/jpeg,caab47e5bac9e18b0639697846b8171bae7257400f761c616545589aa4d1b5cb,c06cae891e66c6e1b311eb4676947137931830835ab118e7cfd520dcbc096aeb}" +"4acb661e24d2bf448a0c9e90897d8ec0a7d0756c78a1eef0f9206561d631fc2f","81b83da61482c06b353f117737f09171353842ce907b8604fe7ea42294088983",1739474505,20,"[[""imeta"", ""url https://blossom.primal.net/b7a7e76b577cd25e6194f28d3bfd3f3bc89e1deabf17ac0a09b040189dcd002e.jpg"", ""x b7a7e76b577cd25e6194f28d3bfd3f3bc89e1deabf17ac0a09b040189dcd002e"", ""dim 1366x1024"", ""m image/jpeg"", ""blurhash g+HoORozR*j]jZj]ay%%ogaxj[ayfkjttSWBj[ayj@j[ayxZRjj[WUfkf6ayR%jsfQayj[WVfR"", ""size 3501656""], [""x"", ""b7a7e76b577cd25e6194f28d3bfd3f3bc89e1deabf17ac0a09b040189dcd002e""], [""m"", ""image/jpeg""], [""alt"", ""This is a image published via Olas.\nhttps://blossom.primal.net/b7a7e76b577cd25e6194f28d3bfd3f3bc89e1deabf17ac0a09b040189dcd002e.jpg""], [""t"", ""photography""], [""t"", ""nature""], [""client"", ""olas"", ""31990:fa984bd7dbb282f07e16e7ae87b26a2a7b9b90b7246a44771f0cf5ae58018f52:1731850618505""]]"," #photography #nature","2ab28460b478741c799527d637a7c69ba6dd89b328ad5ab7da2f00b720e7c98ee6c032f4bd2563662cf22680074622e3d6397ea5245bd47fa326de6a79ec5b24","{b7a7e76b577cd25e6194f28d3bfd3f3bc89e1deabf17ac0a09b040189dcd002e,image/jpeg,photography,nature}" +"000010310206a1d26a15d1f815cb995fa38b2a14c9c937e2a975d1b955009150","5943c88f3c60cd9edb125a668e2911ad419fc04e94549ed96a721901dd958372",1739475927,20,"[[""title"", """"], [""published_at"", ""1739475926""], [""imeta"", ""url https://blossom.primal.net/f3f76cde9d8f378ccbf1ca2ed946c9b0db2323ce2dfdfaf0182289e49193080b.jpg"", ""x f3f76cde9d8f378ccbf1ca2ed946c9b0db2323ce2dfdfaf0182289e49193080b"", ""dim 1440x1633"", ""m image/jpeg"", ""blurhash _KEL$$X9oIe-0Ls8t7k=j[j]NHNGoJfj4nV?oLtR?aS5WBIUaeWUs:ofWroeXAozWBRPRPayWXShWXoes.$%s.WVRPadWWogogWVs:%2f6WCofNGazayxtoft6RjRjoLR*""], [""imeta"", ""url https://blossom.primal.net/3ab666dbc560f65d98f8b7b07163d583806052e54c6dcde1ba5a5563f026f955.jpg"", ""x 3ab666dbc560f65d98f8b7b07163d583806052e54c6dcde1ba5a5563f026f955"", ""dim 1440x1633"", ""m image/jpeg"", ""blurhash _NJ7?i-O0L9GRRxvER9ZD*gONK%2slRPM_WZXAo#t6xU%09uof$gaJ-oofEN%NNHw[%1D*RjogM_aeWFt7WXNHxaM|WBxtoeR+R-xZItbcf4jYoKWBR-t7WBn~ofR+t6j=""], [""nonce"", ""102600"", ""16""]]","Look inspired by Zelda 💙✨ +I made a casual and a bikini version +Hope you like it, which version is better? left or right?💕 +Originally published in: 2023-03-19","7a017a8f96e207e9bdc634322eeb306c52062277670f1687bfa6601486cce1705c2be1aedcb09f2882e4f0a8c5860553bdddcf6e2d9c973b1a3d570d7aaad091",NULL +"00005adaa83aa2dff6ba97384f1804d96bd95c477fb66b621ef8d637e8035931","5943c88f3c60cd9edb125a668e2911ad419fc04e94549ed96a721901dd958372",1739475941,20,"[[""title"", """"], [""published_at"", ""1739475940""], [""imeta"", ""url https://blossom.primal.net/850e90b41000e5946c05966c73e1ff126def3fb46a5128c2c1852f414845d082.jpg"", ""x 850e90b41000e5946c05966c73e1ff126def3fb46a5128c2c1852f414845d082"", ""dim 1440x1695"", ""m image/jpeg"", ""blurhash _LF5,IIojY?GKPtQWV*0RkWBWVxvofj]SK%2fkNHr=IVoJivjZj[aeM{W;bHbvNGa|t7R5xGjZbaa|axkBoLofj[RPofayWCofbHWBofR*jta}jZsoWBWUWBfQWBj]j[of""], [""nonce"", ""50536"", ""16""]]","Mavis from H0tel Tr4nsyIvani4🖤🦇 +Posting cause this is one of my favorite cosplays ever! +Casual and bikini version 💕 witch version you like the most? +Originally published in: 2023-03-26","b091da4167a1c6831d9f06edcec092981b7e22318464d094df82df89e08d596123720c55284e3e3458b0ee1c8c9d974b90afe15bfa500835a1120b1ec50ee990",NULL +"705b33f61edc830b08c7e739a8288a5834b37c9d796fd4c96d767e90b9b35de6","96246920aa53df6684e8e38f02410740df9128b7edc69692a5bc5f744ec1ed6c",1739476096,20,"[[""imeta"", ""url https://blossom.primal.net/8bec352baaea45d03be56571a9809cac52092c2c779de499f97accfb2f193d92.jpg"", ""x 8bec352baaea45d03be56571a9809cac52092c2c779de499f97accfb2f193d92"", ""dim 768x1024"", ""m image/jpeg"", ""blurhash g8CPCQ0g%M-o?F%3Ip-BMy%0Iofl-oRjxB9[xZniInI.xaI.R--UkCR*aekCO9-pNHt7-pt7Wr"", ""size 4255362""], [""x"", ""8bec352baaea45d03be56571a9809cac52092c2c779de499f97accfb2f193d92""], [""m"", ""image/jpeg""], [""alt"", ""This is a image published via Olas.\nhttps://blossom.primal.net/8bec352baaea45d03be56571a9809cac52092c2c779de499f97accfb2f193d92.jpg""], [""client"", ""olas"", ""31990:fa984bd7dbb282f07e16e7ae87b26a2a7b9b90b7246a44771f0cf5ae58018f52:1731850618505""]]","Another photo I took at Petersham Nurseries many moons ago in Covent Garden, Floral Street, London - Afternoon Tea, Wine bar & deli, restaurant and possibly still a plant nursery, but I’m not 100 on that. There’s a beautiful courtyard too","9f23569032866a3eda71e27063eaabfa647170e46758db1b4e1ed29910068d66da842a0e6bcfcb5a1a61a583dc9b39639b0176398275b9217cd512762f7d9401","{8bec352baaea45d03be56571a9809cac52092c2c779de499f97accfb2f193d92,image/jpeg}" +"37a3b93677e570f15737e885ad5d6fad625c0c3c3ba8ee919b3b2bbcf7d879a1","845ee75bddf14a51e7d3c1476cd51955dbb3052f38806efce88bd3e2ffff9736",1739476706,20,"[[""imeta"", ""url https://blossom.primal.net/b5a9aec7a6201a7f5de56b4d9908dc60a17ff466d4ce5aa5449a5aa4b5be8d24.jpg"", ""x b5a9aec7a6201a7f5de56b4d9908dc60a17ff466d4ce5aa5449a5aa4b5be8d24"", ""dim 768x1024"", ""m image/jpeg"", ""blurhash gKA^5z9FoeoLayofafoJoLj[fPj[f6j[0K?Hs:ayjaayj[V[t6WBofa|fQj[_2E1R*j[oeofay"", ""size 6718334""], [""x"", ""b5a9aec7a6201a7f5de56b4d9908dc60a17ff466d4ce5aa5449a5aa4b5be8d24""], [""m"", ""image/jpeg""], [""alt"", ""This is a image published via Olas.\nhttps://blossom.primal.net/b5a9aec7a6201a7f5de56b4d9908dc60a17ff466d4ce5aa5449a5aa4b5be8d24.jpg""], [""client"", ""olas"", ""31990:fa984bd7dbb282f07e16e7ae87b26a2a7b9b90b7246a44771f0cf5ae58018f52:1731850618505""]]","Light on carpet","ea53c3f620d740cf13e6659b4089f35533b36716338d9d6af7a41756d58493ce2018750806853b78aeed199686657d6bc07a6db004bed8860027be0074dd4fb8","{b5a9aec7a6201a7f5de56b4d9908dc60a17ff466d4ce5aa5449a5aa4b5be8d24,image/jpeg}" +"1cc9d397d988190d076a7a5316c42fa2ca114750b5dcc6fb3ef1e547d022d6c0","fbeb2be7271a14196a8426e78ee4c747706be2424392b036f5fabe44331f55e3",1739476825,20,"[[""title"", ""Quote by TheBTCTherapist in #BitcoinTwitter""], [""imeta"", ""url https://bitcointwitter.web.app/images/364.png"", ""m image/png"", ""blurhash oAT8UM_2L#_2HX^N^Nj?pJogVDjEHXaKpxaepJae_3kCZ#jZkXkCL#adf+aJpykC_3kCVDjFk?og"", ""dim 1080x1080"", ""alt My money: bitcoin.\nMy mission: Bitcoin. \nMy people: Bitcoiners.""], [""m"", ""image/png""], [""l"", ""en"", ""ISO-639-1""]]","My money: bitcoin. +My mission: Bitcoin. +My people: Bitcoiners. + - nostr:npub18lkuerktq4kmgte2jv9nhqkjkh84n4umm8rhw3egh8xz8chrv4uqpf03et + +#BitcoinTwitter +https://bitcointwitter.web.app/images/364.png","3024d8cef69ae74f5d545ad468e45ee9e9e16164673744d1ef3936a7c3b3166f0f25715377bdff5d50b73b8e5b445563a5cabb9c2be556f6db4da8a7935e9a36","{image/png,en}" +"23fc81044e53eebacadcd3a8d5495432d451ef48b1f5c9647ce05697df99705c","1b5ee74df1f13eb85d54d36bc19a4180f44ce9aceeba2ea110f9ea79bb1aae6e",1740338910,7,"[[""p"", ""1b5ee74df1f13eb85d54d36bc19a4180f44ce9aceeba2ea110f9ea79bb1aae6e"", """", ""mention""], [""e"", ""af10e5c5a2f650f8de04830b1304a84ed081fe67795bda4063238bce74cf5a69""], [""p"", ""11c43c3d033c8834aeb13f9ec0be64be446ff216f5c3fd20870a7bef2faf7ba4""]]","🤙","34acb19d694f279f0387a5152a1a72f916025651f98e714e5f53cc1ddb993627fb4d167066bfc295daa8c4ca4146e396e725bcff97bc4dff8154d05b6056740d","{1b5ee74df1f13eb85d54d36bc19a4180f44ce9aceeba2ea110f9ea79bb1aae6e,af10e5c5a2f650f8de04830b1304a84ed081fe67795bda4063238bce74cf5a69,11c43c3d033c8834aeb13f9ec0be64be446ff216f5c3fd20870a7bef2faf7ba4}" +"0b5bb90de525dae2b767af345c5850e0306c1d69aba258e426a926af2a0d0a0b","0403c86a1bb4cfbc34c8a493fbd1f0d158d42dd06d03eaa3720882a066d3a378",1739472705,20,"[[""alt"", ""List of pictures""], [""imeta"", ""url https://blossom.primal.net/46e4067377f17833ec17b012358f43b0ba40615237e282530e83b9549a490c37.jpg"", ""m image/jpeg"", ""alt "", ""x 46e4067377f17833ec17b012358f43b0ba40615237e282530e83b9549a490c37"", ""size 299321"", ""dim 1280x1600"", ""blurhash _4Aw6Z=}[N-=Ecs*00}}x^;WsSyDoeX,IoRj9GbHV_a#k;03RO%gWZMxoy4.02NF9?V[xaod%2bwR%NXaespR%-VM{ofa}RQWCWo-UJ.oIIBbcV@V[-o00jX%NRjoKt8n$""], [""x"", ""46e4067377f17833ec17b012358f43b0ba40615237e282530e83b9549a490c37""], [""m"", ""image/jpeg""]]","","822a0feae3817d4fc9bac137c274e85f0ab08d3c58eed56f9df11ca765587bdb6e587356a5d45b54d4cdba16d2d2394bc114c95c52b9d3a936030263e7a0ee21","{46e4067377f17833ec17b012358f43b0ba40615237e282530e83b9549a490c37,image/jpeg}" +"22c0d1d07a72d31df81fadfa4404fd8444ff82ad03271cdf1e389468d1962364","96246920aa53df6684e8e38f02410740df9128b7edc69692a5bc5f744ec1ed6c",1739476381,20,"[[""imeta"", ""url https://blossom.primal.net/4fc546a8f8656925462a1c3e578ac490d61f919fb8f8260fa138299f1dc5ba46.jpg"", ""x 4fc546a8f8656925462a1c3e578ac490d61f919fb8f8260fa138299f1dc5ba46"", ""dim 768x1024"", ""m image/jpeg"", ""blurhash gGGQ8|z=1Z=y=yf$RjG=E4-CJ6R*%2R%$fw]xbR%RjbbocrzSvEfw|WXWBW.RSxXxGRlt5j[WD"", ""size 3689566""], [""x"", ""4fc546a8f8656925462a1c3e578ac490d61f919fb8f8260fa138299f1dc5ba46""], [""m"", ""image/jpeg""], [""imeta"", ""url https://blossom.primal.net/787269b8849ef94ac893dc64e1434c1a5455b8b6302cf9eb326df46a80079b92.jpg"", ""x 787269b8849ef94ac893dc64e1434c1a5455b8b6302cf9eb326df46a80079b92"", ""dim 768x1024"", ""m image/jpeg"", ""blurhash gDIy?|:t5i$|%4={-TLnM,=#NXIXXQs-]:NFNL-PM~RjbH;oR~J%xtxaIpNZ9t$i-nD,-TNIoc"", ""size 3756741""], [""x"", ""787269b8849ef94ac893dc64e1434c1a5455b8b6302cf9eb326df46a80079b92""], [""imeta"", ""url https://blossom.primal.net/a3245c8d0d6d95352e5b9203c902023e34af9c3fb7d21cf0646709a0109e0eda.jpg"", ""x a3245c8d0d6d95352e5b9203c902023e34af9c3fb7d21cf0646709a0109e0eda"", ""dim 768x1024"", ""m image/jpeg"", ""blurhash gFC}X,xD0}w|nQt5oy%en+r@NtIp$%t6OBw{xGR+NZbIs:I@t5bFWEs,WXWVIqs-k9jbxZR+WB"", ""size 2762759""], [""x"", ""a3245c8d0d6d95352e5b9203c902023e34af9c3fb7d21cf0646709a0109e0eda""], [""alt"", ""This is a image published via Olas.\nhttps://blossom.primal.net/4fc546a8f8656925462a1c3e578ac490d61f919fb8f8260fa138299f1dc5ba46.jpg\nhttps://blossom.primal.net/787269b8849ef94ac893dc64e1434c1a5455b8b6302cf9eb326df46a80079b92.jpg\nhttps://blossom.primal.net/a3245c8d0d6d95352e5b9203c902023e34af9c3fb7d21cf0646709a0109e0eda.jpg""], [""client"", ""olas"", ""31990:fa984bd7dbb282f07e16e7ae87b26a2a7b9b90b7246a44771f0cf5ae58018f52:1731850618505""]]","The plant my uncle Keith got me from Petersham Nurseries years ago. I still have the pot it came in. I miss him. I will not let him down. I refuse to let him down. ","4760b6f63e261dc672a942de73b71964284d47764898cf3e55c8d9f2843b35aef957a4ee5facab0f86489714e703c8dd041028239181b044710ca1953afb6d77","{4fc546a8f8656925462a1c3e578ac490d61f919fb8f8260fa138299f1dc5ba46,image/jpeg,787269b8849ef94ac893dc64e1434c1a5455b8b6302cf9eb326df46a80079b92,a3245c8d0d6d95352e5b9203c902023e34af9c3fb7d21cf0646709a0109e0eda}" +"9800b2ec93ead0b942dcacc328e253612593c85c845702892620fd53bb865b05","f5edf98693dffa83828b18aef3d8df7135671f4a1ddbf09cf2bb639f7feaf212",1740338910,7,"[[""e"", ""9975d6084390f31c382f8a5e15272df5e3a477f3affad4599ce1596ad5b41289"", """", """", ""c8df6ae886c711b0e87adf24da0181f5081f2b653a61a23b1055a36022293a06""], [""p"", ""c8df6ae886c711b0e87adf24da0181f5081f2b653a61a23b1055a36022293a06""], [""k"", ""20""], [""client"", ""olas"", ""31990:fa984bd7dbb282f07e16e7ae87b26a2a7b9b90b7246a44771f0cf5ae58018f52:1731850618505""]]","+","a407a568e5b5e58d2f00ea6480696e7ca9d89a10c3eae582f0d98012b9b7c0582b7bbbce9067da8e37a171e010f5d631c5caeb865186d8cf1f908253fd22a661","{9975d6084390f31c382f8a5e15272df5e3a477f3affad4599ce1596ad5b41289,c8df6ae886c711b0e87adf24da0181f5081f2b653a61a23b1055a36022293a06,20}" +"3b74646b1ef176331fa54d1b3219ff6dd5018bec383afd723fbbe977198dbb9f","9fce3aea32b35637838fb45b75be32595742e16bb3e4742cc82bb3d50f9087e6",1739477300,20,"[[""imeta"", ""url https://blossom.primal.net/7cf4661278dce4c822f8e88b17b34c2dcd3c30a776ea20db378b420164db3011.jpg"", ""x 7cf4661278dce4c822f8e88b17b34c2dcd3c30a776ea20db378b420164db3011"", ""dim 768x1024"", ""m image/jpeg"", ""blurhash gOGIimi^D*tRRPt7RPIUx]j]RjofoJM{.8axxaR*xaj?M{~qV@MytSadxuayoyRjR+bIt7tQxa"", ""size 3358992""], [""x"", ""7cf4661278dce4c822f8e88b17b34c2dcd3c30a776ea20db378b420164db3011""], [""m"", ""image/jpeg""], [""alt"", ""This is a image published via Olas.\nhttps://blossom.primal.net/7cf4661278dce4c822f8e88b17b34c2dcd3c30a776ea20db378b420164db3011.jpg""], [""t"", ""catstr""], [""t"", ""olas365""], [""client"", ""olas"", ""31990:fa984bd7dbb282f07e16e7ae87b26a2a7b9b90b7246a44771f0cf5ae58018f52:1731850618505""]]","In case you wondered what they do during zoom calls. #catstr #olas365","3977292f29d0f8ef6931da8901c045a83f80cb5f45443f6ba0c24215cbbe6e49d5cc26d4fd86900720b01e8bde50b72d48395f0f92b9c4170546f9f06828bbb2","{7cf4661278dce4c822f8e88b17b34c2dcd3c30a776ea20db378b420164db3011,image/jpeg,catstr,olas365}" +"71b5a3bb5544cefd8d08dde790983217e83b111e3d22bd0bfe541597646fd0e8","4a916109ff33c5ecec755eb8d2e2f57d78b684b067a4a12b5301a42db0c26f86",1740338911,7,"[[""e"", ""9361bd4b46405965b203e93a05a494076669384d5e504c84276e943ac7c99b72"", ""wss://relay.nostr.band/"", """", ""4dbfcb7c5ddb8249f9c7eb8c21e019f08fbfb7ec5ded5408b614590beb8d1695""], [""p"", ""4dbfcb7c5ddb8249f9c7eb8c21e019f08fbfb7ec5ded5408b614590beb8d1695""]]","+","322a24f5a46ea99f9b5b16a52c812d6c17b6c3761818d44988691427fab759328be7c7b63feb59c42bcc837d0cbba5d1d9e16c1af2881d8f5dca2172bceb1a66","{9361bd4b46405965b203e93a05a494076669384d5e504c84276e943ac7c99b72,4dbfcb7c5ddb8249f9c7eb8c21e019f08fbfb7ec5ded5408b614590beb8d1695}" +"52ddb9fd47b7e635f15ed6333234e62079ad0146f087e40b9c2cf7a9480920a6","4ce66109a2ebabd7ca84551d2e5b6eff409ceaf9e213e3dc061c15cf84d1590c",1739517094,20,"[[""imeta"", ""url https://blossom.primal.net/34c346172687efb9b79da3538a5de88a169e139345d8bcd194622f2f674d986f.jpg"", ""x 34c346172687efb9b79da3538a5de88a169e139345d8bcd194622f2f674d986f"", ""dim 1536x1024"", ""m image/jpeg"", ""blurhash gNDj^lOY10$$xDnPI:5-j[$%ayNbsmWVe.WBn%WCNboexGENS2$%ayWCR+oLs:s:kCoeaff6a{"", ""size 15287104""], [""x"", ""34c346172687efb9b79da3538a5de88a169e139345d8bcd194622f2f674d986f""], [""m"", ""image/jpeg""], [""alt"", ""This is a image published via Olas.\nhttps://blossom.primal.net/34c346172687efb9b79da3538a5de88a169e139345d8bcd194622f2f674d986f.jpg""], [""t"", ""photography""], [""t"", ""leica""], [""t"", ""50mm""], [""t"", ""taiwan""], [""t"", ""taipei""], [""t"", ""halloween""], [""client"", ""olas"", ""31990:fa984bd7dbb282f07e16e7ae87b26a2a7b9b90b7246a44771f0cf5ae58018f52:1731850618505""]]","#photography #leica #50mm #taiwan #taipei #halloween","ad300eb56ecb1ba1587cb39c2e35012ed197dfc857bc5e67a0da99199aa5a5af5925eb8f91e558dbcf6a92b8b6d46940b0a56be1c8bfd2c64f4486749d67c1be","{34c346172687efb9b79da3538a5de88a169e139345d8bcd194622f2f674d986f,image/jpeg,photography,leica,50mm,taiwan,taipei,halloween}" diff --git a/example-data-kind7-only.csv b/example-data-kind7-only.csv new file mode 100644 index 0000000..d48f898 --- /dev/null +++ b/example-data-kind7-only.csv @@ -0,0 +1,6 @@ +"id","pubkey","created_at","kind","tags","content","sig","tagvalues" +"34f78243c63d98b7646805ba7d40af2fcf2decf5893be977970209fb03e3289c","bc5517f67deeb41527a223c0d019c5973c84be351a7d45c265113e8debe09327",1740338621,7,"[[""e"", ""b01f3651cf1b24212df8fd136b24cd250fd899529b132f9909b820c8f66c5443""], [""p"", ""34a22ce5ebf6e367fa307c4e45d0987d88090ba8e7e2e6290276a565ca70ef6c""]]","+","6a639b8539bc1cda51fb347b303b3a8ccb26b1a80a0fb634f09dc60b1cae184199ae764bd97b8f8d154d166f89859945f0e39af802db7728807606204b88a053","{b01f3651cf1b24212df8fd136b24cd250fd899529b132f9909b820c8f66c5443,34a22ce5ebf6e367fa307c4e45d0987d88090ba8e7e2e6290276a565ca70ef6c}" +"68ac8fde29363add3ef0cf1618c11faaad5683f72f4b26e156dd5f85f0dafa92","6a0c596c1484eae2e8131a030f269944921e52619c1dd143a029c64ea6cd9731",1740338621,7,"[[""e"", ""51438a049ee4cc23b9d8bc2d5277e6a8559c145d338b7f3ada0b69903a1676da""], [""p"", ""09521ecc2c08b34b8c5ae019dfad1b8eaaeb089788c658a633e8396390a09207""], [""emoji"", ""nostrich"", ""https://github.com/emuro2/nostr-8bit-icons/blob/main/nostr_purple.png?raw=true""]]",":nostrich:","676c5790d1b23e0ef9b523bcd1e17b7912047a3be8db1e267dc300a7d90cd4657c47945420d084fc1c200bb09ab7c6991c8c2cfe03b9f82a896846195a3b4cbf","{51438a049ee4cc23b9d8bc2d5277e6a8559c145d338b7f3ada0b69903a1676da,09521ecc2c08b34b8c5ae019dfad1b8eaaeb089788c658a633e8396390a09207}" +"17e4060c96d05f7b702e4edad9314a50c7f0be5c81868b9d03286deeb7a71cfc","6a0c596c1484eae2e8131a030f269944921e52619c1dd143a029c64ea6cd9731",1740338630,7,"[[""e"", ""1efb1eb765b7893c1451bd640d7a8adc6d196ee76163d3ba44f896a30200990f""], [""p"", ""3c6142c00ce02d77432b578cbebbef3e5f987ef940eb442bb088c6c62cb6d948""], [""emoji"", ""nostrich"", ""https://github.com/emuro2/nostr-8bit-icons/blob/main/nostr_purple.png?raw=true""]]",":nostrich:","58fc29e22e0cab4cf174e48396e59929fdbff1242f14d0205704755f3f01a950cd949fd41c337c5a55fc446b38456c87d7479cac3a230313fc62be29e9bb5822","{1efb1eb765b7893c1451bd640d7a8adc6d196ee76163d3ba44f896a30200990f,3c6142c00ce02d77432b578cbebbef3e5f987ef940eb442bb088c6c62cb6d948}" +"d860630a3e7d9c3b712991982cd2fcbc62ed0d629af233ee5395a4eb97429051","a0f0ad355cff6618b58f2af840a2d78ff91abf08b91195dc00d7b3ba2a9c4cff",1740338634,7,"[[""e"", ""002353d6fbd278c17fd170f088c6a2a22e7c06623f63e70c741373cb55ff46a7"", """", ""root""], [""p"", ""a0f0ad355cff6618b58f2af840a2d78ff91abf08b91195dc00d7b3ba2a9c4cff""], [""e"", ""7c504c11a2d7455365aa7428759f376ae35953a8e3dad175e3029b88f90428ed""], [""p"", ""5a0944a089a98bed4ecfd42c2a906ccc117563f72408d971caaedd50f098bd9e""]]","🤙","db00ec1af143db13bff5028cc1e6cb4abfa05ced3146e726f27701e5569012afe8b2027413eb81baa6a9d239bcc8b35ee635f8b530ab2910bad803066a8e18af","{002353d6fbd278c17fd170f088c6a2a22e7c06623f63e70c741373cb55ff46a7,a0f0ad355cff6618b58f2af840a2d78ff91abf08b91195dc00d7b3ba2a9c4cff,7c504c11a2d7455365aa7428759f376ae35953a8e3dad175e3029b88f90428ed,5a0944a089a98bed4ecfd42c2a906ccc117563f72408d971caaedd50f098bd9e}" +"89d87c527814f940260eeef4cf679790e4d6cb335790328112dffc626d035905","d679b0f4c94843077301c920480c9d2f2d12c9fa6d10352e134eb1c08229ac9a",1740338617,7,"[[""e"", ""82db25e429523400e0f012d0bd804de7c9b92c1847d5e936e48e21d9887f056c""], [""p"", ""7a117235267b09b67956eb98361e462165fa1af7ce2111347fb800cb7e176dc7""]]","+","76ad4037cbaf6e8bb4d1138f9d0d67dad03774e49284543a11250c41f04d9239ac7c92e1c5b2184f119bf2534d52388e198861169baf392e225db36b7c1ae930","{82db25e429523400e0f012d0bd804de7c9b92c1847d5e936e48e21d9887f056c,7a117235267b09b67956eb98361e462165fa1af7ce2111347fb800cb7e176dc7}" diff --git a/relay/main.go b/relay/main.go index 7564aad..20b10cb 100644 --- a/relay/main.go +++ b/relay/main.go @@ -248,6 +248,81 @@ func main() { } }) + mux.HandleFunc("/api/trending/kind20", func(w http.ResponseWriter, r *http.Request) { + w.Header().Set("Content-Type", "application/json") + + // This query joins kind 20 posts with their reactions (kind 7) + // and counts the number of reactions in the last 24 hours using lateral join + query := ` + WITH reactions AS ( + SELECT + tags_expanded.value->1 #>> '{}' AS original_event_id, + COUNT(*) as reaction_count + FROM event e + CROSS JOIN LATERAL jsonb_array_elements(tags) as tags_expanded(value) + WHERE e.kind::text = '7' + AND e.created_at >= extract(epoch from now() - interval '24 hours')::bigint + AND tags_expanded.value->0 #>> '{}' = 'e' + GROUP BY tags_expanded.value->1 #>> '{}' + ) + SELECT + e.id, + e.pubkey, + to_timestamp(e.created_at) as created_at, + e.kind, + e.content, + e.tags, + COALESCE(r.reaction_count, 0) as reaction_count + FROM event e + LEFT JOIN reactions r ON e.id = r.original_event_id + WHERE e.kind::text = '20' + AND e.created_at >= extract(epoch from now() - interval '24 hours')::bigint + ORDER BY reaction_count DESC, e.created_at DESC + LIMIT 20 + ` + + rows, err := db.DB.Query(query) + if err != nil { + http.Error(w, fmt.Sprintf("Error querying trending posts: %v", err), http.StatusInternalServerError) + return + } + defer rows.Close() + + type TrendingPost struct { + ID string `json:"id"` + PubKey string `json:"pubkey"` + CreatedAt time.Time `json:"created_at"` + Kind string `json:"kind"` + Content string `json:"content"` + Tags [][]string `json:"tags"` + ReactionCount int `json:"reaction_count"` + } + + var trendingPosts []TrendingPost + for rows.Next() { + var post TrendingPost + var tagsJSON []byte + if err := rows.Scan(&post.ID, &post.PubKey, &post.CreatedAt, &post.Kind, &post.Content, &tagsJSON, &post.ReactionCount); err != nil { + http.Error(w, fmt.Sprintf("Error scanning row: %v", err), http.StatusInternalServerError) + return + } + // Parse the tags JSON + if err := json.Unmarshal(tagsJSON, &post.Tags); err != nil { + http.Error(w, fmt.Sprintf("Error parsing tags: %v", err), http.StatusInternalServerError) + return + } + trendingPosts = append(trendingPosts, post) + } + + response := map[string]interface{}{ + "trending": trendingPosts, + } + + if err := json.NewEncoder(w).Encode(response); err != nil { + http.Error(w, fmt.Sprintf("Error encoding JSON: %v", err), http.StatusInternalServerError) + } + }) + fmt.Println("running on :3334") http.ListenAndServe(":3334", relay) }