mirror of
https://github.com/gofiber/storage.git
synced 2025-10-24 17:00:28 +08:00
Compare commits
458 Commits
rueidis/v1
...
couchbase/
Author | SHA1 | Date | |
---|---|---|---|
![]() |
e596d39946 | ||
![]() |
2f5cfe7538 | ||
![]() |
caa448dfae | ||
![]() |
74b9f8786b | ||
![]() |
7489a3eb94 | ||
![]() |
42cc20f51d | ||
![]() |
2ad757cb5c | ||
![]() |
c596db0402 | ||
![]() |
b1f2b4f2b3 | ||
![]() |
25aa03c417 | ||
![]() |
c86034f531 | ||
![]() |
7ae8f414b1 | ||
![]() |
8463c7f8f4 | ||
![]() |
490131cdb1 | ||
![]() |
888bd54955 | ||
![]() |
f0b53d9a66 | ||
![]() |
be69a192d2 | ||
![]() |
b5a0d5ba88 | ||
![]() |
709bde3b56 | ||
![]() |
7d6aec5b4a | ||
![]() |
68e6ee57eb | ||
![]() |
c914bf3107 | ||
![]() |
034736306c | ||
![]() |
c07f9034d8 | ||
![]() |
ebc0dbd566 | ||
![]() |
51ed2951e6 | ||
![]() |
25935ed3d6 | ||
![]() |
6abe5e5385 | ||
![]() |
1b79f1941d | ||
![]() |
978e9decb9 | ||
![]() |
0a96159376 | ||
![]() |
1fd56464e1 | ||
![]() |
7559525547 | ||
![]() |
d431239437 | ||
![]() |
46aa8dbd7c | ||
![]() |
40586cc9df | ||
![]() |
bd94f13340 | ||
![]() |
6d5a45d959 | ||
![]() |
7027f24216 | ||
![]() |
20be56d1f0 | ||
![]() |
1b81d6a00f | ||
![]() |
ed7eae497f | ||
![]() |
137add4487 | ||
![]() |
63cf32031d | ||
![]() |
cedaaf2fd9 | ||
![]() |
366e1ee571 | ||
![]() |
1df42bd461 | ||
![]() |
e1e3a4ffaa | ||
![]() |
e21a9065b5 | ||
![]() |
aad60beab6 | ||
![]() |
bc86e8015c | ||
![]() |
0364bd4676 | ||
![]() |
ce8dc55659 | ||
![]() |
bb7a0cadb2 | ||
![]() |
d1b13cac69 | ||
![]() |
73bf79313b | ||
![]() |
7c75678090 | ||
![]() |
698ae8a390 | ||
![]() |
3ab20cabab | ||
![]() |
ff6212a42c | ||
![]() |
aac5d67055 | ||
![]() |
827ef9ec96 | ||
![]() |
a875f39f69 | ||
![]() |
17b879d6e4 | ||
![]() |
8855b7eda1 | ||
![]() |
0e4dfc0d07 | ||
![]() |
61d00d996b | ||
![]() |
a5733f7261 | ||
![]() |
c38280d308 | ||
![]() |
c2122f7e4a | ||
![]() |
649c51909b | ||
![]() |
65642eae0d | ||
![]() |
8840678883 | ||
![]() |
c5fb7a0de1 | ||
![]() |
aad87d2b7e | ||
![]() |
3da4dff355 | ||
![]() |
714f912b30 | ||
![]() |
fc37a1c2f1 | ||
![]() |
7f5e9eb94d | ||
![]() |
6339526f6e | ||
![]() |
4805f9f14b | ||
![]() |
6ab1dd1c75 | ||
![]() |
196723e48f | ||
![]() |
d844832d3e | ||
![]() |
2390e2a92d | ||
![]() |
481cdff03b | ||
![]() |
b41c6e1c9a | ||
![]() |
7bdb6140ce | ||
![]() |
944575d106 | ||
![]() |
59a861ea30 | ||
![]() |
a99cf3930a | ||
![]() |
69467ed7ab | ||
![]() |
3d26d32f1a | ||
![]() |
bd89daaba0 | ||
![]() |
f1b52c57d7 | ||
![]() |
7a56299372 | ||
![]() |
b775dc4c8e | ||
![]() |
db6449b454 | ||
![]() |
d4015ce4e6 | ||
![]() |
92fadd0f07 | ||
![]() |
617e1029e4 | ||
![]() |
bf555fc757 | ||
![]() |
ab54fa3fea | ||
![]() |
64092ed5b7 | ||
![]() |
9fe80fb996 | ||
![]() |
cc552d8da1 | ||
![]() |
1e5842520e | ||
![]() |
a6e90596b1 | ||
![]() |
a6df18aab0 | ||
![]() |
ec5fe0ce57 | ||
![]() |
36ac34e4ee | ||
![]() |
44ee39125c | ||
![]() |
db78bf31a9 | ||
![]() |
8217bf1674 | ||
![]() |
c3a43fa547 | ||
![]() |
ea8757954d | ||
![]() |
9eb4031a70 | ||
![]() |
e5b3f3d3ff | ||
![]() |
425facc354 | ||
![]() |
fd01240c04 | ||
![]() |
18555af9ce | ||
![]() |
aebc8cb8b1 | ||
![]() |
fc7d7b7b35 | ||
![]() |
1adc6bfd94 | ||
![]() |
83a4738628 | ||
![]() |
7ac8a3ed25 | ||
![]() |
ebd3e90db5 | ||
![]() |
37fee35346 | ||
![]() |
6e6a2e1022 | ||
![]() |
e6b8e31197 | ||
![]() |
d6e73157b6 | ||
![]() |
4c57f3872e | ||
![]() |
988773fffc | ||
![]() |
0e68f36008 | ||
![]() |
8914be3ee5 | ||
![]() |
28d296d96b | ||
![]() |
84eba42d87 | ||
![]() |
9e2257de4f | ||
![]() |
1be3b2025e | ||
![]() |
7e6ffad8d7 | ||
![]() |
3570609353 | ||
![]() |
6fe8158deb | ||
![]() |
7de84bcae4 | ||
![]() |
71aa8ed852 | ||
![]() |
2656670d54 | ||
![]() |
8c03fe7af2 | ||
![]() |
e615c6f01e | ||
![]() |
9ab4df2a01 | ||
![]() |
98a1bbe290 | ||
![]() |
705706a418 | ||
![]() |
b539c9dde8 | ||
![]() |
912bb43630 | ||
![]() |
8e13a6f387 | ||
![]() |
95f243e26a | ||
![]() |
b1026d4553 | ||
![]() |
33b00bdd97 | ||
![]() |
43ec0f0380 | ||
![]() |
8f693eb683 | ||
![]() |
53f69d1576 | ||
![]() |
3abb5afc2e | ||
![]() |
d7c3475ec9 | ||
![]() |
3c3622d811 | ||
![]() |
4a002049c5 | ||
![]() |
b0410809eb | ||
![]() |
904a606aa2 | ||
![]() |
ea7c246e81 | ||
![]() |
6fbff46b8e | ||
![]() |
3cbad5a75e | ||
![]() |
e7fddf6676 | ||
![]() |
dd6819e781 | ||
![]() |
82d4154c74 | ||
![]() |
9953832a00 | ||
![]() |
371e69053c | ||
![]() |
d8e70de944 | ||
![]() |
7a1d8d2c98 | ||
![]() |
b136a5b56e | ||
![]() |
58de66d122 | ||
![]() |
dd6143892e | ||
![]() |
e04e1e6346 | ||
![]() |
66fef6ba6d | ||
![]() |
875834314f | ||
![]() |
5ee1715022 | ||
![]() |
f94632f947 | ||
![]() |
1654e52f95 | ||
![]() |
1e0b4e416b | ||
![]() |
06f44dedaf | ||
![]() |
7c88d7908a | ||
![]() |
43a61892dc | ||
![]() |
21e89f59d2 | ||
![]() |
1e2e8012e7 | ||
![]() |
4145f60593 | ||
![]() |
fe2db5baf5 | ||
![]() |
6b40a05ccd | ||
![]() |
f3d338dad2 | ||
![]() |
cd4fe07ff3 | ||
![]() |
a28f8689f1 | ||
![]() |
13a1852057 | ||
![]() |
653c430f9d | ||
![]() |
3366e6dd63 | ||
![]() |
fa14baae3d | ||
![]() |
4cd1214f69 | ||
![]() |
442e4809ae | ||
![]() |
406ba73eec | ||
![]() |
56dc1dd7ff | ||
![]() |
088154f2af | ||
![]() |
8391d854bc | ||
![]() |
ced0e613a0 | ||
![]() |
e748baf9cf | ||
![]() |
4405f46024 | ||
![]() |
41afe4116e | ||
![]() |
77869acab6 | ||
![]() |
7b1fdb7325 | ||
![]() |
e7581b6e08 | ||
![]() |
72d3e80126 | ||
![]() |
c9cf50ee93 | ||
![]() |
70aa68fee1 | ||
![]() |
b04a6d0bd2 | ||
![]() |
0f6fecf48e | ||
![]() |
5fdad1dca7 | ||
![]() |
5401e4c6ca | ||
![]() |
63962a4a9e | ||
![]() |
7476af6227 | ||
![]() |
cd34271491 | ||
![]() |
87cf07648d | ||
![]() |
337dc45da8 | ||
![]() |
e27e1727e7 | ||
![]() |
7c028869e3 | ||
![]() |
ff932113e8 | ||
![]() |
bc12528362 | ||
![]() |
2a0b6423af | ||
![]() |
533de03ce9 | ||
![]() |
d4d7eedd05 | ||
![]() |
ee376faa57 | ||
![]() |
e378910337 | ||
![]() |
c54d54995b | ||
![]() |
6beaff2fa0 | ||
![]() |
30e6e5ad85 | ||
![]() |
fd65cef217 | ||
![]() |
28503829f6 | ||
![]() |
3f7110fcdd | ||
![]() |
287a903a19 | ||
![]() |
c688b234de | ||
![]() |
a2646d6fc3 | ||
![]() |
9fd09d88e1 | ||
![]() |
acc0d6b62f | ||
![]() |
9deea0d835 | ||
![]() |
eb73209838 | ||
![]() |
46eea52615 | ||
![]() |
9f8091caff | ||
![]() |
5b03e3c258 | ||
![]() |
585b3e93ae | ||
![]() |
235d001e9c | ||
![]() |
05d66770ef | ||
![]() |
bc80cbb400 | ||
![]() |
823b9f9a6f | ||
![]() |
138a8f9b87 | ||
![]() |
d5694955e7 | ||
![]() |
c138cabfb3 | ||
![]() |
c1933ed3e8 | ||
![]() |
11379815a1 | ||
![]() |
093771565c | ||
![]() |
f1d4944525 | ||
![]() |
64eb3d85be | ||
![]() |
98ce163298 | ||
![]() |
9b6b3c8afe | ||
![]() |
0a1254849f | ||
![]() |
21157c2990 | ||
![]() |
e0f5735b25 | ||
![]() |
3d82298d30 | ||
![]() |
715cafdc96 | ||
![]() |
5c2bcfea9b | ||
![]() |
7f995dafb2 | ||
![]() |
ab88d43900 | ||
![]() |
6b31862a33 | ||
![]() |
785e71215f | ||
![]() |
ea98e0ac2c | ||
![]() |
a2f349766f | ||
![]() |
b60700c0b9 | ||
![]() |
3f5304479a | ||
![]() |
51759980d0 | ||
![]() |
0f9476ea39 | ||
![]() |
e91a22a066 | ||
![]() |
f2ff5e7a39 | ||
![]() |
fe98837e83 | ||
![]() |
1fa944bef7 | ||
![]() |
c2e5b74f2a | ||
![]() |
0c2d884898 | ||
![]() |
d3c0d39dc8 | ||
![]() |
fbfc6d9394 | ||
![]() |
165b2ae02a | ||
![]() |
174e393340 | ||
![]() |
fb997fd4b5 | ||
![]() |
a3bf4c9e20 | ||
![]() |
45a0bc547e | ||
![]() |
40f3844551 | ||
![]() |
1b4c2425db | ||
![]() |
d8b1437f50 | ||
![]() |
b5d51650a3 | ||
![]() |
863ef71f8b | ||
![]() |
f2a5ba2e7c | ||
![]() |
85b4a99042 | ||
![]() |
44d93745d1 | ||
![]() |
b4cd42b73e | ||
![]() |
10116f925d | ||
![]() |
de3b493523 | ||
![]() |
e4abddc19f | ||
![]() |
69a51dc87e | ||
![]() |
6e08ff8098 | ||
![]() |
4f0e6c465f | ||
![]() |
7e74ccf6da | ||
![]() |
93c211d4ab | ||
![]() |
c00f6495c5 | ||
![]() |
10e473e1eb | ||
![]() |
4a7a7f0480 | ||
![]() |
5e5858e217 | ||
![]() |
86575200b3 | ||
![]() |
a7c7b42836 | ||
![]() |
a9bb64e9ec | ||
![]() |
c1362f1eae | ||
![]() |
4c2246e2b9 | ||
![]() |
3a3ab81b5a | ||
![]() |
d793dc4af0 | ||
![]() |
6742f2ae27 | ||
![]() |
3fc1b8ca86 | ||
![]() |
33d9b48f4e | ||
![]() |
962c314b98 | ||
![]() |
511a96be07 | ||
![]() |
4e570adc99 | ||
![]() |
951bb773c1 | ||
![]() |
cf25873ebd | ||
![]() |
2cc5e2c03b | ||
![]() |
d4b254694f | ||
![]() |
e4a7a648ab | ||
![]() |
41e11d61c6 | ||
![]() |
0f88b957a8 | ||
![]() |
8e75266dac | ||
![]() |
66cdbbd9fa | ||
![]() |
4e4e57512e | ||
![]() |
0439f04e0e | ||
![]() |
ddbe48768f | ||
![]() |
9210a551ac | ||
![]() |
c5fa26046a | ||
![]() |
f29aa524ca | ||
![]() |
07689915d3 | ||
![]() |
cc15d52131 | ||
![]() |
cb30085763 | ||
![]() |
505f3710b9 | ||
![]() |
c6792f4a17 | ||
![]() |
8caf6b9812 | ||
![]() |
e1e51a0d68 | ||
![]() |
fd5f9f7993 | ||
![]() |
b49ff3a6a6 | ||
![]() |
c58fcf23e2 | ||
![]() |
3f32afe238 | ||
![]() |
c7ef3ee5f2 | ||
![]() |
32c31af76e | ||
![]() |
96079e7650 | ||
![]() |
16ebadc5c1 | ||
![]() |
7a92ddb16e | ||
![]() |
de074c555d | ||
![]() |
bba2cc0ba7 | ||
![]() |
67fc665919 | ||
![]() |
e1aa2a6ae7 | ||
![]() |
3d77696dec | ||
![]() |
e8128ff53c | ||
![]() |
babfff4dc4 | ||
![]() |
72a92b9221 | ||
![]() |
be47d1fea6 | ||
![]() |
e8b18f7ef2 | ||
![]() |
ea2775d9af | ||
![]() |
d7e2b3000a | ||
![]() |
dc96462306 | ||
![]() |
526bd7826b | ||
![]() |
f01f10c006 | ||
![]() |
3bfea340e7 | ||
![]() |
0fe8e5fda3 | ||
![]() |
ff55ec3477 | ||
![]() |
ff83043d09 | ||
![]() |
5a6ee123cf | ||
![]() |
a9f76af4ba | ||
![]() |
2aa6a93b98 | ||
![]() |
33e4479ce7 | ||
![]() |
adea65d290 | ||
![]() |
537b31756b | ||
![]() |
3b91f93611 | ||
![]() |
42831dcee6 | ||
![]() |
89a0a97fe8 | ||
![]() |
86f1b406e3 | ||
![]() |
102acc252b | ||
![]() |
4c24f5c1d3 | ||
![]() |
e6249971b8 | ||
![]() |
a8c6a4ec0b | ||
![]() |
412e272a97 | ||
![]() |
394700037c | ||
![]() |
6ec8bcd32c | ||
![]() |
b4652e76d3 | ||
![]() |
fc45f97811 | ||
![]() |
8a058382a7 | ||
![]() |
e05e7cd714 | ||
![]() |
3de4b9e83e | ||
![]() |
472d68a4ec | ||
![]() |
bf194ad2a4 | ||
![]() |
81439cd1b5 | ||
![]() |
ed9c7d186b | ||
![]() |
22f2630f8d | ||
![]() |
5a356f7c64 | ||
![]() |
7c1aec139a | ||
![]() |
19282554cc | ||
![]() |
889d229330 | ||
![]() |
e6fc5c6ab0 | ||
![]() |
c2c72ffc7f | ||
![]() |
84a578cc4e | ||
![]() |
3818d87d4d | ||
![]() |
af52fa3e09 | ||
![]() |
c0611659e1 | ||
![]() |
ae3a2de340 | ||
![]() |
cac4fd5e8d | ||
![]() |
b074e83e98 | ||
![]() |
478ea67bea | ||
![]() |
4f1577ad2c | ||
![]() |
15865d59ff | ||
![]() |
8cb7bc56b2 | ||
![]() |
bff5333d67 | ||
![]() |
af5faa0fa3 | ||
![]() |
8ee81305a1 | ||
![]() |
39be2580ea | ||
![]() |
a7a26b8d29 | ||
![]() |
cdf78c223e | ||
![]() |
1a5e6f92b2 | ||
![]() |
49eeb1d494 | ||
![]() |
78da7fcbd1 | ||
![]() |
db3ab9a2d8 | ||
![]() |
b3a2e40c62 | ||
![]() |
a4849c83f7 | ||
![]() |
60be628083 | ||
![]() |
3cd89dbcf7 | ||
![]() |
43a47ef467 | ||
![]() |
153c837357 | ||
![]() |
efbc89fea6 | ||
![]() |
7bbad9a837 | ||
![]() |
1c23d53a9b | ||
![]() |
f962d64885 | ||
![]() |
1bb4d922e9 | ||
![]() |
75c8525a46 | ||
![]() |
4d7a172400 | ||
![]() |
1d6c0c3e25 | ||
![]() |
c80f1269f0 | ||
![]() |
471a6ac36a | ||
![]() |
de8f798d6e | ||
![]() |
b53f02beb1 | ||
![]() |
4ad4b034cb | ||
![]() |
fc01fc5829 | ||
![]() |
ff25433c70 | ||
![]() |
689759c035 | ||
![]() |
2f5263ef85 | ||
![]() |
2f174934c2 | ||
![]() |
0e060e19d1 | ||
![]() |
4ed36499ca |
8
.github/dependabot.yml
vendored
8
.github/dependabot.yml
vendored
@@ -4,21 +4,17 @@
|
|||||||
version: 2
|
version: 2
|
||||||
updates:
|
updates:
|
||||||
- package-ecosystem: "github-actions"
|
- package-ecosystem: "github-actions"
|
||||||
|
open-pull-requests-limit: 15
|
||||||
directory: "/"
|
directory: "/"
|
||||||
labels:
|
labels:
|
||||||
- "🤖 Dependencies"
|
- "🤖 Dependencies"
|
||||||
schedule:
|
schedule:
|
||||||
interval: "daily"
|
interval: "daily"
|
||||||
- package-ecosystem: "gomod"
|
- package-ecosystem: "gomod"
|
||||||
|
open-pull-requests-limit: 15
|
||||||
directories:
|
directories:
|
||||||
- "**/*"
|
- "**/*"
|
||||||
labels:
|
labels:
|
||||||
- "🤖 Dependencies"
|
- "🤖 Dependencies"
|
||||||
schedule:
|
schedule:
|
||||||
interval: "daily"
|
interval: "daily"
|
||||||
- package-ecosystem: "gomod"
|
|
||||||
directory: "/clickhouse/" # Location of package manifests
|
|
||||||
labels:
|
|
||||||
- "🤖 Dependencies"
|
|
||||||
schedule:
|
|
||||||
interval: "daily"
|
|
||||||
|
50
.github/release-drafter-azureblob.yml
vendored
50
.github/release-drafter-azureblob.yml
vendored
@@ -1,50 +0,0 @@
|
|||||||
name-template: 'Azure Blob - v$RESOLVED_VERSION'
|
|
||||||
tag-template: 'azureblob/v$RESOLVED_VERSION'
|
|
||||||
tag-prefix: azureblob/v
|
|
||||||
include-paths:
|
|
||||||
- azureblob
|
|
||||||
categories:
|
|
||||||
- title: '❗ Breaking Changes'
|
|
||||||
labels:
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
- title: '🚀 New'
|
|
||||||
labels:
|
|
||||||
- '✏️ Feature'
|
|
||||||
- title: '🧹 Updates'
|
|
||||||
labels:
|
|
||||||
- '🧹 Updates'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- title: '🐛 Fixes'
|
|
||||||
labels:
|
|
||||||
- '☢️ Bug'
|
|
||||||
- title: '📚 Documentation'
|
|
||||||
labels:
|
|
||||||
- '📒 Documentation'
|
|
||||||
change-template: '- $TITLE (#$NUMBER)'
|
|
||||||
change-title-escapes: '\<*_&' # You can add # and @ to disable mentions, and add ` to disable code blocks.
|
|
||||||
exclude-contributors:
|
|
||||||
- dependabot
|
|
||||||
- dependabot[bot]
|
|
||||||
version-resolver:
|
|
||||||
major:
|
|
||||||
labels:
|
|
||||||
- 'major'
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
minor:
|
|
||||||
labels:
|
|
||||||
- 'minor'
|
|
||||||
- '✏️ Feature'
|
|
||||||
patch:
|
|
||||||
labels:
|
|
||||||
- 'patch'
|
|
||||||
- '📒 Documentation'
|
|
||||||
- '☢️ Bug'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- '🧹 Updates'
|
|
||||||
default: patch
|
|
||||||
template: |
|
|
||||||
$CHANGES
|
|
||||||
|
|
||||||
**Full Changelog**: https://github.com/$OWNER/$REPOSITORY/compare/$PREVIOUS_TAG...azureblob/v$RESOLVED_VERSION
|
|
||||||
|
|
||||||
Thank you $CONTRIBUTORS for making this update possible.
|
|
50
.github/release-drafter-badger.yml
vendored
50
.github/release-drafter-badger.yml
vendored
@@ -1,50 +0,0 @@
|
|||||||
name-template: 'Badger - v$RESOLVED_VERSION'
|
|
||||||
tag-template: 'badger/v$RESOLVED_VERSION'
|
|
||||||
tag-prefix: badger/v
|
|
||||||
include-paths:
|
|
||||||
- badger
|
|
||||||
categories:
|
|
||||||
- title: '❗ Breaking Changes'
|
|
||||||
labels:
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
- title: '🚀 New'
|
|
||||||
labels:
|
|
||||||
- '✏️ Feature'
|
|
||||||
- title: '🧹 Updates'
|
|
||||||
labels:
|
|
||||||
- '🧹 Updates'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- title: '🐛 Fixes'
|
|
||||||
labels:
|
|
||||||
- '☢️ Bug'
|
|
||||||
- title: '📚 Documentation'
|
|
||||||
labels:
|
|
||||||
- '📒 Documentation'
|
|
||||||
change-template: '- $TITLE (#$NUMBER)'
|
|
||||||
change-title-escapes: '\<*_&' # You can add # and @ to disable mentions, and add ` to disable code blocks.
|
|
||||||
exclude-contributors:
|
|
||||||
- dependabot
|
|
||||||
- dependabot[bot]
|
|
||||||
version-resolver:
|
|
||||||
major:
|
|
||||||
labels:
|
|
||||||
- 'major'
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
minor:
|
|
||||||
labels:
|
|
||||||
- 'minor'
|
|
||||||
- '✏️ Feature'
|
|
||||||
patch:
|
|
||||||
labels:
|
|
||||||
- 'patch'
|
|
||||||
- '📒 Documentation'
|
|
||||||
- '☢️ Bug'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- '🧹 Updates'
|
|
||||||
default: patch
|
|
||||||
template: |
|
|
||||||
$CHANGES
|
|
||||||
|
|
||||||
**Full Changelog**: https://github.com/$OWNER/$REPOSITORY/compare/$PREVIOUS_TAG...badger/v$RESOLVED_VERSION
|
|
||||||
|
|
||||||
Thank you $CONTRIBUTORS for making this update possible.
|
|
50
.github/release-drafter-bbolt.yml
vendored
50
.github/release-drafter-bbolt.yml
vendored
@@ -1,50 +0,0 @@
|
|||||||
name-template: 'Bbolt - v$RESOLVED_VERSION'
|
|
||||||
tag-template: 'bbolt/v$RESOLVED_VERSION'
|
|
||||||
tag-prefix: bbolt/v
|
|
||||||
include-paths:
|
|
||||||
- bbolt
|
|
||||||
categories:
|
|
||||||
- title: '❗ Breaking Changes'
|
|
||||||
labels:
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
- title: '🚀 New'
|
|
||||||
labels:
|
|
||||||
- '✏️ Feature'
|
|
||||||
- title: '🧹 Updates'
|
|
||||||
labels:
|
|
||||||
- '🧹 Updates'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- title: '🐛 Fixes'
|
|
||||||
labels:
|
|
||||||
- '☢️ Bug'
|
|
||||||
- title: '📚 Documentation'
|
|
||||||
labels:
|
|
||||||
- '📒 Documentation'
|
|
||||||
change-template: '- $TITLE (#$NUMBER)'
|
|
||||||
change-title-escapes: '\<*_&' # You can add # and @ to disable mentions, and add ` to disable code blocks.
|
|
||||||
exclude-contributors:
|
|
||||||
- dependabot
|
|
||||||
- dependabot[bot]
|
|
||||||
version-resolver:
|
|
||||||
major:
|
|
||||||
labels:
|
|
||||||
- 'major'
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
minor:
|
|
||||||
labels:
|
|
||||||
- 'minor'
|
|
||||||
- '✏️ Feature'
|
|
||||||
patch:
|
|
||||||
labels:
|
|
||||||
- 'patch'
|
|
||||||
- '📒 Documentation'
|
|
||||||
- '☢️ Bug'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- '🧹 Updates'
|
|
||||||
default: patch
|
|
||||||
template: |
|
|
||||||
$CHANGES
|
|
||||||
|
|
||||||
**Full Changelog**: https://github.com/$OWNER/$REPOSITORY/compare/$PREVIOUS_TAG...bbolt/v$RESOLVED_VERSION
|
|
||||||
|
|
||||||
Thank you $CONTRIBUTORS for making this update possible.
|
|
50
.github/release-drafter-clickhouse.yml
vendored
50
.github/release-drafter-clickhouse.yml
vendored
@@ -1,50 +0,0 @@
|
|||||||
name-template: 'ClickHouse - v$RESOLVED_VERSION'
|
|
||||||
tag-template: 'clickhouse/v$RESOLVED_VERSION'
|
|
||||||
tag-prefix: clickhouse/v
|
|
||||||
include-paths:
|
|
||||||
- clickhouse
|
|
||||||
categories:
|
|
||||||
- title: '❗ Breaking Changes'
|
|
||||||
labels:
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
- title: '🚀 New'
|
|
||||||
labels:
|
|
||||||
- '✏️ Feature'
|
|
||||||
- title: '🧹 Updates'
|
|
||||||
labels:
|
|
||||||
- '🧹 Updates'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- title: '🐛 Fixes'
|
|
||||||
labels:
|
|
||||||
- '☢️ Bug'
|
|
||||||
- title: '📚 Documentation'
|
|
||||||
labels:
|
|
||||||
- '📒 Documentation'
|
|
||||||
change-template: '- $TITLE (#$NUMBER)'
|
|
||||||
change-title-escapes: '\<*_&' # You can add # and @ to disable mentions, and add ` to disable code blocks.
|
|
||||||
exclude-contributors:
|
|
||||||
- dependabot
|
|
||||||
- dependabot[bot]
|
|
||||||
version-resolver:
|
|
||||||
major:
|
|
||||||
labels:
|
|
||||||
- 'major'
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
minor:
|
|
||||||
labels:
|
|
||||||
- 'minor'
|
|
||||||
- '✏️ Feature'
|
|
||||||
patch:
|
|
||||||
labels:
|
|
||||||
- 'patch'
|
|
||||||
- '📒 Documentation'
|
|
||||||
- '☢️ Bug'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- '🧹 Updates'
|
|
||||||
default: patch
|
|
||||||
template: |
|
|
||||||
$CHANGES
|
|
||||||
|
|
||||||
**Full Changelog**: https://github.com/$OWNER/$REPOSITORY/compare/$PREVIOUS_TAG...clickhouse/v$RESOLVED_VERSION
|
|
||||||
|
|
||||||
Thank you $CONTRIBUTORS for making this update possible.
|
|
46
.github/release-drafter-cloudflarekv.yml
vendored
46
.github/release-drafter-cloudflarekv.yml
vendored
@@ -1,46 +0,0 @@
|
|||||||
name-template: "CloudflareKV - v$RESOLVED_VERSION"
|
|
||||||
tag-template: "cloudflarekv/v$RESOLVED_VERSION"
|
|
||||||
tag-prefix: cloudflarekv/v
|
|
||||||
include-paths:
|
|
||||||
- cloudflarekv
|
|
||||||
categories:
|
|
||||||
- title: "🚀 New"
|
|
||||||
labels:
|
|
||||||
- "✏️ Feature"
|
|
||||||
- title: "🧹 Updates"
|
|
||||||
labels:
|
|
||||||
- "🧹 Updates"
|
|
||||||
- "🤖 Dependencies"
|
|
||||||
- title: "🐛 Fixes"
|
|
||||||
labels:
|
|
||||||
- "☢️ Bug"
|
|
||||||
- title: "📚 Documentation"
|
|
||||||
labels:
|
|
||||||
- "📒 Documentation"
|
|
||||||
change-template: "- $TITLE (#$NUMBER)"
|
|
||||||
change-title-escapes: '\<*_&' # You can add # and @ to disable mentions, and add ` to disable code blocks.
|
|
||||||
exclude-contributors:
|
|
||||||
- dependabot
|
|
||||||
- dependabot[bot]
|
|
||||||
version-resolver:
|
|
||||||
major:
|
|
||||||
labels:
|
|
||||||
- "major"
|
|
||||||
minor:
|
|
||||||
labels:
|
|
||||||
- "minor"
|
|
||||||
- "✏️ Feature"
|
|
||||||
patch:
|
|
||||||
labels:
|
|
||||||
- "patch"
|
|
||||||
- "📒 Documentation"
|
|
||||||
- "☢️ Bug"
|
|
||||||
- "🤖 Dependencies"
|
|
||||||
- "🧹 Updates"
|
|
||||||
default: patch
|
|
||||||
template: |
|
|
||||||
$CHANGES
|
|
||||||
|
|
||||||
**Full Changelog**: https://github.com/$OWNER/$REPOSITORY/compare/$PREVIOUS_TAG...cloudflarekv/v$RESOLVED_VERSION
|
|
||||||
|
|
||||||
Thank you $CONTRIBUTORS for making this update possible.
|
|
50
.github/release-drafter-coherence.yml
vendored
50
.github/release-drafter-coherence.yml
vendored
@@ -1,50 +0,0 @@
|
|||||||
name-template: 'Coherence - v$RESOLVED_VERSION'
|
|
||||||
tag-template: 'coherence/v$RESOLVED_VERSION'
|
|
||||||
tag-prefix: coherence/v
|
|
||||||
include-paths:
|
|
||||||
- coherence
|
|
||||||
categories:
|
|
||||||
- title: '❗ Breaking Changes'
|
|
||||||
labels:
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
- title: '🚀 New'
|
|
||||||
labels:
|
|
||||||
- '✏️ Feature'
|
|
||||||
- title: '🧹 Updates'
|
|
||||||
labels:
|
|
||||||
- '🧹 Updates'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- title: '🐛 Fixes'
|
|
||||||
labels:
|
|
||||||
- '☢️ Bug'
|
|
||||||
- title: '📚 Documentation'
|
|
||||||
labels:
|
|
||||||
- '📒 Documentation'
|
|
||||||
change-template: '- $TITLE (#$NUMBER)'
|
|
||||||
change-title-escapes: '\<*_&' # You can add # and @ to disable mentions, and add ` to disable code blocks.
|
|
||||||
exclude-contributors:
|
|
||||||
- dependabot
|
|
||||||
- dependabot[bot]
|
|
||||||
version-resolver:
|
|
||||||
major:
|
|
||||||
labels:
|
|
||||||
- 'major'
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
minor:
|
|
||||||
labels:
|
|
||||||
- 'minor'
|
|
||||||
- '✏️ Feature'
|
|
||||||
patch:
|
|
||||||
labels:
|
|
||||||
- 'patch'
|
|
||||||
- '📒 Documentation'
|
|
||||||
- '☢️ Bug'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- '🧹 Updates'
|
|
||||||
default: patch
|
|
||||||
template: |
|
|
||||||
$CHANGES
|
|
||||||
|
|
||||||
**Full Changelog**: https://github.com/$OWNER/$REPOSITORY/compare/$PREVIOUS_TAG...coherence/v$RESOLVED_VERSION
|
|
||||||
|
|
||||||
Thank you $CONTRIBUTORS for making this update possible.
|
|
50
.github/release-drafter-couchbase.yml
vendored
50
.github/release-drafter-couchbase.yml
vendored
@@ -1,50 +0,0 @@
|
|||||||
name-template: 'Couchbase - v$RESOLVED_VERSION'
|
|
||||||
tag-template: 'couchbase/v$RESOLVED_VERSION'
|
|
||||||
tag-prefix: couchbase/v
|
|
||||||
include-paths:
|
|
||||||
- couchbase
|
|
||||||
categories:
|
|
||||||
- title: '❗ Breaking Changes'
|
|
||||||
labels:
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
- title: '🚀 New'
|
|
||||||
labels:
|
|
||||||
- '✏️ Feature'
|
|
||||||
- title: '🧹 Updates'
|
|
||||||
labels:
|
|
||||||
- '🧹 Updates'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- title: '🐛 Fixes'
|
|
||||||
labels:
|
|
||||||
- '☢️ Bug'
|
|
||||||
- title: '📚 Documentation'
|
|
||||||
labels:
|
|
||||||
- '📒 Documentation'
|
|
||||||
change-template: '- $TITLE (#$NUMBER)'
|
|
||||||
change-title-escapes: '\<*_&' # You can add # and @ to disable mentions, and add ` to disable code blocks.
|
|
||||||
exclude-contributors:
|
|
||||||
- dependabot
|
|
||||||
- dependabot[bot]
|
|
||||||
version-resolver:
|
|
||||||
major:
|
|
||||||
labels:
|
|
||||||
- 'major'
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
minor:
|
|
||||||
labels:
|
|
||||||
- 'minor'
|
|
||||||
- '✏️ Feature'
|
|
||||||
patch:
|
|
||||||
labels:
|
|
||||||
- 'patch'
|
|
||||||
- '📒 Documentation'
|
|
||||||
- '☢️ Bug'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- '🧹 Updates'
|
|
||||||
default: patch
|
|
||||||
template: |
|
|
||||||
$CHANGES
|
|
||||||
|
|
||||||
**Full Changelog**: https://github.com/$OWNER/$REPOSITORY/compare/$PREVIOUS_TAG...couchbase/v$RESOLVED_VERSION
|
|
||||||
|
|
||||||
Thank you $CONTRIBUTORS for making this update possible.
|
|
50
.github/release-drafter-dynamodb.yml
vendored
50
.github/release-drafter-dynamodb.yml
vendored
@@ -1,50 +0,0 @@
|
|||||||
name-template: 'DynamoDB - v$RESOLVED_VERSION'
|
|
||||||
tag-template: 'dynamodb/v$RESOLVED_VERSION'
|
|
||||||
tag-prefix: dynamodb/v
|
|
||||||
include-paths:
|
|
||||||
- dynamodb
|
|
||||||
categories:
|
|
||||||
- title: '❗ Breaking Changes'
|
|
||||||
labels:
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
- title: '🚀 New'
|
|
||||||
labels:
|
|
||||||
- '✏️ Feature'
|
|
||||||
- title: '🧹 Updates'
|
|
||||||
labels:
|
|
||||||
- '🧹 Updates'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- title: '🐛 Fixes'
|
|
||||||
labels:
|
|
||||||
- '☢️ Bug'
|
|
||||||
- title: '📚 Documentation'
|
|
||||||
labels:
|
|
||||||
- '📒 Documentation'
|
|
||||||
change-template: '- $TITLE (#$NUMBER)'
|
|
||||||
change-title-escapes: '\<*_&' # You can add # and @ to disable mentions, and add ` to disable code blocks.
|
|
||||||
exclude-contributors:
|
|
||||||
- dependabot
|
|
||||||
- dependabot[bot]
|
|
||||||
version-resolver:
|
|
||||||
major:
|
|
||||||
labels:
|
|
||||||
- 'major'
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
minor:
|
|
||||||
labels:
|
|
||||||
- 'minor'
|
|
||||||
- '✏️ Feature'
|
|
||||||
patch:
|
|
||||||
labels:
|
|
||||||
- 'patch'
|
|
||||||
- '📒 Documentation'
|
|
||||||
- '☢️ Bug'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- '🧹 Updates'
|
|
||||||
default: patch
|
|
||||||
template: |
|
|
||||||
$CHANGES
|
|
||||||
|
|
||||||
**Full Changelog**: https://github.com/$OWNER/$REPOSITORY/compare/$PREVIOUS_TAG...dynamodb/v$RESOLVED_VERSION
|
|
||||||
|
|
||||||
Thank you $CONTRIBUTORS for making this update possible.
|
|
50
.github/release-drafter-etcd.yml
vendored
50
.github/release-drafter-etcd.yml
vendored
@@ -1,50 +0,0 @@
|
|||||||
name-template: 'Etcd - v$RESOLVED_VERSION'
|
|
||||||
tag-template: 'etcd/v$RESOLVED_VERSION'
|
|
||||||
tag-prefix: etcd/v
|
|
||||||
include-paths:
|
|
||||||
- etcd
|
|
||||||
categories:
|
|
||||||
- title: '❗ Breaking Changes'
|
|
||||||
labels:
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
- title: '🚀 New'
|
|
||||||
labels:
|
|
||||||
- '✏️ Feature'
|
|
||||||
- title: '🧹 Updates'
|
|
||||||
labels:
|
|
||||||
- '🧹 Updates'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- title: '🐛 Fixes'
|
|
||||||
labels:
|
|
||||||
- '☢️ Bug'
|
|
||||||
- title: '📚 Documentation'
|
|
||||||
labels:
|
|
||||||
- '📒 Documentation'
|
|
||||||
change-template: '- $TITLE (#$NUMBER)'
|
|
||||||
change-title-escapes: '\<*_&' # You can add # and @ to disable mentions, and add ` to disable code blocks.
|
|
||||||
exclude-contributors:
|
|
||||||
- dependabot
|
|
||||||
- dependabot[bot]
|
|
||||||
version-resolver:
|
|
||||||
major:
|
|
||||||
labels:
|
|
||||||
- 'major'
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
minor:
|
|
||||||
labels:
|
|
||||||
- 'minor'
|
|
||||||
- '✏️ Feature'
|
|
||||||
patch:
|
|
||||||
labels:
|
|
||||||
- 'patch'
|
|
||||||
- '📒 Documentation'
|
|
||||||
- '☢️ Bug'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- '🧹 Updates'
|
|
||||||
default: patch
|
|
||||||
template: |
|
|
||||||
$CHANGES
|
|
||||||
|
|
||||||
**Full Changelog**: https://github.com/$OWNER/$REPOSITORY/compare/$PREVIOUS_TAG...etcd/v$RESOLVED_VERSION
|
|
||||||
|
|
||||||
Thank you $CONTRIBUTORS for making this update possible.
|
|
50
.github/release-drafter-memcache.yml
vendored
50
.github/release-drafter-memcache.yml
vendored
@@ -1,50 +0,0 @@
|
|||||||
name-template: 'Memcache - v$RESOLVED_VERSION'
|
|
||||||
tag-template: 'memcache/v$RESOLVED_VERSION'
|
|
||||||
tag-prefix: memcache/v
|
|
||||||
include-paths:
|
|
||||||
- memcache
|
|
||||||
categories:
|
|
||||||
- title: '❗ Breaking Changes'
|
|
||||||
labels:
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
- title: '🚀 New'
|
|
||||||
labels:
|
|
||||||
- '✏️ Feature'
|
|
||||||
- title: '🧹 Updates'
|
|
||||||
labels:
|
|
||||||
- '🧹 Updates'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- title: '🐛 Fixes'
|
|
||||||
labels:
|
|
||||||
- '☢️ Bug'
|
|
||||||
- title: '📚 Documentation'
|
|
||||||
labels:
|
|
||||||
- '📒 Documentation'
|
|
||||||
change-template: '- $TITLE (#$NUMBER)'
|
|
||||||
change-title-escapes: '\<*_&' # You can add # and @ to disable mentions, and add ` to disable code blocks.
|
|
||||||
exclude-contributors:
|
|
||||||
- dependabot
|
|
||||||
- dependabot[bot]
|
|
||||||
version-resolver:
|
|
||||||
major:
|
|
||||||
labels:
|
|
||||||
- 'major'
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
minor:
|
|
||||||
labels:
|
|
||||||
- 'minor'
|
|
||||||
- '✏️ Feature'
|
|
||||||
patch:
|
|
||||||
labels:
|
|
||||||
- 'patch'
|
|
||||||
- '📒 Documentation'
|
|
||||||
- '☢️ Bug'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- '🧹 Updates'
|
|
||||||
default: patch
|
|
||||||
template: |
|
|
||||||
$CHANGES
|
|
||||||
|
|
||||||
**Full Changelog**: https://github.com/$OWNER/$REPOSITORY/compare/$PREVIOUS_TAG...memcache/v$RESOLVED_VERSION
|
|
||||||
|
|
||||||
Thank you $CONTRIBUTORS for making this update possible.
|
|
50
.github/release-drafter-memory.yml
vendored
50
.github/release-drafter-memory.yml
vendored
@@ -1,50 +0,0 @@
|
|||||||
name-template: 'Memory - v$RESOLVED_VERSION'
|
|
||||||
tag-template: 'memory/v$RESOLVED_VERSION'
|
|
||||||
tag-prefix: memory/v
|
|
||||||
include-paths:
|
|
||||||
- memory
|
|
||||||
categories:
|
|
||||||
- title: '❗ Breaking Changes'
|
|
||||||
labels:
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
- title: '🚀 New'
|
|
||||||
labels:
|
|
||||||
- '✏️ Feature'
|
|
||||||
- title: '🧹 Updates'
|
|
||||||
labels:
|
|
||||||
- '🧹 Updates'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- title: '🐛 Fixes'
|
|
||||||
labels:
|
|
||||||
- '☢️ Bug'
|
|
||||||
- title: '📚 Documentation'
|
|
||||||
labels:
|
|
||||||
- '📒 Documentation'
|
|
||||||
change-template: '- $TITLE (#$NUMBER)'
|
|
||||||
change-title-escapes: '\<*_&' # You can add # and @ to disable mentions, and add ` to disable code blocks.
|
|
||||||
exclude-contributors:
|
|
||||||
- dependabot
|
|
||||||
- dependabot[bot]
|
|
||||||
version-resolver:
|
|
||||||
major:
|
|
||||||
labels:
|
|
||||||
- 'major'
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
minor:
|
|
||||||
labels:
|
|
||||||
- 'minor'
|
|
||||||
- '✏️ Feature'
|
|
||||||
patch:
|
|
||||||
labels:
|
|
||||||
- 'patch'
|
|
||||||
- '📒 Documentation'
|
|
||||||
- '☢️ Bug'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- '🧹 Updates'
|
|
||||||
default: patch
|
|
||||||
template: |
|
|
||||||
$CHANGES
|
|
||||||
|
|
||||||
**Full Changelog**: https://github.com/$OWNER/$REPOSITORY/compare/$PREVIOUS_TAG...memory/v$RESOLVED_VERSION
|
|
||||||
|
|
||||||
Thank you $CONTRIBUTORS for making this update possible.
|
|
50
.github/release-drafter-minio.yml
vendored
50
.github/release-drafter-minio.yml
vendored
@@ -1,50 +0,0 @@
|
|||||||
name-template: 'Minio - v$RESOLVED_VERSION'
|
|
||||||
tag-template: 'minio/v$RESOLVED_VERSION'
|
|
||||||
tag-prefix: minio/v
|
|
||||||
include-paths:
|
|
||||||
- minio
|
|
||||||
categories:
|
|
||||||
- title: '❗ Breaking Changes'
|
|
||||||
labels:
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
- title: '🚀 New'
|
|
||||||
labels:
|
|
||||||
- '✏️ Feature'
|
|
||||||
- title: '🧹 Updates'
|
|
||||||
labels:
|
|
||||||
- '🧹 Updates'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- title: '🐛 Fixes'
|
|
||||||
labels:
|
|
||||||
- '☢️ Bug'
|
|
||||||
- title: '📚 Documentation'
|
|
||||||
labels:
|
|
||||||
- '📒 Documentation'
|
|
||||||
change-template: '- $TITLE (#$NUMBER)'
|
|
||||||
change-title-escapes: '\<*_&' # You can add # and @ to disable mentions, and add ` to disable code blocks.
|
|
||||||
exclude-contributors:
|
|
||||||
- dependabot
|
|
||||||
- dependabot[bot]
|
|
||||||
version-resolver:
|
|
||||||
major:
|
|
||||||
labels:
|
|
||||||
- 'major'
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
minor:
|
|
||||||
labels:
|
|
||||||
- 'minor'
|
|
||||||
- '✏️ Feature'
|
|
||||||
patch:
|
|
||||||
labels:
|
|
||||||
- 'patch'
|
|
||||||
- '📒 Documentation'
|
|
||||||
- '☢️ Bug'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- '🧹 Updates'
|
|
||||||
default: patch
|
|
||||||
template: |
|
|
||||||
$CHANGES
|
|
||||||
|
|
||||||
**Full Changelog**: https://github.com/$OWNER/$REPOSITORY/compare/$PREVIOUS_TAG...minio/v$RESOLVED_VERSION
|
|
||||||
|
|
||||||
Thank you $CONTRIBUTORS for making this update possible.
|
|
50
.github/release-drafter-mockstorage.yml
vendored
50
.github/release-drafter-mockstorage.yml
vendored
@@ -1,50 +0,0 @@
|
|||||||
name-template: 'MockStorage - v$RESOLVED_VERSION'
|
|
||||||
tag-template: 'mockstorage/v$RESOLVED_VERSION'
|
|
||||||
tag-prefix: mockstorage/v
|
|
||||||
include-paths:
|
|
||||||
- mockstorage
|
|
||||||
categories:
|
|
||||||
- title: '❗ Breaking Changes'
|
|
||||||
labels:
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
- title: '🚀 New'
|
|
||||||
labels:
|
|
||||||
- '✏️ Feature'
|
|
||||||
- title: '🧹 Updates'
|
|
||||||
labels:
|
|
||||||
- '🧹 Updates'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- title: '🐛 Fixes'
|
|
||||||
labels:
|
|
||||||
- '☢️ Bug'
|
|
||||||
- title: '📚 Documentation'
|
|
||||||
labels:
|
|
||||||
- '📒 Documentation'
|
|
||||||
change-template: '- $TITLE (#$NUMBER)'
|
|
||||||
change-title-escapes: '\<*_&' # You can add # and @ to disable mentions, and add ` to disable code blocks.
|
|
||||||
exclude-contributors:
|
|
||||||
- dependabot
|
|
||||||
- dependabot[bot]
|
|
||||||
version-resolver:
|
|
||||||
major:
|
|
||||||
labels:
|
|
||||||
- 'major'
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
minor:
|
|
||||||
labels:
|
|
||||||
- 'minor'
|
|
||||||
- '✏️ Feature'
|
|
||||||
patch:
|
|
||||||
labels:
|
|
||||||
- 'patch'
|
|
||||||
- '📒 Documentation'
|
|
||||||
- '☢️ Bug'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- '🧹 Updates'
|
|
||||||
default: patch
|
|
||||||
template: |
|
|
||||||
$CHANGES
|
|
||||||
|
|
||||||
**Full Changelog**: https://github.com/$OWNER/$REPOSITORY/compare/$PREVIOUS_TAG...mockstorage/v$RESOLVED_VERSION
|
|
||||||
|
|
||||||
Thank you $CONTRIBUTORS for making this update possible.
|
|
50
.github/release-drafter-mongodb.yml
vendored
50
.github/release-drafter-mongodb.yml
vendored
@@ -1,50 +0,0 @@
|
|||||||
name-template: 'MongoDB - v$RESOLVED_VERSION'
|
|
||||||
tag-template: 'mongodb/v$RESOLVED_VERSION'
|
|
||||||
tag-prefix: mongodb/v
|
|
||||||
include-paths:
|
|
||||||
- mongodb
|
|
||||||
categories:
|
|
||||||
- title: '❗ Breaking Changes'
|
|
||||||
labels:
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
- title: '🚀 New'
|
|
||||||
labels:
|
|
||||||
- '✏️ Feature'
|
|
||||||
- title: '🧹 Updates'
|
|
||||||
labels:
|
|
||||||
- '🧹 Updates'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- title: '🐛 Fixes'
|
|
||||||
labels:
|
|
||||||
- '☢️ Bug'
|
|
||||||
- title: '📚 Documentation'
|
|
||||||
labels:
|
|
||||||
- '📒 Documentation'
|
|
||||||
change-template: '- $TITLE (#$NUMBER)'
|
|
||||||
change-title-escapes: '\<*_&' # You can add # and @ to disable mentions, and add ` to disable code blocks.
|
|
||||||
exclude-contributors:
|
|
||||||
- dependabot
|
|
||||||
- dependabot[bot]
|
|
||||||
version-resolver:
|
|
||||||
major:
|
|
||||||
labels:
|
|
||||||
- 'major'
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
minor:
|
|
||||||
labels:
|
|
||||||
- 'minor'
|
|
||||||
- '✏️ Feature'
|
|
||||||
patch:
|
|
||||||
labels:
|
|
||||||
- 'patch'
|
|
||||||
- '📒 Documentation'
|
|
||||||
- '☢️ Bug'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- '🧹 Updates'
|
|
||||||
default: patch
|
|
||||||
template: |
|
|
||||||
$CHANGES
|
|
||||||
|
|
||||||
**Full Changelog**: https://github.com/$OWNER/$REPOSITORY/compare/$PREVIOUS_TAG...mongodb/v$RESOLVED_VERSION
|
|
||||||
|
|
||||||
Thank you $CONTRIBUTORS for making this update possible.
|
|
50
.github/release-drafter-mssql.yml
vendored
50
.github/release-drafter-mssql.yml
vendored
@@ -1,50 +0,0 @@
|
|||||||
name-template: 'MSSQL - v$RESOLVED_VERSION'
|
|
||||||
tag-template: 'mssql/v$RESOLVED_VERSION'
|
|
||||||
tag-prefix: mssql/v
|
|
||||||
include-paths:
|
|
||||||
- mssql
|
|
||||||
categories:
|
|
||||||
- title: '❗ Breaking Changes'
|
|
||||||
labels:
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
- title: '🚀 New'
|
|
||||||
labels:
|
|
||||||
- '✏️ Feature'
|
|
||||||
- title: '🧹 Updates'
|
|
||||||
labels:
|
|
||||||
- '🧹 Updates'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- title: '🐛 Fixes'
|
|
||||||
labels:
|
|
||||||
- '☢️ Bug'
|
|
||||||
- title: '📚 Documentation'
|
|
||||||
labels:
|
|
||||||
- '📒 Documentation'
|
|
||||||
change-template: '- $TITLE (#$NUMBER)'
|
|
||||||
change-title-escapes: '\<*_&' # You can add # and @ to disable mentions, and add ` to disable code blocks.
|
|
||||||
exclude-contributors:
|
|
||||||
- dependabot
|
|
||||||
- dependabot[bot]
|
|
||||||
version-resolver:
|
|
||||||
major:
|
|
||||||
labels:
|
|
||||||
- 'major'
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
minor:
|
|
||||||
labels:
|
|
||||||
- 'minor'
|
|
||||||
- '✏️ Feature'
|
|
||||||
patch:
|
|
||||||
labels:
|
|
||||||
- 'patch'
|
|
||||||
- '📒 Documentation'
|
|
||||||
- '☢️ Bug'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- '🧹 Updates'
|
|
||||||
default: patch
|
|
||||||
template: |
|
|
||||||
$CHANGES
|
|
||||||
|
|
||||||
**Full Changelog**: https://github.com/$OWNER/$REPOSITORY/compare/$PREVIOUS_TAG...mssql/v$RESOLVED_VERSION
|
|
||||||
|
|
||||||
Thank you $CONTRIBUTORS for making this update possible.
|
|
50
.github/release-drafter-mysql.yml
vendored
50
.github/release-drafter-mysql.yml
vendored
@@ -1,50 +0,0 @@
|
|||||||
name-template: 'MySQL - v$RESOLVED_VERSION'
|
|
||||||
tag-template: 'mysql/v$RESOLVED_VERSION'
|
|
||||||
tag-prefix: mysql/v
|
|
||||||
include-paths:
|
|
||||||
- mysql
|
|
||||||
categories:
|
|
||||||
- title: '❗ Breaking Changes'
|
|
||||||
labels:
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
- title: '🚀 New'
|
|
||||||
labels:
|
|
||||||
- '✏️ Feature'
|
|
||||||
- title: '🧹 Updates'
|
|
||||||
labels:
|
|
||||||
- '🧹 Updates'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- title: '🐛 Fixes'
|
|
||||||
labels:
|
|
||||||
- '☢️ Bug'
|
|
||||||
- title: '📚 Documentation'
|
|
||||||
labels:
|
|
||||||
- '📒 Documentation'
|
|
||||||
change-template: '- $TITLE (#$NUMBER)'
|
|
||||||
change-title-escapes: '\<*_&' # You can add # and @ to disable mentions, and add ` to disable code blocks.
|
|
||||||
exclude-contributors:
|
|
||||||
- dependabot
|
|
||||||
- dependabot[bot]
|
|
||||||
version-resolver:
|
|
||||||
major:
|
|
||||||
labels:
|
|
||||||
- 'major'
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
minor:
|
|
||||||
labels:
|
|
||||||
- 'minor'
|
|
||||||
- '✏️ Feature'
|
|
||||||
patch:
|
|
||||||
labels:
|
|
||||||
- 'patch'
|
|
||||||
- '📒 Documentation'
|
|
||||||
- '☢️ Bug'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- '🧹 Updates'
|
|
||||||
default: patch
|
|
||||||
template: |
|
|
||||||
$CHANGES
|
|
||||||
|
|
||||||
**Full Changelog**: https://github.com/$OWNER/$REPOSITORY/compare/$PREVIOUS_TAG...mysql/v$RESOLVED_VERSION
|
|
||||||
|
|
||||||
Thank you $CONTRIBUTORS for making this update possible.
|
|
50
.github/release-drafter-nats.yml
vendored
50
.github/release-drafter-nats.yml
vendored
@@ -1,50 +0,0 @@
|
|||||||
name-template: 'Nats - v$RESOLVED_VERSION'
|
|
||||||
tag-template: 'nats/v$RESOLVED_VERSION'
|
|
||||||
tag-prefix: nats/v
|
|
||||||
include-paths:
|
|
||||||
- nats
|
|
||||||
categories:
|
|
||||||
- title: '❗ Breaking Changes'
|
|
||||||
labels:
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
- title: '🚀 New'
|
|
||||||
labels:
|
|
||||||
- '✏️ Feature'
|
|
||||||
- title: '🧹 Updates'
|
|
||||||
labels:
|
|
||||||
- '🧹 Updates'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- title: '🐛 Fixes'
|
|
||||||
labels:
|
|
||||||
- '☢️ Bug'
|
|
||||||
- title: '📚 Documentation'
|
|
||||||
labels:
|
|
||||||
- '📒 Documentation'
|
|
||||||
change-template: '- $TITLE (#$NUMBER)'
|
|
||||||
change-title-escapes: '\<*_&' # You can add # and @ to disable mentions, and add ` to disable code blocks.
|
|
||||||
exclude-contributors:
|
|
||||||
- dependabot
|
|
||||||
- dependabot[bot]
|
|
||||||
version-resolver:
|
|
||||||
major:
|
|
||||||
labels:
|
|
||||||
- 'major'
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
minor:
|
|
||||||
labels:
|
|
||||||
- 'minor'
|
|
||||||
- '✏️ Feature'
|
|
||||||
patch:
|
|
||||||
labels:
|
|
||||||
- 'patch'
|
|
||||||
- '📒 Documentation'
|
|
||||||
- '☢️ Bug'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- '🧹 Updates'
|
|
||||||
default: patch
|
|
||||||
template: |
|
|
||||||
$CHANGES
|
|
||||||
|
|
||||||
**Full Changelog**: https://github.com/$OWNER/$REPOSITORY/compare/$PREVIOUS_TAG...nats/v$RESOLVED_VERSION
|
|
||||||
|
|
||||||
Thank you $CONTRIBUTORS for making this update possible.
|
|
50
.github/release-drafter-pebble.yml
vendored
50
.github/release-drafter-pebble.yml
vendored
@@ -1,50 +0,0 @@
|
|||||||
name-template: "Pebble - v$RESOLVED_VERSION"
|
|
||||||
tag-template: "pebble/v$RESOLVED_VERSION"
|
|
||||||
tag-prefix: pebble/v
|
|
||||||
include-paths:
|
|
||||||
- pebble
|
|
||||||
categories:
|
|
||||||
- title: '❗ Breaking Changes'
|
|
||||||
labels:
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
- title: '🚀 New'
|
|
||||||
labels:
|
|
||||||
- '✏️ Feature'
|
|
||||||
- title: '🧹 Updates'
|
|
||||||
labels:
|
|
||||||
- '🧹 Updates'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- title: '🐛 Fixes'
|
|
||||||
labels:
|
|
||||||
- '☢️ Bug'
|
|
||||||
- title: '📚 Documentation'
|
|
||||||
labels:
|
|
||||||
- '📒 Documentation'
|
|
||||||
change-template: '- $TITLE (#$NUMBER)'
|
|
||||||
change-title-escapes: '\<*_&' # You can add # and @ to disable mentions, and add ` to disable code blocks.
|
|
||||||
exclude-contributors:
|
|
||||||
- dependabot
|
|
||||||
- dependabot[bot]
|
|
||||||
version-resolver:
|
|
||||||
major:
|
|
||||||
labels:
|
|
||||||
- 'major'
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
minor:
|
|
||||||
labels:
|
|
||||||
- 'minor'
|
|
||||||
- '✏️ Feature'
|
|
||||||
patch:
|
|
||||||
labels:
|
|
||||||
- 'patch'
|
|
||||||
- '📒 Documentation'
|
|
||||||
- '☢️ Bug'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- '🧹 Updates'
|
|
||||||
default: patch
|
|
||||||
template: |
|
|
||||||
$CHANGES
|
|
||||||
|
|
||||||
**Full Changelog**: https://github.com/$OWNER/$REPOSITORY/compare/$PREVIOUS_TAG...pebble/v$RESOLVED_VERSION
|
|
||||||
|
|
||||||
Thank you $CONTRIBUTORS for making this update possible.
|
|
50
.github/release-drafter-postgres.yml
vendored
50
.github/release-drafter-postgres.yml
vendored
@@ -1,50 +0,0 @@
|
|||||||
name-template: 'Postgres - v$RESOLVED_VERSION'
|
|
||||||
tag-template: 'postgres/v$RESOLVED_VERSION'
|
|
||||||
tag-prefix: postgres/v
|
|
||||||
include-paths:
|
|
||||||
- postgres
|
|
||||||
categories:
|
|
||||||
- title: '❗ Breaking Changes'
|
|
||||||
labels:
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
- title: '🚀 New'
|
|
||||||
labels:
|
|
||||||
- '✏️ Feature'
|
|
||||||
- title: '🧹 Updates'
|
|
||||||
labels:
|
|
||||||
- '🧹 Updates'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- title: '🐛 Fixes'
|
|
||||||
labels:
|
|
||||||
- '☢️ Bug'
|
|
||||||
- title: '📚 Documentation'
|
|
||||||
labels:
|
|
||||||
- '📒 Documentation'
|
|
||||||
change-template: '- $TITLE (#$NUMBER)'
|
|
||||||
change-title-escapes: '\<*_&' # You can add # and @ to disable mentions, and add ` to disable code blocks.
|
|
||||||
exclude-contributors:
|
|
||||||
- dependabot
|
|
||||||
- dependabot[bot]
|
|
||||||
version-resolver:
|
|
||||||
major:
|
|
||||||
labels:
|
|
||||||
- 'major'
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
minor:
|
|
||||||
labels:
|
|
||||||
- 'minor'
|
|
||||||
- '✏️ Feature'
|
|
||||||
patch:
|
|
||||||
labels:
|
|
||||||
- 'patch'
|
|
||||||
- '📒 Documentation'
|
|
||||||
- '☢️ Bug'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- '🧹 Updates'
|
|
||||||
default: patch
|
|
||||||
template: |
|
|
||||||
$CHANGES
|
|
||||||
|
|
||||||
**Full Changelog**: https://github.com/$OWNER/$REPOSITORY/compare/$PREVIOUS_TAG...postgres/v$RESOLVED_VERSION
|
|
||||||
|
|
||||||
Thank you $CONTRIBUTORS for making this update possible.
|
|
50
.github/release-drafter-redis.yml
vendored
50
.github/release-drafter-redis.yml
vendored
@@ -1,50 +0,0 @@
|
|||||||
name-template: 'Redis - v$RESOLVED_VERSION'
|
|
||||||
tag-template: 'redis/v$RESOLVED_VERSION'
|
|
||||||
tag-prefix: redis/v
|
|
||||||
include-paths:
|
|
||||||
- redis
|
|
||||||
categories:
|
|
||||||
- title: '❗ Breaking Changes'
|
|
||||||
labels:
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
- title: '🚀 New'
|
|
||||||
labels:
|
|
||||||
- '✏️ Feature'
|
|
||||||
- title: '🧹 Updates'
|
|
||||||
labels:
|
|
||||||
- '🧹 Updates'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- title: '🐛 Fixes'
|
|
||||||
labels:
|
|
||||||
- '☢️ Bug'
|
|
||||||
- title: '📚 Documentation'
|
|
||||||
labels:
|
|
||||||
- '📒 Documentation'
|
|
||||||
change-template: '- $TITLE (#$NUMBER)'
|
|
||||||
change-title-escapes: '\<*_&' # You can add # and @ to disable mentions, and add ` to disable code blocks.
|
|
||||||
exclude-contributors:
|
|
||||||
- dependabot
|
|
||||||
- dependabot[bot]
|
|
||||||
version-resolver:
|
|
||||||
major:
|
|
||||||
labels:
|
|
||||||
- 'major'
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
minor:
|
|
||||||
labels:
|
|
||||||
- 'minor'
|
|
||||||
- '✏️ Feature'
|
|
||||||
patch:
|
|
||||||
labels:
|
|
||||||
- 'patch'
|
|
||||||
- '📒 Documentation'
|
|
||||||
- '☢️ Bug'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- '🧹 Updates'
|
|
||||||
default: patch
|
|
||||||
template: |
|
|
||||||
$CHANGES
|
|
||||||
|
|
||||||
**Full Changelog**: https://github.com/$OWNER/$REPOSITORY/compare/$PREVIOUS_TAG...redis/v$RESOLVED_VERSION
|
|
||||||
|
|
||||||
Thank you $CONTRIBUTORS for making this update possible.
|
|
50
.github/release-drafter-ristretto.yml
vendored
50
.github/release-drafter-ristretto.yml
vendored
@@ -1,50 +0,0 @@
|
|||||||
name-template: 'Ristretto - v$RESOLVED_VERSION'
|
|
||||||
tag-template: 'ristretto/v$RESOLVED_VERSION'
|
|
||||||
tag-prefix: ristretto/v
|
|
||||||
include-paths:
|
|
||||||
- ristretto
|
|
||||||
categories:
|
|
||||||
- title: '❗ Breaking Changes'
|
|
||||||
labels:
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
- title: '🚀 New'
|
|
||||||
labels:
|
|
||||||
- '✏️ Feature'
|
|
||||||
- title: '🧹 Updates'
|
|
||||||
labels:
|
|
||||||
- '🧹 Updates'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- title: '🐛 Fixes'
|
|
||||||
labels:
|
|
||||||
- '☢️ Bug'
|
|
||||||
- title: '📚 Documentation'
|
|
||||||
labels:
|
|
||||||
- '📒 Documentation'
|
|
||||||
change-template: '- $TITLE (#$NUMBER)'
|
|
||||||
change-title-escapes: '\<*_&' # You can add # and @ to disable mentions, and add ` to disable code blocks.
|
|
||||||
exclude-contributors:
|
|
||||||
- dependabot
|
|
||||||
- dependabot[bot]
|
|
||||||
version-resolver:
|
|
||||||
major:
|
|
||||||
labels:
|
|
||||||
- 'major'
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
minor:
|
|
||||||
labels:
|
|
||||||
- 'minor'
|
|
||||||
- '✏️ Feature'
|
|
||||||
patch:
|
|
||||||
labels:
|
|
||||||
- 'patch'
|
|
||||||
- '📒 Documentation'
|
|
||||||
- '☢️ Bug'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- '🧹 Updates'
|
|
||||||
default: patch
|
|
||||||
template: |
|
|
||||||
$CHANGES
|
|
||||||
|
|
||||||
**Full Changelog**: https://github.com/$OWNER/$REPOSITORY/compare/$PREVIOUS_TAG...ristretto/v$RESOLVED_VERSION
|
|
||||||
|
|
||||||
Thank you $CONTRIBUTORS for making this update possible.
|
|
50
.github/release-drafter-rueidis.yml
vendored
50
.github/release-drafter-rueidis.yml
vendored
@@ -1,50 +0,0 @@
|
|||||||
name-template: 'Rueidis - v$RESOLVED_VERSION'
|
|
||||||
tag-template: 'rueidis/v$RESOLVED_VERSION'
|
|
||||||
tag-prefix: rueidis/v
|
|
||||||
include-paths:
|
|
||||||
- rueidis
|
|
||||||
categories:
|
|
||||||
- title: '❗ Breaking Changes'
|
|
||||||
labels:
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
- title: '🚀 New'
|
|
||||||
labels:
|
|
||||||
- '✏️ Feature'
|
|
||||||
- title: '🧹 Updates'
|
|
||||||
labels:
|
|
||||||
- '🧹 Updates'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- title: '🐛 Fixes'
|
|
||||||
labels:
|
|
||||||
- '☢️ Bug'
|
|
||||||
- title: '📚 Documentation'
|
|
||||||
labels:
|
|
||||||
- '📒 Documentation'
|
|
||||||
change-template: '- $TITLE (#$NUMBER)'
|
|
||||||
change-title-escapes: '\<*_&' # You can add # and @ to disable mentions, and add ` to disable code blocks.
|
|
||||||
exclude-contributors:
|
|
||||||
- dependabot
|
|
||||||
- dependabot[bot]
|
|
||||||
version-resolver:
|
|
||||||
major:
|
|
||||||
labels:
|
|
||||||
- 'major'
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
minor:
|
|
||||||
labels:
|
|
||||||
- 'minor'
|
|
||||||
- '✏️ Feature'
|
|
||||||
patch:
|
|
||||||
labels:
|
|
||||||
- 'patch'
|
|
||||||
- '📒 Documentation'
|
|
||||||
- '☢️ Bug'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- '🧹 Updates'
|
|
||||||
default: patch
|
|
||||||
template: |
|
|
||||||
$CHANGES
|
|
||||||
|
|
||||||
**Full Changelog**: https://github.com/$OWNER/$REPOSITORY/compare/$PREVIOUS_TAG...rueidis/v$RESOLVED_VERSION
|
|
||||||
|
|
||||||
Thank you $CONTRIBUTORS for making this update possible.
|
|
50
.github/release-drafter-s3.yml
vendored
50
.github/release-drafter-s3.yml
vendored
@@ -1,50 +0,0 @@
|
|||||||
name-template: 'S3 - v$RESOLVED_VERSION'
|
|
||||||
tag-template: 's3/v$RESOLVED_VERSION'
|
|
||||||
tag-prefix: s3/v
|
|
||||||
include-paths:
|
|
||||||
- s3
|
|
||||||
categories:
|
|
||||||
- title: '❗ Breaking Changes'
|
|
||||||
labels:
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
- title: '🚀 New'
|
|
||||||
labels:
|
|
||||||
- '✏️ Feature'
|
|
||||||
- title: '🧹 Updates'
|
|
||||||
labels:
|
|
||||||
- '🧹 Updates'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- title: '🐛 Fixes'
|
|
||||||
labels:
|
|
||||||
- '☢️ Bug'
|
|
||||||
- title: '📚 Documentation'
|
|
||||||
labels:
|
|
||||||
- '📒 Documentation'
|
|
||||||
change-template: '- $TITLE (#$NUMBER)'
|
|
||||||
change-title-escapes: '\<*_&' # You can add # and @ to disable mentions, and add ` to disable code blocks.
|
|
||||||
exclude-contributors:
|
|
||||||
- dependabot
|
|
||||||
- dependabot[bot]
|
|
||||||
version-resolver:
|
|
||||||
major:
|
|
||||||
labels:
|
|
||||||
- 'major'
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
minor:
|
|
||||||
labels:
|
|
||||||
- 'minor'
|
|
||||||
- '✏️ Feature'
|
|
||||||
patch:
|
|
||||||
labels:
|
|
||||||
- 'patch'
|
|
||||||
- '📒 Documentation'
|
|
||||||
- '☢️ Bug'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- '🧹 Updates'
|
|
||||||
default: patch
|
|
||||||
template: |
|
|
||||||
$CHANGES
|
|
||||||
|
|
||||||
**Full Changelog**: https://github.com/$OWNER/$REPOSITORY/compare/$PREVIOUS_TAG...s3/v$RESOLVED_VERSION
|
|
||||||
|
|
||||||
Thank you $CONTRIBUTORS for making this update possible.
|
|
50
.github/release-drafter-scylladb.yml
vendored
50
.github/release-drafter-scylladb.yml
vendored
@@ -1,50 +0,0 @@
|
|||||||
name-template: 'ScyllaDb - v$RESOLVED_VERSION'
|
|
||||||
tag-template: 'scylladb/v$RESOLVED_VERSION'
|
|
||||||
tag-prefix: scylladb/v
|
|
||||||
include-paths:
|
|
||||||
- scylladb
|
|
||||||
categories:
|
|
||||||
- title: '❗ Breaking Changes'
|
|
||||||
labels:
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
- title: '🚀 New'
|
|
||||||
labels:
|
|
||||||
- '✏️ Feature'
|
|
||||||
- title: '🧹 Updates'
|
|
||||||
labels:
|
|
||||||
- '🧹 Updates'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- title: '🐛 Fixes'
|
|
||||||
labels:
|
|
||||||
- '☢️ Bug'
|
|
||||||
- title: '📚 Documentation'
|
|
||||||
labels:
|
|
||||||
- '📒 Documentation'
|
|
||||||
change-template: '- $TITLE (#$NUMBER)'
|
|
||||||
change-title-escapes: '\<*_&' # You can add # and @ to disable mentions, and add ` to disable code blocks.
|
|
||||||
exclude-contributors:
|
|
||||||
- dependabot
|
|
||||||
- dependabot[bot]
|
|
||||||
version-resolver:
|
|
||||||
major:
|
|
||||||
labels:
|
|
||||||
- 'major'
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
minor:
|
|
||||||
labels:
|
|
||||||
- 'minor'
|
|
||||||
- '✏️ Feature'
|
|
||||||
patch:
|
|
||||||
labels:
|
|
||||||
- 'patch'
|
|
||||||
- '📒 Documentation'
|
|
||||||
- '☢️ Bug'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- '🧹 Updates'
|
|
||||||
default: patch
|
|
||||||
template: |
|
|
||||||
$CHANGES
|
|
||||||
|
|
||||||
**Full Changelog**: https://github.com/$OWNER/$REPOSITORY/compare/$PREVIOUS_TAG...scylladb/v$RESOLVED_VERSION
|
|
||||||
|
|
||||||
Thank you $CONTRIBUTORS for making this update possible.
|
|
50
.github/release-drafter-sqlite3.yml
vendored
50
.github/release-drafter-sqlite3.yml
vendored
@@ -1,50 +0,0 @@
|
|||||||
name-template: 'SQLite3 - v$RESOLVED_VERSION'
|
|
||||||
tag-template: 'sqlite3/v$RESOLVED_VERSION'
|
|
||||||
tag-prefix: sqlite3/v
|
|
||||||
include-paths:
|
|
||||||
- sqlite3
|
|
||||||
categories:
|
|
||||||
- title: '❗ Breaking Changes'
|
|
||||||
labels:
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
- title: '🚀 New'
|
|
||||||
labels:
|
|
||||||
- '✏️ Feature'
|
|
||||||
- title: '🧹 Updates'
|
|
||||||
labels:
|
|
||||||
- '🧹 Updates'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- title: '🐛 Fixes'
|
|
||||||
labels:
|
|
||||||
- '☢️ Bug'
|
|
||||||
- title: '📚 Documentation'
|
|
||||||
labels:
|
|
||||||
- '📒 Documentation'
|
|
||||||
change-template: '- $TITLE (#$NUMBER)'
|
|
||||||
change-title-escapes: '\<*_&' # You can add # and @ to disable mentions, and add ` to disable code blocks.
|
|
||||||
exclude-contributors:
|
|
||||||
- dependabot
|
|
||||||
- dependabot[bot]
|
|
||||||
version-resolver:
|
|
||||||
major:
|
|
||||||
labels:
|
|
||||||
- 'major'
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
minor:
|
|
||||||
labels:
|
|
||||||
- 'minor'
|
|
||||||
- '✏️ Feature'
|
|
||||||
patch:
|
|
||||||
labels:
|
|
||||||
- 'patch'
|
|
||||||
- '📒 Documentation'
|
|
||||||
- '☢️ Bug'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- '🧹 Updates'
|
|
||||||
default: patch
|
|
||||||
template: |
|
|
||||||
$CHANGES
|
|
||||||
|
|
||||||
**Full Changelog**: https://github.com/$OWNER/$REPOSITORY/compare/$PREVIOUS_TAG...sqlite3/v$RESOLVED_VERSION
|
|
||||||
|
|
||||||
Thank you $CONTRIBUTORS for making this update possible.
|
|
@@ -1,8 +1,8 @@
|
|||||||
name-template: 'ArangoDB - v$RESOLVED_VERSION'
|
name-template: '{{FOLDER}} - v$RESOLVED_VERSION'
|
||||||
tag-template: 'arangodb/v$RESOLVED_VERSION'
|
tag-template: '{{FOLDER}}/v$RESOLVED_VERSION'
|
||||||
tag-prefix: arangodb/v
|
tag-prefix: {{FOLDER}}/v
|
||||||
include-paths:
|
include-paths:
|
||||||
- arangodb
|
- {{FOLDER}}
|
||||||
categories:
|
categories:
|
||||||
- title: '❗ Breaking Changes'
|
- title: '❗ Breaking Changes'
|
||||||
labels:
|
labels:
|
||||||
@@ -45,6 +45,6 @@ version-resolver:
|
|||||||
template: |
|
template: |
|
||||||
$CHANGES
|
$CHANGES
|
||||||
|
|
||||||
**Full Changelog**: https://github.com/$OWNER/$REPOSITORY/compare/$PREVIOUS_TAG...arangodb/v$RESOLVED_VERSION
|
**Full Changelog**: https://github.com/$OWNER/$REPOSITORY/compare/$PREVIOUS_TAG...{{FOLDER}}/v$RESOLVED_VERSION
|
||||||
|
|
||||||
Thank you $CONTRIBUTORS for making this update possible.
|
Thank you $CONTRIBUTORS for making this update possible.
|
50
.github/release-drafter-valkey.yml
vendored
50
.github/release-drafter-valkey.yml
vendored
@@ -1,50 +0,0 @@
|
|||||||
name-template: 'Valkey - v$RESOLVED_VERSION'
|
|
||||||
tag-template: 'valkey/v$RESOLVED_VERSION'
|
|
||||||
tag-prefix: valkey/v
|
|
||||||
include-paths:
|
|
||||||
- valkey
|
|
||||||
categories:
|
|
||||||
- title: '❗ Breaking Changes'
|
|
||||||
labels:
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
- title: '🚀 New'
|
|
||||||
labels:
|
|
||||||
- '✏️ Feature'
|
|
||||||
- title: '🧹 Updates'
|
|
||||||
labels:
|
|
||||||
- '🧹 Updates'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- title: '🐛 Fixes'
|
|
||||||
labels:
|
|
||||||
- '☢️ Bug'
|
|
||||||
- title: '📚 Documentation'
|
|
||||||
labels:
|
|
||||||
- '📒 Documentation'
|
|
||||||
change-template: '- $TITLE (#$NUMBER)'
|
|
||||||
change-title-escapes: '\<*_&' # You can add # and @ to disable mentions, and add ` to disable code blocks.
|
|
||||||
exclude-contributors:
|
|
||||||
- dependabot
|
|
||||||
- dependabot[bot]
|
|
||||||
version-resolver:
|
|
||||||
major:
|
|
||||||
labels:
|
|
||||||
- 'major'
|
|
||||||
- '❗ BreakingChange'
|
|
||||||
minor:
|
|
||||||
labels:
|
|
||||||
- 'minor'
|
|
||||||
- '✏️ Feature'
|
|
||||||
patch:
|
|
||||||
labels:
|
|
||||||
- 'patch'
|
|
||||||
- '📒 Documentation'
|
|
||||||
- '☢️ Bug'
|
|
||||||
- '🤖 Dependencies'
|
|
||||||
- '🧹 Updates'
|
|
||||||
default: patch
|
|
||||||
template: |
|
|
||||||
$CHANGES
|
|
||||||
|
|
||||||
**Full Changelog**: https://github.com/$OWNER/$REPOSITORY/compare/$PREVIOUS_TAG...valkey/v$RESOLVED_VERSION
|
|
||||||
|
|
||||||
Thank you $CONTRIBUTORS for making this update possible.
|
|
27
.github/release.yml
vendored
Normal file
27
.github/release.yml
vendored
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
# .github/release.yml
|
||||||
|
|
||||||
|
changelog:
|
||||||
|
categories:
|
||||||
|
- title: '❗ Breaking Changes'
|
||||||
|
labels:
|
||||||
|
- '❗ BreakingChange'
|
||||||
|
- title: '🚀 New Features'
|
||||||
|
labels:
|
||||||
|
- '✏️ Feature'
|
||||||
|
- '📝 Proposal'
|
||||||
|
- title: '🧹 Updates'
|
||||||
|
labels:
|
||||||
|
- '🧹 Updates'
|
||||||
|
- '⚡️ Performance'
|
||||||
|
- title: '🐛 Bug Fixes'
|
||||||
|
labels:
|
||||||
|
- '☢️ Bug'
|
||||||
|
- title: '🛠️ Maintenance'
|
||||||
|
labels:
|
||||||
|
- '🤖 Dependencies'
|
||||||
|
- title: '📚 Documentation'
|
||||||
|
labels:
|
||||||
|
- '📒 Documentation'
|
||||||
|
- title: 'Other Changes'
|
||||||
|
labels:
|
||||||
|
- '*'
|
158
.github/workflows/benchmark.yml
vendored
158
.github/workflows/benchmark.yml
vendored
@@ -17,67 +17,40 @@ permissions:
|
|||||||
|
|
||||||
name: Benchmark
|
name: Benchmark
|
||||||
jobs:
|
jobs:
|
||||||
Compare:
|
changes:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
services:
|
permissions:
|
||||||
arangodb:
|
pull-requests: read
|
||||||
image: 'arangodb:latest'
|
steps:
|
||||||
env:
|
- name: Checkout repository
|
||||||
ARANGO_NO_AUTH: 1
|
uses: actions/checkout@v4
|
||||||
ports:
|
|
||||||
- '8529:8529'
|
|
||||||
dynamodb:
|
|
||||||
image: 'amazon/dynamodb-local:latest'
|
|
||||||
ports:
|
|
||||||
- '8000:8000'
|
|
||||||
memcached:
|
|
||||||
image: 'memcached:latest'
|
|
||||||
ports:
|
|
||||||
- '11211:11211'
|
|
||||||
mongo:
|
|
||||||
image: 'mongo:latest'
|
|
||||||
ports:
|
|
||||||
- '27017:27017'
|
|
||||||
mssql:
|
|
||||||
image: 'mcmoe/mssqldocker:latest'
|
|
||||||
ports:
|
|
||||||
- '1433:1433'
|
|
||||||
env:
|
|
||||||
ACCEPT_EULA: Y
|
|
||||||
SA_PASSWORD: MsSql!1234
|
|
||||||
MSSQL_DB: master
|
|
||||||
MSSQL_USER: sa
|
|
||||||
MSSQL_PASSWORD: MsSql!1234
|
|
||||||
options: >-
|
|
||||||
--health-cmd "/opt/mssql-tools/bin/sqlcmd -U sa -P $SA_PASSWORD -Q 'select 1' -b -o /dev/null"
|
|
||||||
--health-interval 1s
|
|
||||||
--health-timeout 30s
|
|
||||||
--health-start-period 10s
|
|
||||||
--health-retries 20
|
|
||||||
mysql:
|
|
||||||
image: 'mysql:latest'
|
|
||||||
env:
|
|
||||||
MYSQL_DATABASE: fiber
|
|
||||||
MYSQL_USER: username
|
|
||||||
MYSQL_PASSWORD: password
|
|
||||||
MYSQL_ROOT_PASSWORD: password
|
|
||||||
ports:
|
|
||||||
- '3306:3306'
|
|
||||||
options: >-
|
|
||||||
--health-cmd "mysqladmin ping" --health-interval 10s --health-timeout
|
|
||||||
5s --health-retries 5
|
|
||||||
postgres:
|
|
||||||
image: 'postgres:latest'
|
|
||||||
ports:
|
|
||||||
- '5432:5432'
|
|
||||||
env:
|
|
||||||
POSTGRES_DB: fiber
|
|
||||||
POSTGRES_USER: username
|
|
||||||
POSTGRES_PASSWORD: "pass#w%rd"
|
|
||||||
options: >-
|
|
||||||
--health-cmd pg_isready --health-interval 10s --health-timeout 5s
|
|
||||||
--health-retries 5
|
|
||||||
|
|
||||||
|
- name: Generate filters
|
||||||
|
id: filter-setup
|
||||||
|
run: |
|
||||||
|
filters=$(find . -maxdepth 1 -type d ! -path ./.git ! -path . -exec basename {} \; | grep -v '^\.' | awk '{printf "%s: \"%s/**\"\n", $1, $1}')
|
||||||
|
echo "filters<<EOF" >> $GITHUB_OUTPUT
|
||||||
|
echo "$filters" >> $GITHUB_OUTPUT
|
||||||
|
echo "EOF" >> $GITHUB_OUTPUT
|
||||||
|
shell: bash
|
||||||
|
|
||||||
|
- name: Filter changes
|
||||||
|
id: filter
|
||||||
|
uses: dorny/paths-filter@v3
|
||||||
|
with:
|
||||||
|
filters: ${{ steps.filter-setup.outputs.filters }}
|
||||||
|
outputs:
|
||||||
|
packages: ${{ steps.filter.outputs.changes || '[]' }}
|
||||||
|
|
||||||
|
compare:
|
||||||
|
needs: changes
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
timeout-minutes: 30
|
||||||
|
if: needs.changes.outputs.packages != '[]' # Ensure job runs only if there are changes
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
package: ${{ fromJSON(needs.changes.outputs.packages || '[]') }}
|
||||||
|
fail-fast: false
|
||||||
steps:
|
steps:
|
||||||
- name: Fetch Repository
|
- name: Fetch Repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
@@ -86,29 +59,38 @@ jobs:
|
|||||||
uses: actions/setup-go@v5
|
uses: actions/setup-go@v5
|
||||||
with:
|
with:
|
||||||
# NOTE: Keep this in sync with the version from go.mod
|
# NOTE: Keep this in sync with the version from go.mod
|
||||||
go-version: "1.21.x"
|
go-version: "1.23.x"
|
||||||
|
|
||||||
- name: Setup Node.js
|
- name: Setup Node.js
|
||||||
uses: actions/setup-node@v4
|
uses: actions/setup-node@v4
|
||||||
with:
|
with:
|
||||||
node-version: '18'
|
node-version: '18'
|
||||||
|
|
||||||
- name: Install Azurite
|
- name: Install ArangoDB
|
||||||
|
if: ${{ matrix.package == 'arangodb' }}
|
||||||
run: |
|
run: |
|
||||||
docker run -d -p 10000:10000 mcr.microsoft.com/azure-storage/azurite azurite-blob --blobHost 0.0.0.0 --blobPort 10000
|
docker run -d -p 8529:8529 -e "ARANGO_NO_AUTH=1" arangodb:latest
|
||||||
|
|
||||||
|
- name: Install Memcached
|
||||||
|
if: ${{ matrix.package == 'memcache' }}
|
||||||
|
run: |
|
||||||
|
docker run -d -p 11211:11211 memcached:latest
|
||||||
|
|
||||||
- name: Install Cloudflare Worker
|
- name: Install Cloudflare Worker
|
||||||
|
if: ${{ matrix.package == 'cloudflarekv' }}
|
||||||
run : |
|
run : |
|
||||||
.github/scripts/initialize-wrangler.sh
|
.github/scripts/initialize-wrangler.sh
|
||||||
cd cloudflarekv && npx wrangler dev &
|
cd cloudflarekv && npx wrangler dev &
|
||||||
npx wait-on tcp:8787
|
npx wait-on tcp:8787
|
||||||
|
|
||||||
- name: Install Coherence
|
- name: Install Coherence
|
||||||
|
if: ${{ matrix.package == 'coherence' }}
|
||||||
run: |
|
run: |
|
||||||
docker run -d -p 1408:1408 -p 30000:30000 ghcr.io/oracle/coherence-ce:22.06.5
|
docker run -d -p 1408:1408 -p 30000:30000 ghcr.io/oracle/coherence-ce:22.06.5
|
||||||
sleep 30
|
sleep 30
|
||||||
|
|
||||||
- name: Install etcd
|
- name: Install etcd
|
||||||
|
if: ${{ matrix.package == 'etcd' }}
|
||||||
run: |
|
run: |
|
||||||
docker run -d --name Etcd-server \
|
docker run -d --name Etcd-server \
|
||||||
--publish 2379:2379 \
|
--publish 2379:2379 \
|
||||||
@@ -117,70 +99,60 @@ jobs:
|
|||||||
--env ETCD_ADVERTISE_CLIENT_URLS=http://etcd-server:2379 \
|
--env ETCD_ADVERTISE_CLIENT_URLS=http://etcd-server:2379 \
|
||||||
bitnami/etcd:latest
|
bitnami/etcd:latest
|
||||||
|
|
||||||
- name: Install ScyllaDb
|
|
||||||
run: |
|
|
||||||
docker run --name scylladb -p 9042:9042 -p 19042:19042 -p 9160:9160 -p 7000:7000 -p 7001:7001 -p 7199:7199 -p 9180:9180 -d scylladb/scylla:latest --broadcast-address 127.0.0.1 --listen-address 0.0.0.0 --broadcast-rpc-address 127.0.0.1
|
|
||||||
sleep 15 # Wait for ScyllaDb to initialize
|
|
||||||
|
|
||||||
- name: Setup Redis
|
- name: Setup Redis
|
||||||
|
if: ${{ matrix.package == 'redis' || matrix.package == 'rueidis' }}
|
||||||
uses: shogo82148/actions-setup-redis@v1
|
uses: shogo82148/actions-setup-redis@v1
|
||||||
with:
|
with:
|
||||||
redis-version: '7.x'
|
redis-version: '7.x'
|
||||||
auto-start: 'false'
|
auto-start: 'false'
|
||||||
|
|
||||||
- name: Run Redis
|
- name: Run Redis
|
||||||
|
if: ${{ matrix.package == 'redis' || matrix.package == 'rueidis' }}
|
||||||
run: |
|
run: |
|
||||||
redis-server --port 6379 &
|
redis-server --port 6379 &
|
||||||
|
|
||||||
- name: Run NATS
|
|
||||||
run: |
|
|
||||||
./.github/scripts/gen-test-certs.sh
|
|
||||||
docker run -d --name nats-jetstream -p 4443:4443 -v ./nats/testdata:/testdata -v ./tls:/tls nats:latest --jetstream -c /testdata/nats-tls.conf
|
|
||||||
sleep 2
|
|
||||||
|
|
||||||
- name: Run Benchmarks
|
- name: Run Benchmarks
|
||||||
|
working-directory: ${{ matrix.package }}
|
||||||
run: |
|
run: |
|
||||||
set -o pipefail
|
set -o pipefail
|
||||||
for d in */ ; do
|
echo "Bench dir: ${{ matrix.package }}"
|
||||||
[[ $d == "tls/" ]] && continue
|
go test ./... -timeout 900s -benchmem -run=^$ -bench . | tee -a output.txt
|
||||||
[[ $d == "node_modules/" ]] && continue
|
|
||||||
|
|
||||||
cd "$d"
|
|
||||||
echo "Bench dir: $d"
|
|
||||||
go test ./... -benchmem -run=^$ -bench . | tee -a ../output.txt
|
|
||||||
cd ..
|
|
||||||
done
|
|
||||||
shell: bash
|
shell: bash
|
||||||
env:
|
env:
|
||||||
MSSQL_DATABASE: master
|
MSSQL_DATABASE: master
|
||||||
MSSQL_USERNAME: sa
|
MSSQL_USERNAME: sa
|
||||||
MSSQL_PASSWORD: MsSql!1234
|
MSSQL_PASSWORD: MsSql!1234
|
||||||
MYSQL_USERNAME: username
|
TEST_AZURITE_IMAGE: mcr.microsoft.com/azure-storage/azurite:latest
|
||||||
MYSQL_PASSWORD: password
|
TEST_AEROSPIKE_IMAGE: aerospike/aerospike-server:latest
|
||||||
MYSQL_DATABASE: fiber
|
|
||||||
POSTGRES_DATABASE: fiber
|
|
||||||
POSTGRES_USERNAME: username
|
|
||||||
POSTGRES_PASSWORD: "pass#w%rd"
|
|
||||||
TEST_CLICKHOUSE_IMAGE: "clickhouse/clickhouse-server:23-alpine"
|
TEST_CLICKHOUSE_IMAGE: "clickhouse/clickhouse-server:23-alpine"
|
||||||
TEST_COUCHBASE_IMAGE: "couchbase:enterprise-7.1.1"
|
TEST_CASSANDRA_IMAGE: "cassandra:latest"
|
||||||
TEST_MINIO_IMAGE: "docker.io/minio/minio:RELEASE.2024-08-17T01-24-54Z"
|
TEST_COUCHBASE_IMAGE: "couchbase:enterprise-7.6.5"
|
||||||
|
TEST_DYNAMODB_IMAGE: amazon/dynamodb-local:latest
|
||||||
|
TEST_MINIO_IMAGE: "docker.io/minio/minio:latest"
|
||||||
|
TEST_MONGODB_IMAGE: "docker.io/mongo:7"
|
||||||
|
TEST_MYSQL_IMAGE: "docker.io/mysql:9"
|
||||||
|
TEST_NATS_IMAGE: "nats:2-alpine"
|
||||||
|
TEST_POSTGRES_IMAGE: "docker.io/postgres:16-alpine"
|
||||||
|
TEST_SCYLLADB_IMAGE: "scylladb/scylla:6.2"
|
||||||
|
|
||||||
- name: Get Previous Benchmark Results
|
- name: Get Previous Benchmark Results
|
||||||
uses: actions/cache@v4
|
uses: actions/cache@v4
|
||||||
with:
|
with:
|
||||||
path: ./cache
|
path: ./cache
|
||||||
key: ${{ runner.os }}-benchmark
|
key: ${{ runner.os }}-benchmark-${{ matrix.package }}
|
||||||
|
|
||||||
- name: Save Benchmark Results
|
- name: Save Benchmark Results
|
||||||
uses: benchmark-action/github-action-benchmark@v1.20.4
|
uses: benchmark-action/github-action-benchmark@v1.20.4
|
||||||
with:
|
with:
|
||||||
tool: "go"
|
tool: "go"
|
||||||
output-file-path: output.txt
|
output-file-path: ${{ matrix.package }}/output.txt
|
||||||
github-token: ${{ secrets.BENCHMARK_TOKEN }}
|
github-token: ${{ secrets.BENCHMARK_TOKEN }}
|
||||||
benchmark-data-dir-path: "benchmarks"
|
benchmark-data-dir-path: "benchmarks/${{ matrix.package }}"
|
||||||
alert-threshold: "300%"
|
alert-threshold: "300%"
|
||||||
fail-on-alert: true
|
fail-on-alert: true
|
||||||
comment-on-alert: ${{ github.event_name == 'push' || github.event_name == 'workflow_dispatch' }}
|
comment-on-alert: ${{ github.event_name == 'push' || github.event_name == 'workflow_dispatch' }}
|
||||||
#summary-always: ${{ github.event_name != 'push' && github.event_name != 'workflow_dispatch' }}
|
#summary-always: ${{ github.event_name != 'push' && github.event_name != 'workflow_dispatch' }}
|
||||||
auto-push: ${{ github.event_name == 'push' || github.event_name == 'workflow_dispatch' }}
|
auto-push: ${{ github.event_name == 'push' || github.event_name == 'workflow_dispatch' }}
|
||||||
save-data-file: ${{ github.event_name == 'push' || github.event_name == 'workflow_dispatch' }}
|
save-data-file: ${{ github.event_name == 'push' || github.event_name == 'workflow_dispatch' }}
|
||||||
|
|
||||||
|
|
54
.github/workflows/codeql-analysis.yml
vendored
54
.github/workflows/codeql-analysis.yml
vendored
@@ -1,54 +0,0 @@
|
|||||||
name: "CodeQL"
|
|
||||||
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
branches: [master, main]
|
|
||||||
pull_request:
|
|
||||||
# The branches below must be a subset of the branches above
|
|
||||||
branches: [master, main]
|
|
||||||
schedule:
|
|
||||||
- cron: '0 3 * * 6'
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
analyse:
|
|
||||||
name: Analyse
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- name: Checkout repository
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
with:
|
|
||||||
# We must fetch at least the immediate parents so that if this is
|
|
||||||
# a pull request then we can checkout the head.
|
|
||||||
fetch-depth: 2
|
|
||||||
|
|
||||||
# If this run was triggered by a pull request event, then checkout
|
|
||||||
# the head of the pull request instead of the merge commit.
|
|
||||||
- run: git checkout HEAD^2
|
|
||||||
if: ${{ github.event_name == 'pull_request' }}
|
|
||||||
|
|
||||||
# Initializes the CodeQL tools for scanning.
|
|
||||||
- name: Initialize CodeQL
|
|
||||||
uses: github/codeql-action/init@v3
|
|
||||||
# Override language selection by uncommenting this and choosing your languages
|
|
||||||
with:
|
|
||||||
languages: go
|
|
||||||
|
|
||||||
# Autobuild attempts to build any compiled languages (C/C++, C#, or Java).
|
|
||||||
# If this step fails, then you should remove it and run the build manually (see below)
|
|
||||||
- name: Autobuild
|
|
||||||
uses: github/codeql-action/autobuild@v3
|
|
||||||
|
|
||||||
# ℹ️ Command-line programs to run using the OS shell.
|
|
||||||
# 📚 https://git.io/JvXDl
|
|
||||||
|
|
||||||
# ✏️ If the Autobuild fails above, remove it and uncomment the following three lines
|
|
||||||
# and modify them (or add more) to build your code if your project
|
|
||||||
# uses a compiled language
|
|
||||||
|
|
||||||
#- run: |
|
|
||||||
# make bootstrap
|
|
||||||
# make release
|
|
||||||
|
|
||||||
- name: Perform CodeQL Analysis
|
|
||||||
uses: github/codeql-action/analyze@v3
|
|
2
.github/workflows/dependabot_automerge.yml
vendored
2
.github/workflows/dependabot_automerge.yml
vendored
@@ -28,7 +28,7 @@ jobs:
|
|||||||
steps:
|
steps:
|
||||||
- name: Dependabot metadata
|
- name: Dependabot metadata
|
||||||
id: metadata
|
id: metadata
|
||||||
uses: dependabot/fetch-metadata@v2.2.0
|
uses: dependabot/fetch-metadata@v2.3.0
|
||||||
with:
|
with:
|
||||||
github-token: "${{ secrets.PR_TOKEN }}"
|
github-token: "${{ secrets.PR_TOKEN }}"
|
||||||
- name: Enable auto-merge for Dependabot PRs
|
- name: Enable auto-merge for Dependabot PRs
|
||||||
|
45
.github/workflows/golangci-lint.yml
vendored
45
.github/workflows/golangci-lint.yml
vendored
@@ -20,42 +20,37 @@ on:
|
|||||||
- ".github/dependabot.yml"
|
- ".github/dependabot.yml"
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
generate-matrix:
|
changes:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
outputs:
|
|
||||||
matrix: ${{ steps.set-matrix.outputs.matrix }}
|
|
||||||
steps:
|
steps:
|
||||||
- name: Fetch Repository
|
- name: Fetch Repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
with:
|
with:
|
||||||
fetch-depth: 0
|
fetch-depth: 0
|
||||||
- id: set-matrix
|
|
||||||
|
- name: Generate filters
|
||||||
|
id: filter-setup
|
||||||
run: |
|
run: |
|
||||||
# Determine the base and head commits for diff based on the event type
|
filters=$(find . -maxdepth 1 -type d ! -path ./.git ! -path . -exec basename {} \; | grep -v '^\.' | awk '{printf "%s: \"%s/**\"\n", $1, $1}')
|
||||||
BASE_SHA="${{ github.event.pull_request.base.sha || github.event.before }}"
|
echo "filters<<EOF" >> $GITHUB_OUTPUT
|
||||||
HEAD_SHA="${{ github.event.pull_request.head.sha || github.event.after }}"
|
echo "$filters" >> $GITHUB_OUTPUT
|
||||||
|
echo "EOF" >> $GITHUB_OUTPUT
|
||||||
|
shell: bash
|
||||||
|
|
||||||
# Extract directories from changed files, only include those with go.mod files
|
- name: Filter changes
|
||||||
GO_MOD_DIRECTORIES=()
|
id: filter
|
||||||
FILES=$(git diff --name-only $BASE_SHA $HEAD_SHA | grep -vE '/\.')
|
uses: dorny/paths-filter@v3
|
||||||
DIRECTORIES=$(echo "$FILES" | xargs -L1 dirname | sort -u)
|
with:
|
||||||
|
filters: ${{ steps.filter-setup.outputs.filters }}
|
||||||
for dir in $DIRECTORIES; do
|
outputs:
|
||||||
if [[ -f "$dir/go.mod" ]]; then
|
packages: ${{ steps.filter.outputs.changes || '[]' }}
|
||||||
GO_MOD_DIRECTORIES+=("$dir")
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
# Export the JSON array
|
|
||||||
JSON_ARRAY=$(printf '%s\n' "${GO_MOD_DIRECTORIES[@]}" | jq -R -s -c 'split("\n")[:-1]')
|
|
||||||
echo "matrix=${JSON_ARRAY}" >> $GITHUB_OUTPUT
|
|
||||||
|
|
||||||
lint:
|
lint:
|
||||||
needs: generate-matrix
|
needs: changes
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
modules: ${{fromJson(needs.generate-matrix.outputs.matrix)}}
|
package: ${{ fromJSON(needs.changes.outputs.packages || '[]') }}
|
||||||
steps:
|
steps:
|
||||||
- name: Fetch Repository
|
- name: Fetch Repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
@@ -63,6 +58,6 @@ jobs:
|
|||||||
uses: reviewdog/action-golangci-lint@v2
|
uses: reviewdog/action-golangci-lint@v2
|
||||||
with:
|
with:
|
||||||
golangci_lint_flags: "--tests=false --timeout=5m"
|
golangci_lint_flags: "--tests=false --timeout=5m"
|
||||||
workdir: ${{ matrix.modules }}
|
workdir: ${{ matrix.package }}
|
||||||
fail_on_error: true
|
fail_level: "warning"
|
||||||
filter_mode: nofilter
|
filter_mode: nofilter
|
||||||
|
65
.github/workflows/gosec.yml
vendored
65
.github/workflows/gosec.yml
vendored
@@ -1,65 +0,0 @@
|
|||||||
name: Gosec Security Scan
|
|
||||||
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- "master"
|
|
||||||
- "main"
|
|
||||||
paths-ignore:
|
|
||||||
- "**.md"
|
|
||||||
- LICENSE
|
|
||||||
- ".github/ISSUE_TEMPLATE/*.yml"
|
|
||||||
- ".github/dependabot.yml"
|
|
||||||
pull_request:
|
|
||||||
branches:
|
|
||||||
- "*"
|
|
||||||
paths-ignore:
|
|
||||||
- "**.md"
|
|
||||||
- LICENSE
|
|
||||||
- ".github/ISSUE_TEMPLATE/*.yml"
|
|
||||||
- ".github/dependabot.yml"
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
detect-changes:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
outputs:
|
|
||||||
matrix: ${{ steps.changed-files.outputs.all_changed_files }}
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v4
|
|
||||||
with:
|
|
||||||
fetch-depth: 0
|
|
||||||
- name: Changed Files
|
|
||||||
uses: tj-actions/changed-files@v45
|
|
||||||
id: changed-files
|
|
||||||
with:
|
|
||||||
files_ignore: |
|
|
||||||
.github/**
|
|
||||||
**.md
|
|
||||||
json: true
|
|
||||||
escape_json: false
|
|
||||||
dir_names: true
|
|
||||||
dir_names_max_depth: '1'
|
|
||||||
dir_names_exclude_current_dir: true
|
|
||||||
|
|
||||||
gosec-scan:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
needs: detect-changes
|
|
||||||
env:
|
|
||||||
GO111MODULE: on
|
|
||||||
strategy:
|
|
||||||
matrix:
|
|
||||||
modules: ${{ fromJSON(needs.detect-changes.outputs.matrix) }}
|
|
||||||
steps:
|
|
||||||
- name: Fetch Repository
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
- name: Install Go
|
|
||||||
uses: actions/setup-go@v5
|
|
||||||
with:
|
|
||||||
go-version: '^1.19.x'
|
|
||||||
check-latest: true
|
|
||||||
cache: false
|
|
||||||
- name: Install gosec
|
|
||||||
run: go install github.com/securego/gosec/v2/cmd/gosec@latest
|
|
||||||
- name: Run gosec
|
|
||||||
working-directory: ${{ matrix.modules }}
|
|
||||||
run: gosec ./...
|
|
39
.github/workflows/govulncheck.yml
vendored
39
.github/workflows/govulncheck.yml
vendored
@@ -1,39 +0,0 @@
|
|||||||
name: Govulncheck Security Scan
|
|
||||||
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- "master"
|
|
||||||
- "main"
|
|
||||||
paths-ignore:
|
|
||||||
- "**.md"
|
|
||||||
- LICENSE
|
|
||||||
- ".github/ISSUE_TEMPLATE/*.yml"
|
|
||||||
- ".github/dependabot.yml"
|
|
||||||
pull_request:
|
|
||||||
branches:
|
|
||||||
- "*"
|
|
||||||
paths-ignore:
|
|
||||||
- "**.md"
|
|
||||||
- LICENSE
|
|
||||||
- ".github/ISSUE_TEMPLATE/*.yml"
|
|
||||||
- ".github/dependabot.yml"
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
govulncheck-check:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
env:
|
|
||||||
GO111MODULE: on
|
|
||||||
steps:
|
|
||||||
- name: Fetch Repository
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
- name: Install Go
|
|
||||||
uses: actions/setup-go@v5
|
|
||||||
with:
|
|
||||||
go-version: 'stable'
|
|
||||||
check-latest: true
|
|
||||||
cache: false
|
|
||||||
- name: Install Govulncheck
|
|
||||||
run: go install golang.org/x/vuln/cmd/govulncheck@latest
|
|
||||||
- name: Run Govulncheck
|
|
||||||
run: govulncheck ./...
|
|
19
.github/workflows/release-drafter-arangodb.yml
vendored
19
.github/workflows/release-drafter-arangodb.yml
vendored
@@ -1,19 +0,0 @@
|
|||||||
name: Release Drafter Arangodb
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
# branches to consider in the event; optional, defaults to all
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
- main
|
|
||||||
paths:
|
|
||||||
- 'arangodb/**'
|
|
||||||
jobs:
|
|
||||||
draft_release_arangodb:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- uses: release-drafter/release-drafter@v6
|
|
||||||
with:
|
|
||||||
config-name: release-drafter-arangodb.yml
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
19
.github/workflows/release-drafter-azureblob.yml
vendored
19
.github/workflows/release-drafter-azureblob.yml
vendored
@@ -1,19 +0,0 @@
|
|||||||
name: Release Drafter Azureblob
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
# branches to consider in the event; optional, defaults to all
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
- main
|
|
||||||
paths:
|
|
||||||
- 'azureblob/**'
|
|
||||||
jobs:
|
|
||||||
draft_release_azureblob:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- uses: release-drafter/release-drafter@v6
|
|
||||||
with:
|
|
||||||
config-name: release-drafter-azureblob.yml
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
19
.github/workflows/release-drafter-badger.yml
vendored
19
.github/workflows/release-drafter-badger.yml
vendored
@@ -1,19 +0,0 @@
|
|||||||
name: Release Drafter Badger
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
# branches to consider in the event; optional, defaults to all
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
- main
|
|
||||||
paths:
|
|
||||||
- 'badger/**'
|
|
||||||
jobs:
|
|
||||||
draft_release_badger:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- uses: release-drafter/release-drafter@v6
|
|
||||||
with:
|
|
||||||
config-name: release-drafter-badger.yml
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
19
.github/workflows/release-drafter-bbolt.yml
vendored
19
.github/workflows/release-drafter-bbolt.yml
vendored
@@ -1,19 +0,0 @@
|
|||||||
name: Release Drafter Bbolt
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
# branches to consider in the event; optional, defaults to all
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
- main
|
|
||||||
paths:
|
|
||||||
- 'bbolt/**'
|
|
||||||
jobs:
|
|
||||||
draft_release_bbolt:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- uses: release-drafter/release-drafter@v6
|
|
||||||
with:
|
|
||||||
config-name: release-drafter-bbolt.yml
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
19
.github/workflows/release-drafter-clickhouse.yml
vendored
19
.github/workflows/release-drafter-clickhouse.yml
vendored
@@ -1,19 +0,0 @@
|
|||||||
name: Release Drafter Clickhouse
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
# branches to consider in the event; optional, defaults to all
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
- main
|
|
||||||
paths:
|
|
||||||
- 'clickhouse/**'
|
|
||||||
jobs:
|
|
||||||
draft_release_clickhouse:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- uses: release-drafter/release-drafter@v6
|
|
||||||
with:
|
|
||||||
config-name: release-drafter-clickhouse.yml
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
@@ -1,19 +0,0 @@
|
|||||||
name: Release Drafter Cloudflare KV
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
# branches to consider in the event; optional, defaults to all
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
- main
|
|
||||||
paths:
|
|
||||||
- "cloudflarekv/**"
|
|
||||||
jobs:
|
|
||||||
draft_release_cloudflarekv:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- uses: release-drafter/release-drafter@v6
|
|
||||||
with:
|
|
||||||
config-name: release-drafter-cloudflarekv.yml
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
19
.github/workflows/release-drafter-coherence.yml
vendored
19
.github/workflows/release-drafter-coherence.yml
vendored
@@ -1,19 +0,0 @@
|
|||||||
name: Release Drafter Coherence
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
# branches to consider in the event; optional, defaults to all
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
- main
|
|
||||||
paths:
|
|
||||||
- 'coherence/**'
|
|
||||||
jobs:
|
|
||||||
draft_release_coherence:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- uses: release-drafter/release-drafter@v6
|
|
||||||
with:
|
|
||||||
config-name: release-drafter-coherence.yml
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
19
.github/workflows/release-drafter-couchbase.yml
vendored
19
.github/workflows/release-drafter-couchbase.yml
vendored
@@ -1,19 +0,0 @@
|
|||||||
name: Release Drafter Couchbase
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
# branches to consider in the event; optional, defaults to all
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
- main
|
|
||||||
paths:
|
|
||||||
- 'couchbase/**'
|
|
||||||
jobs:
|
|
||||||
draft_release_couchbase:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- uses: release-drafter/release-drafter@v6
|
|
||||||
with:
|
|
||||||
config-name: release-drafter-couchbase.yml
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
19
.github/workflows/release-drafter-dynamodb.yml
vendored
19
.github/workflows/release-drafter-dynamodb.yml
vendored
@@ -1,19 +0,0 @@
|
|||||||
name: Release Drafter Dynamodb
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
# branches to consider in the event; optional, defaults to all
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
- main
|
|
||||||
paths:
|
|
||||||
- 'dynamodb/**'
|
|
||||||
jobs:
|
|
||||||
draft_release_dynamodb:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- uses: release-drafter/release-drafter@v6
|
|
||||||
with:
|
|
||||||
config-name: release-drafter-dynamodb.yml
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
19
.github/workflows/release-drafter-etcd.yml
vendored
19
.github/workflows/release-drafter-etcd.yml
vendored
@@ -1,19 +0,0 @@
|
|||||||
name: Release Drafter Etcd
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
# branches to consider in the event; optional, defaults to all
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
- main
|
|
||||||
paths:
|
|
||||||
- 'etcd/**'
|
|
||||||
jobs:
|
|
||||||
draft_release_etcd:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- uses: release-drafter/release-drafter@v6
|
|
||||||
with:
|
|
||||||
config-name: release-drafter-etcd.yml
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
19
.github/workflows/release-drafter-memcache.yml
vendored
19
.github/workflows/release-drafter-memcache.yml
vendored
@@ -1,19 +0,0 @@
|
|||||||
name: Release Drafter Memcache
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
# branches to consider in the event; optional, defaults to all
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
- main
|
|
||||||
paths:
|
|
||||||
- 'memcache/**'
|
|
||||||
jobs:
|
|
||||||
draft_release_memcache:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- uses: release-drafter/release-drafter@v6
|
|
||||||
with:
|
|
||||||
config-name: release-drafter-memcache.yml
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
19
.github/workflows/release-drafter-memory.yml
vendored
19
.github/workflows/release-drafter-memory.yml
vendored
@@ -1,19 +0,0 @@
|
|||||||
name: Release Drafter Memory
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
# branches to consider in the event; optional, defaults to all
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
- main
|
|
||||||
paths:
|
|
||||||
- 'memory/**'
|
|
||||||
jobs:
|
|
||||||
draft_release_memcache:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- uses: release-drafter/release-drafter@v6
|
|
||||||
with:
|
|
||||||
config-name: release-drafter-memory.yml
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
19
.github/workflows/release-drafter-minio.yml
vendored
19
.github/workflows/release-drafter-minio.yml
vendored
@@ -1,19 +0,0 @@
|
|||||||
name: Release Drafter Minio
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
# branches to consider in the event; optional, defaults to all
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
- main
|
|
||||||
paths:
|
|
||||||
- 'minio/**'
|
|
||||||
jobs:
|
|
||||||
draft_release_minio:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- uses: release-drafter/release-drafter@v6
|
|
||||||
with:
|
|
||||||
config-name: release-drafter-minio.yml
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
@@ -1,19 +0,0 @@
|
|||||||
name: Release Drafter MockStorage
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
# branches to consider in the event; optional, defaults to all
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
- main
|
|
||||||
paths:
|
|
||||||
- 'mockstorage/**'
|
|
||||||
jobs:
|
|
||||||
draft_release_memcache:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- uses: release-drafter/release-drafter@v6
|
|
||||||
with:
|
|
||||||
config-name: release-drafter-mockstorage.yml
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
19
.github/workflows/release-drafter-mongodb.yml
vendored
19
.github/workflows/release-drafter-mongodb.yml
vendored
@@ -1,19 +0,0 @@
|
|||||||
name: Release Drafter Mongodb
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
# branches to consider in the event; optional, defaults to all
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
- main
|
|
||||||
paths:
|
|
||||||
- 'mongodb/**'
|
|
||||||
jobs:
|
|
||||||
draft_release_mongodb:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- uses: release-drafter/release-drafter@v6
|
|
||||||
with:
|
|
||||||
config-name: release-drafter-mongodb.yml
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
19
.github/workflows/release-drafter-mssql.yml
vendored
19
.github/workflows/release-drafter-mssql.yml
vendored
@@ -1,19 +0,0 @@
|
|||||||
name: Release Drafter Mssql
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
# branches to consider in the event; optional, defaults to all
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
- main
|
|
||||||
paths:
|
|
||||||
- 'mssql/**'
|
|
||||||
jobs:
|
|
||||||
draft_release_mssql:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- uses: release-drafter/release-drafter@v6
|
|
||||||
with:
|
|
||||||
config-name: release-drafter-mssql.yml
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
19
.github/workflows/release-drafter-mysql.yml
vendored
19
.github/workflows/release-drafter-mysql.yml
vendored
@@ -1,19 +0,0 @@
|
|||||||
name: Release Drafter Mysql
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
# branches to consider in the event; optional, defaults to all
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
- main
|
|
||||||
paths:
|
|
||||||
- 'mysql/**'
|
|
||||||
jobs:
|
|
||||||
draft_release_mysql:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- uses: release-drafter/release-drafter@v6
|
|
||||||
with:
|
|
||||||
config-name: release-drafter-mysql.yml
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
19
.github/workflows/release-drafter-nats.yml
vendored
19
.github/workflows/release-drafter-nats.yml
vendored
@@ -1,19 +0,0 @@
|
|||||||
name: Release Drafter Nats
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
# branches to consider in the event; optional, defaults to all
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
- main
|
|
||||||
paths:
|
|
||||||
- 'nats/**'
|
|
||||||
jobs:
|
|
||||||
draft_release_nats:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- uses: release-drafter/release-drafter@v6
|
|
||||||
with:
|
|
||||||
config-name: release-drafter-nats.yml
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
19
.github/workflows/release-drafter-pebble.yml
vendored
19
.github/workflows/release-drafter-pebble.yml
vendored
@@ -1,19 +0,0 @@
|
|||||||
name: Release Drafter Pebble
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
# branches to consider in the event; optional, defaults to all
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
- main
|
|
||||||
paths:
|
|
||||||
- "pebble/**"
|
|
||||||
jobs:
|
|
||||||
draft_release_pebble:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- uses: release-drafter/release-drafter@v6
|
|
||||||
with:
|
|
||||||
config-name: release-drafter-pebble.yml
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
19
.github/workflows/release-drafter-postgres.yml
vendored
19
.github/workflows/release-drafter-postgres.yml
vendored
@@ -1,19 +0,0 @@
|
|||||||
name: Release Drafter Postgres
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
# branches to consider in the event; optional, defaults to all
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
- main
|
|
||||||
paths:
|
|
||||||
- 'postgres/**'
|
|
||||||
jobs:
|
|
||||||
draft_release_postgres:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- uses: release-drafter/release-drafter@v6
|
|
||||||
with:
|
|
||||||
config-name: release-drafter-postgres.yml
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
19
.github/workflows/release-drafter-redis.yml
vendored
19
.github/workflows/release-drafter-redis.yml
vendored
@@ -1,19 +0,0 @@
|
|||||||
name: Release Drafter Redis
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
# branches to consider in the event; optional, defaults to all
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
- main
|
|
||||||
paths:
|
|
||||||
- 'redis/**'
|
|
||||||
jobs:
|
|
||||||
draft_release_redis:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- uses: release-drafter/release-drafter@v6
|
|
||||||
with:
|
|
||||||
config-name: release-drafter-redis.yml
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
19
.github/workflows/release-drafter-ristretto.yml
vendored
19
.github/workflows/release-drafter-ristretto.yml
vendored
@@ -1,19 +0,0 @@
|
|||||||
name: Release Drafter Ristretto
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
# branches to consider in the event; optional, defaults to all
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
- main
|
|
||||||
paths:
|
|
||||||
- 'ristretto/**'
|
|
||||||
jobs:
|
|
||||||
draft_release_ristretto:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- uses: release-drafter/release-drafter@v6
|
|
||||||
with:
|
|
||||||
config-name: release-drafter-ristretto.yml
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
19
.github/workflows/release-drafter-rueidis.yml
vendored
19
.github/workflows/release-drafter-rueidis.yml
vendored
@@ -1,19 +0,0 @@
|
|||||||
name: Release Drafter Rueidis
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
# branches to consider in the event; optional, defaults to all
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
- main
|
|
||||||
paths:
|
|
||||||
- 'rueidis/**'
|
|
||||||
jobs:
|
|
||||||
draft_release_rueidis:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- uses: release-drafter/release-drafter@v6
|
|
||||||
with:
|
|
||||||
config-name: release-drafter-rueidis.yml
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
19
.github/workflows/release-drafter-s3.yml
vendored
19
.github/workflows/release-drafter-s3.yml
vendored
@@ -1,19 +0,0 @@
|
|||||||
name: Release Drafter S3
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
# branches to consider in the event; optional, defaults to all
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
- main
|
|
||||||
paths:
|
|
||||||
- 's3/**'
|
|
||||||
jobs:
|
|
||||||
draft_release_s3:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- uses: release-drafter/release-drafter@v6
|
|
||||||
with:
|
|
||||||
config-name: release-drafter-s3.yml
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
19
.github/workflows/release-drafter-scylladb.yml
vendored
19
.github/workflows/release-drafter-scylladb.yml
vendored
@@ -1,19 +0,0 @@
|
|||||||
name: Release Drafter ScyllaDb
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
# branches to consider in the event; optional, defaults to all
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
- main
|
|
||||||
paths:
|
|
||||||
- 'scylladb/**'
|
|
||||||
jobs:
|
|
||||||
draft_release_scylladb:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- uses: release-drafter/release-drafter@v6
|
|
||||||
with:
|
|
||||||
config-name: release-drafter-scylladb.yml
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
20
.github/workflows/release-drafter-sqlite3.yml
vendored
20
.github/workflows/release-drafter-sqlite3.yml
vendored
@@ -1,20 +0,0 @@
|
|||||||
name: Release Drafter Sqlite3
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
# branches to consider in the event; optional, defaults to all
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
- main
|
|
||||||
paths:
|
|
||||||
- 'sqlite3/**'
|
|
||||||
jobs:
|
|
||||||
draft_release_sqlite3:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- uses: release-drafter/release-drafter@v6
|
|
||||||
with:
|
|
||||||
config-name: release-drafter-sqlite3.yml
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
||||||
|
|
19
.github/workflows/release-drafter-valkey.yml
vendored
19
.github/workflows/release-drafter-valkey.yml
vendored
@@ -1,19 +0,0 @@
|
|||||||
name: Release Drafter Valkey
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
# branches to consider in the event; optional, defaults to all
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
- main
|
|
||||||
paths:
|
|
||||||
- 'valkey/**'
|
|
||||||
jobs:
|
|
||||||
draft_release_valkey:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
timeout-minutes: 30
|
|
||||||
steps:
|
|
||||||
- uses: release-drafter/release-drafter@v6
|
|
||||||
with:
|
|
||||||
config-name: release-drafter-valkey.yml
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
61
.github/workflows/release-drafter.yml
vendored
Normal file
61
.github/workflows/release-drafter.yml
vendored
Normal file
@@ -0,0 +1,61 @@
|
|||||||
|
name: Release Drafter (All)
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- master
|
||||||
|
- main
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
changes:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
permissions:
|
||||||
|
pull-requests: read
|
||||||
|
steps:
|
||||||
|
- name: Checkout repository
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- name: Generate filters
|
||||||
|
id: filter-setup
|
||||||
|
run: |
|
||||||
|
filters=$(find . -maxdepth 1 -type d ! -path ./.git ! -path . -exec basename {} \; | grep -v '^\.' | awk '{printf "%s: \"%s/**\"\n", $1, $1}')
|
||||||
|
echo "filters<<EOF" >> $GITHUB_OUTPUT
|
||||||
|
echo "$filters" >> $GITHUB_OUTPUT
|
||||||
|
echo "EOF" >> $GITHUB_OUTPUT
|
||||||
|
shell: bash
|
||||||
|
- name: Filter changes
|
||||||
|
id: filter
|
||||||
|
uses: dorny/paths-filter@v3
|
||||||
|
with:
|
||||||
|
filters: ${{ steps.filter-setup.outputs.filters }}
|
||||||
|
|
||||||
|
outputs:
|
||||||
|
packages: ${{ steps.filter.outputs.changes || '[]' }}
|
||||||
|
|
||||||
|
release-drafter:
|
||||||
|
needs: changes
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
timeout-minutes: 30
|
||||||
|
if: needs.changes.outputs.packages != '[]' # Ensure job runs only if there are changes
|
||||||
|
env:
|
||||||
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
package: ${{ fromJSON(needs.changes.outputs.packages || '[]') }}
|
||||||
|
steps:
|
||||||
|
- name: Checkout repository
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- name: Generate dynamic config from template
|
||||||
|
id: generate-config
|
||||||
|
run: |
|
||||||
|
folder="${{ matrix.package }}"
|
||||||
|
sed "s|{{FOLDER}}|$folder|g" .github/release-drafter-template.yml > .github/release-drafter-$folder.yml
|
||||||
|
echo "config<<EOF" >> $GITHUB_OUTPUT
|
||||||
|
cat .github/release-drafter-$folder.yml >> $GITHUB_OUTPUT
|
||||||
|
echo "EOF" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
|
- name: Use dynamic release-drafter configuration
|
||||||
|
uses: ReneWerner87/release-drafter@6dec4ceb1fb86b6514f11a2e7a39e1dedce709d0
|
||||||
|
with:
|
||||||
|
config: ${{ steps.generate-config.outputs.config }}
|
30
.github/workflows/test-aerospike.yml
vendored
Normal file
30
.github/workflows/test-aerospike.yml
vendored
Normal file
@@ -0,0 +1,30 @@
|
|||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- master
|
||||||
|
- main
|
||||||
|
paths:
|
||||||
|
- 'aerospike/**'
|
||||||
|
pull_request:
|
||||||
|
paths:
|
||||||
|
- 'aerospike/**'
|
||||||
|
name: "Tests Aerospike"
|
||||||
|
jobs:
|
||||||
|
Tests:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
go-version:
|
||||||
|
- 1.23.x
|
||||||
|
- 1.24.x
|
||||||
|
steps:
|
||||||
|
- name: Fetch Repository
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
- name: Install Go
|
||||||
|
uses: actions/setup-go@v5
|
||||||
|
with:
|
||||||
|
go-version: '${{ matrix.go-version }}'
|
||||||
|
- name: Run Test
|
||||||
|
env:
|
||||||
|
TEST_AEROSPIKE_IMAGE: aerospike/aerospike-server:latest
|
||||||
|
run: cd ./aerospike && go test ./... -v -race
|
10
.github/workflows/test-azureblob.yml
vendored
10
.github/workflows/test-azureblob.yml
vendored
@@ -15,13 +15,9 @@ jobs:
|
|||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
go-version:
|
go-version:
|
||||||
- 1.19.x
|
- 1.23.x
|
||||||
- 1.20.x
|
- 1.24.x
|
||||||
- 1.21.x
|
|
||||||
steps:
|
steps:
|
||||||
- name: Install Azurite
|
|
||||||
run: |
|
|
||||||
docker run -d -p 10000:10000 mcr.microsoft.com/azure-storage/azurite azurite-blob --blobHost 0.0.0.0 --blobPort 10000
|
|
||||||
- name: Fetch Repository
|
- name: Fetch Repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
- name: Install Go
|
- name: Install Go
|
||||||
@@ -29,4 +25,6 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
go-version: '${{ matrix.go-version }}'
|
go-version: '${{ matrix.go-version }}'
|
||||||
- name: Run Test
|
- name: Run Test
|
||||||
|
env:
|
||||||
|
TEST_AZURITE_IMAGE: mcr.microsoft.com/azure-storage/azurite:latest
|
||||||
run: cd ./azureblob && go test ./... -v -race
|
run: cd ./azureblob && go test ./... -v -race
|
||||||
|
30
.github/workflows/test-cassandra.yml
vendored
Normal file
30
.github/workflows/test-cassandra.yml
vendored
Normal file
@@ -0,0 +1,30 @@
|
|||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- master
|
||||||
|
- main
|
||||||
|
paths:
|
||||||
|
- 'cassandra/**'
|
||||||
|
pull_request:
|
||||||
|
paths:
|
||||||
|
- 'cassandra/**'
|
||||||
|
name: 'Tests Cassandra'
|
||||||
|
jobs:
|
||||||
|
Tests:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
go-version:
|
||||||
|
- 1.23.x
|
||||||
|
- 1.24.x
|
||||||
|
steps:
|
||||||
|
- name: Fetch Repository
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
- name: Install Go
|
||||||
|
uses: actions/setup-go@v5
|
||||||
|
with:
|
||||||
|
go-version: '${{ matrix.go-version }}'
|
||||||
|
- name: Run Test
|
||||||
|
env:
|
||||||
|
TEST_CASSANDRA_IMAGE: cassandra:latest
|
||||||
|
run: cd ./cassandra && go clean -testcache && go test ./... -v -race
|
4
.github/workflows/test-clickhouse.yml
vendored
4
.github/workflows/test-clickhouse.yml
vendored
@@ -15,8 +15,8 @@ jobs:
|
|||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
go-version:
|
go-version:
|
||||||
- 1.21.x
|
- 1.23.x
|
||||||
- 1.22.x
|
- 1.24.x
|
||||||
steps:
|
steps:
|
||||||
- name: Fetch Repository
|
- name: Fetch Repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
|
8
.github/workflows/test-coherence.yml
vendored
8
.github/workflows/test-coherence.yml
vendored
@@ -15,16 +15,14 @@ jobs:
|
|||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
go-version:
|
go-version:
|
||||||
- 1.19.x
|
- 1.23.x
|
||||||
- 1.20.x
|
- 1.24.x
|
||||||
- 1.21.x
|
|
||||||
- 1.22.x
|
|
||||||
steps:
|
steps:
|
||||||
- name: Fetch Repository
|
- name: Fetch Repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
- name: Startup Coherence
|
- name: Startup Coherence
|
||||||
run: |
|
run: |
|
||||||
docker run -d -p 1408:1408 -p 30000:30000 ghcr.io/oracle/coherence-ce:24.09
|
docker run -d -p 1408:1408 -p 30000:30000 ghcr.io/oracle/coherence-ce:25.03
|
||||||
sleep 30
|
sleep 30
|
||||||
- name: Install Go
|
- name: Install Go
|
||||||
uses: actions/setup-go@v5
|
uses: actions/setup-go@v5
|
||||||
|
5
.github/workflows/test-couchbase.yml
vendored
5
.github/workflows/test-couchbase.yml
vendored
@@ -15,9 +15,8 @@ jobs:
|
|||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
go-version:
|
go-version:
|
||||||
- 1.21.x
|
|
||||||
- 1.22.x
|
|
||||||
- 1.23.x
|
- 1.23.x
|
||||||
|
- 1.24.x
|
||||||
steps:
|
steps:
|
||||||
- name: Fetch Repository
|
- name: Fetch Repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
@@ -27,5 +26,5 @@ jobs:
|
|||||||
go-version: '${{ matrix.go-version }}'
|
go-version: '${{ matrix.go-version }}'
|
||||||
- name: Run Test
|
- name: Run Test
|
||||||
env:
|
env:
|
||||||
TEST_COUCHBASE_IMAGE: couchbase:enterprise-7.1.1
|
TEST_COUCHBASE_IMAGE: couchbase:enterprise-7.6.5
|
||||||
run: cd ./couchbase && go test ./... -v -race
|
run: cd ./couchbase && go test ./... -v -race
|
||||||
|
7
.github/workflows/test-dynamodb.yml
vendored
7
.github/workflows/test-dynamodb.yml
vendored
@@ -20,9 +20,8 @@ jobs:
|
|||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
go-version:
|
go-version:
|
||||||
- 1.19.x
|
- 1.23.x
|
||||||
- 1.20.x
|
- 1.24.x
|
||||||
- 1.21.x
|
|
||||||
steps:
|
steps:
|
||||||
- name: Fetch Repository
|
- name: Fetch Repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
@@ -31,4 +30,6 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
go-version: '${{ matrix.go-version }}'
|
go-version: '${{ matrix.go-version }}'
|
||||||
- name: Run Test
|
- name: Run Test
|
||||||
|
env:
|
||||||
|
TEST_DYNAMODB_IMAGE: amazon/dynamodb-local:latest
|
||||||
run: cd ./dynamodb && go test ./... -v -race
|
run: cd ./dynamodb && go test ./... -v -race
|
||||||
|
28
.github/workflows/test-leveldb.yml
vendored
Normal file
28
.github/workflows/test-leveldb.yml
vendored
Normal file
@@ -0,0 +1,28 @@
|
|||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- master
|
||||||
|
- main
|
||||||
|
paths:
|
||||||
|
- 'leveldb/**'
|
||||||
|
pull_request:
|
||||||
|
paths:
|
||||||
|
- 'leveldb/**'
|
||||||
|
name: "Tests LevelDB"
|
||||||
|
jobs:
|
||||||
|
Tests:
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
go-version:
|
||||||
|
- 1.23.x
|
||||||
|
- 1.24.x
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- name: Fetch Repository
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
- name: Install Go
|
||||||
|
uses: actions/setup-go@v5
|
||||||
|
with:
|
||||||
|
go-version: '${{ matrix.go-version }}'
|
||||||
|
- name: Test LevelDB
|
||||||
|
run: cd ./leveldb && go test ./... -v -race
|
5
.github/workflows/test-minio.yml
vendored
5
.github/workflows/test-minio.yml
vendored
@@ -15,9 +15,8 @@ jobs:
|
|||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
go-version:
|
go-version:
|
||||||
- 1.21.x
|
|
||||||
- 1.22.x
|
|
||||||
- 1.23.x
|
- 1.23.x
|
||||||
|
- 1.24.x
|
||||||
steps:
|
steps:
|
||||||
- name: Fetch Repository
|
- name: Fetch Repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
@@ -27,5 +26,5 @@ jobs:
|
|||||||
go-version: '${{ matrix.go-version }}'
|
go-version: '${{ matrix.go-version }}'
|
||||||
- name: Run Test
|
- name: Run Test
|
||||||
env:
|
env:
|
||||||
TEST_MINIO_IMAGE: docker.io/minio/minio:RELEASE.2024-08-17T01-24-54Z
|
TEST_MINIO_IMAGE: docker.io/minio/minio:latest
|
||||||
run: cd ./minio && go test ./... -v -race
|
run: cd ./minio && go test ./... -v -race
|
||||||
|
12
.github/workflows/test-mongodb.yml
vendored
12
.github/workflows/test-mongodb.yml
vendored
@@ -12,17 +12,11 @@ name: "Tests Mongodb"
|
|||||||
jobs:
|
jobs:
|
||||||
Tests:
|
Tests:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
services:
|
|
||||||
mongo:
|
|
||||||
image: 'mongo:latest'
|
|
||||||
ports:
|
|
||||||
- '27017:27017'
|
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
go-version:
|
go-version:
|
||||||
- 1.19.x
|
- 1.23.x
|
||||||
- 1.20.x
|
- 1.24.x
|
||||||
- 1.21.x
|
|
||||||
steps:
|
steps:
|
||||||
- name: Fetch Repository
|
- name: Fetch Repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
@@ -31,5 +25,7 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
go-version: '${{ matrix.go-version }}'
|
go-version: '${{ matrix.go-version }}'
|
||||||
- name: Run Test
|
- name: Run Test
|
||||||
|
env:
|
||||||
|
TEST_MONGODB_IMAGE: docker.io/mongo:7
|
||||||
run: cd ./mongodb && go test ./... -v -race
|
run: cd ./mongodb && go test ./... -v -race
|
||||||
|
|
||||||
|
24
.github/workflows/test-mysql.yml
vendored
24
.github/workflows/test-mysql.yml
vendored
@@ -12,25 +12,11 @@ name: "Tests MySQL"
|
|||||||
jobs:
|
jobs:
|
||||||
Tests:
|
Tests:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
services:
|
|
||||||
mysql:
|
|
||||||
image: 'mysql:latest'
|
|
||||||
env:
|
|
||||||
MYSQL_DATABASE: fiber
|
|
||||||
MYSQL_USER: username
|
|
||||||
MYSQL_PASSWORD: password
|
|
||||||
MYSQL_ROOT_PASSWORD: password
|
|
||||||
ports:
|
|
||||||
- '3306:3306'
|
|
||||||
options: >-
|
|
||||||
--health-cmd "mysqladmin ping" --health-interval 10s --health-timeout
|
|
||||||
5s --health-retries 5
|
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
go-version:
|
go-version:
|
||||||
- 1.19.x
|
- 1.23.x
|
||||||
- 1.20.x
|
- 1.24.x
|
||||||
- 1.21.x
|
|
||||||
steps:
|
steps:
|
||||||
- name: Fetch Repository
|
- name: Fetch Repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
@@ -39,8 +25,6 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
go-version: '${{ matrix.go-version }}'
|
go-version: '${{ matrix.go-version }}'
|
||||||
- name: Run Test
|
- name: Run Test
|
||||||
run: cd ./mysql && go test ./... -v -race
|
|
||||||
env:
|
env:
|
||||||
MYSQL_USERNAME: username
|
TEST_MYSQL_IMAGE: docker.io/mysql:9
|
||||||
MYSQL_PASSWORD: password
|
run: cd ./mysql && go test ./... -v -race
|
||||||
MYSQL_DATABASE: fiber
|
|
||||||
|
13
.github/workflows/test-nats.yml
vendored
13
.github/workflows/test-nats.yml
vendored
@@ -14,9 +14,8 @@ jobs:
|
|||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
go-version:
|
go-version:
|
||||||
- 1.20.x
|
- 1.23.x
|
||||||
- 1.21.x
|
- 1.24.x
|
||||||
- 1.22.x
|
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- name: Fetch Repository
|
- name: Fetch Repository
|
||||||
@@ -25,11 +24,7 @@ jobs:
|
|||||||
uses: actions/setup-go@v5
|
uses: actions/setup-go@v5
|
||||||
with:
|
with:
|
||||||
go-version: '${{ matrix.go-version }}'
|
go-version: '${{ matrix.go-version }}'
|
||||||
- name: Generate config
|
|
||||||
run: ./.github/scripts/gen-test-certs.sh
|
|
||||||
- name: Run NATS
|
|
||||||
run: |
|
|
||||||
docker run -d --name nats-jetstream -p 4443:4443 -v ./nats/testdata:/testdata -v ./tls:/tls nats:latest --jetstream -c /testdata/nats-tls.conf
|
|
||||||
sleep 5
|
|
||||||
- name: Test Nats
|
- name: Test Nats
|
||||||
|
env:
|
||||||
|
TEST_NATS_IMAGE: "nats:2-alpine"
|
||||||
run: cd ./nats && go test ./... -v -race
|
run: cd ./nats && go test ./... -v -race
|
||||||
|
27
.github/workflows/test-neo4j.yml
vendored
Normal file
27
.github/workflows/test-neo4j.yml
vendored
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- master
|
||||||
|
- main
|
||||||
|
paths:
|
||||||
|
- 'neo4j/**'
|
||||||
|
pull_request:
|
||||||
|
paths:
|
||||||
|
- 'neo4j/**'
|
||||||
|
name: "Tests Neo4j"
|
||||||
|
jobs:
|
||||||
|
Tests:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
go-version:
|
||||||
|
- 1.23.x
|
||||||
|
steps:
|
||||||
|
- name: Fetch Repository
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
- name: Install Go
|
||||||
|
uses: actions/setup-go@v5
|
||||||
|
with:
|
||||||
|
go-version: '${{ matrix.go-version }}'
|
||||||
|
- name: Run Test
|
||||||
|
run: cd ./neo4j && go test ./... -v -race
|
23
.github/workflows/test-postgres.yml
vendored
23
.github/workflows/test-postgres.yml
vendored
@@ -12,24 +12,11 @@ name: "Tests Postgres"
|
|||||||
jobs:
|
jobs:
|
||||||
Tests:
|
Tests:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
services:
|
|
||||||
postgres:
|
|
||||||
image: 'postgres:latest'
|
|
||||||
ports:
|
|
||||||
- '5432:5432'
|
|
||||||
env:
|
|
||||||
POSTGRES_DB: fiber
|
|
||||||
POSTGRES_USER: username
|
|
||||||
POSTGRES_PASSWORD: "pass#w%rd"
|
|
||||||
options: >-
|
|
||||||
--health-cmd pg_isready --health-interval 10s --health-timeout 5s
|
|
||||||
--health-retries 5
|
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
go-version:
|
go-version:
|
||||||
- 1.20.x
|
- 1.23.x
|
||||||
- 1.21.x
|
- 1.24.x
|
||||||
- 1.22.x
|
|
||||||
steps:
|
steps:
|
||||||
- name: Fetch Repository
|
- name: Fetch Repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
@@ -38,8 +25,6 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
go-version: '${{ matrix.go-version }}'
|
go-version: '${{ matrix.go-version }}'
|
||||||
- name: Run Test
|
- name: Run Test
|
||||||
run: cd ./postgres && go test ./... -v -race
|
|
||||||
env:
|
env:
|
||||||
POSTGRES_DATABASE: fiber
|
TEST_POSTGRES_IMAGE: "docker.io/postgres:16-alpine"
|
||||||
POSTGRES_USERNAME: username
|
run: cd ./postgres && go test ./... -v -race
|
||||||
POSTGRES_PASSWORD: "pass#w%rd"
|
|
||||||
|
9
.github/workflows/test-s3.yml
vendored
9
.github/workflows/test-s3.yml
vendored
@@ -15,12 +15,9 @@ jobs:
|
|||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
go-version:
|
go-version:
|
||||||
- 1.19.x
|
- 1.23.x
|
||||||
- 1.20.x
|
- 1.24.x
|
||||||
- 1.21.x
|
|
||||||
steps:
|
steps:
|
||||||
- name: Install MinIO
|
|
||||||
run: docker run -d --restart always -p 9000:9000 --name storage-minio -e MINIO_ROOT_USER='minio-user' -e MINIO_ROOT_PASSWORD='minio-password' minio/minio server /data
|
|
||||||
- name: Fetch Repository
|
- name: Fetch Repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
- name: Install Go
|
- name: Install Go
|
||||||
@@ -28,4 +25,6 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
go-version: '${{ matrix.go-version }}'
|
go-version: '${{ matrix.go-version }}'
|
||||||
- name: Run Test
|
- name: Run Test
|
||||||
|
env:
|
||||||
|
TEST_MINIO_IMAGE: docker.io/minio/minio:latest
|
||||||
run: cd ./s3 && go test ./... -v -race
|
run: cd ./s3 && go test ./... -v -race
|
||||||
|
11
.github/workflows/test-scylladb.yml
vendored
11
.github/workflows/test-scylladb.yml
vendored
@@ -18,22 +18,19 @@ jobs:
|
|||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
go-version:
|
go-version:
|
||||||
- 1.20.x
|
- 1.23.x
|
||||||
- 1.21.x
|
- 1.24.x
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Fetch Repository
|
- name: Fetch Repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
- name: Run ScyllaDb
|
|
||||||
run: |
|
|
||||||
docker run --name scylladb -p 9042:9042 -p 19042:19042 -p 9160:9160 -p 10000:10000 -p 7000:7000 -p 7001:7001 -p 7199:7199 -p 9180:9180 -d scylladb/scylla:latest --broadcast-address 127.0.0.1 --listen-address 0.0.0.0 --broadcast-rpc-address 127.0.0.1
|
|
||||||
sleep 30 # Wait for ScyllaDb to initialize
|
|
||||||
|
|
||||||
- name: Install Go
|
- name: Install Go
|
||||||
uses: actions/setup-go@v5
|
uses: actions/setup-go@v5
|
||||||
with:
|
with:
|
||||||
go-version: '${{ matrix.go-version }}'
|
go-version: '${{ matrix.go-version }}'
|
||||||
|
|
||||||
- name: Run Test
|
- name: Run Test
|
||||||
|
env:
|
||||||
|
TEST_SCYLLADB_IMAGE: "scylladb/scylla:6.2"
|
||||||
run: cd ./scylladb && go test ./... -v -race
|
run: cd ./scylladb && go test ./... -v -race
|
||||||
|
1
.gitignore
vendored
1
.gitignore
vendored
@@ -22,6 +22,7 @@
|
|||||||
*.fasthttp.gz
|
*.fasthttp.gz
|
||||||
*.pprof
|
*.pprof
|
||||||
*.workspace
|
*.workspace
|
||||||
|
/tmp/
|
||||||
|
|
||||||
# Dependencies
|
# Dependencies
|
||||||
/vendor/
|
/vendor/
|
||||||
|
22
MIGRATE.md
Normal file
22
MIGRATE.md
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
This document contains instructions for migrating to various storage versions.
|
||||||
|
|
||||||
|
### 0.1 -> 0.2
|
||||||
|
v0.2 fixes [a bug](https://github.com/gofiber/fiber/issues/1258) in MYSQL, Postgres and Arangodb in which
|
||||||
|
inserting non-UTF8 characters would trigger a panic due to the values being saved in a TEXT column instead of a
|
||||||
|
BYTEA/BLOB column. Migration instructions (note you may need to adjust the table names if you have supplied a custom
|
||||||
|
config to the storage):
|
||||||
|
|
||||||
|
**Postgres**
|
||||||
|
```sql
|
||||||
|
ALTER TABLE fiber_storage
|
||||||
|
ALTER COLUMN v TYPE BYTEA USING v::bytea;
|
||||||
|
```
|
||||||
|
|
||||||
|
**MYSQL**
|
||||||
|
```sql
|
||||||
|
ALTER TABLE fiber_storage MODIFY COLUMN v BLOB;
|
||||||
|
```
|
||||||
|
|
||||||
|
**Arangodb**
|
||||||
|
|
||||||
|
No migration other then updating the library is necessary.
|
@@ -49,16 +49,18 @@ type Storage interface {
|
|||||||
```
|
```
|
||||||
|
|
||||||
## 📑 Storage Implementations
|
## 📑 Storage Implementations
|
||||||
|
- [Aerospike](./aerospike/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+Aerospike%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-aerospike.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
||||||
- [ArangoDB](./arangodb/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+ArangoDB%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-arangodb.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
- [ArangoDB](./arangodb/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+ArangoDB%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-arangodb.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
||||||
- [AzureBlob](./azureblob/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+Azure+Blob%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-azureblob.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
- [AzureBlob](./azureblob/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+Azure+Blob%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-azureblob.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
||||||
- [Badger](./badger/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+Badger%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-badger.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
- [Badger](./badger/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+Badger%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-badger.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
||||||
- [Bbolt](./bbolt) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+Bbolt%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-bbolt.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
- [Bbolt](./bbolt) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+Bbolt%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-bbolt.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
||||||
|
- [Cassandra](./cassandra/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+Cassandra%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-cassandra.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
||||||
- [CloudflareKV](./cloudflarekv/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+CloudflareKV%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-cloudflarekv.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
- [CloudflareKV](./cloudflarekv/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+CloudflareKV%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-cloudflarekv.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
||||||
- [Coherence](./coherence/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+Coherence%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-coherence.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
- [Coherence](./coherence/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+Coherence%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-coherence.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
||||||
- [Couchbase](./couchbase/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+Couchbase%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-couchbase.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
- [Couchbase](./couchbase/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+Couchbase%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-couchbase.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
||||||
- [DynamoDB](./dynamodb/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+DynamoDB%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-dynamodb.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
- [DynamoDB](./dynamodb/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+DynamoDB%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-dynamodb.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
||||||
- [Etcd](./etcd/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+Etcd%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-etcd.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
- [Etcd](./etcd/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+Etcd%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-etcd.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
||||||
|
- [LevelDB](./leveldb/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+LevelDB%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-leveldb.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" alt="LevelDB Tests Status"/> </a>
|
||||||
- [Memcache](./memcache/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+Memcache%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-memcache.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
- [Memcache](./memcache/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+Memcache%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-memcache.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
||||||
- [Memory](./memory/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+Local+Storage%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-memory.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
- [Memory](./memory/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+Local+Storage%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-memory.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
||||||
- [Minio](./minio/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+Minio%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-minio.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
- [Minio](./minio/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+Minio%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-minio.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
||||||
@@ -67,6 +69,7 @@ type Storage interface {
|
|||||||
- [MSSQL](./mssql/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+MSSQL%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-mssql.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
- [MSSQL](./mssql/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+MSSQL%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-mssql.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
||||||
- [MySQL](./mysql/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+MySQL%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-mysql.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
- [MySQL](./mysql/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+MySQL%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-mysql.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
||||||
- [NATS](./nats/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests%20Nats%20Driver%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-nats.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
- [NATS](./nats/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests%20Nats%20Driver%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-nats.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
||||||
|
- [Neo4j](./neo4j/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+Neo4j%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-neo4j.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
||||||
- [Pebble](./pebble/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+Pebble%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-pebble.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
- [Pebble](./pebble/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+Pebble%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-pebble.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
||||||
- [Postgres](./postgres/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+Postgres%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-postgres.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
- [Postgres](./postgres/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+Postgres%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-postgres.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
||||||
- [Redis](./redis/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+Redis%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-redis.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
- [Redis](./redis/README.md) <a href="https://github.com/gofiber/storage/actions?query=workflow%3A%22Tests+Redis%22"> <img src="https://img.shields.io/github/actions/workflow/status/gofiber/storage/test-redis.yml?branch=main&label=%F0%9F%A7%AA%20&style=flat&color=75C46B" /> </a>
|
||||||
|
119
aerospike/README.md
Normal file
119
aerospike/README.md
Normal file
@@ -0,0 +1,119 @@
|
|||||||
|
---
|
||||||
|
id: aerospike
|
||||||
|
title: Aerospike
|
||||||
|
---
|
||||||
|
|
||||||
|

|
||||||
|
[](https://gofiber.io/discord)
|
||||||
|

|
||||||
|
|
||||||
|
An Aerospike client driver using `aerospike/aerospike-client-go` and [aerospike/aerospike-client-go](https://github.com/aerospike/aerospike-client-go).
|
||||||
|
|
||||||
|
**Note: Requires Go 1.23 and above**
|
||||||
|
|
||||||
|
### Table of Contents
|
||||||
|
|
||||||
|
- [Signatures](#signatures)
|
||||||
|
- [Installation](#installation)
|
||||||
|
- [Examples](#examples)
|
||||||
|
- [Config](#config)
|
||||||
|
- [Default Config](#default-config)
|
||||||
|
|
||||||
|
### Signatures
|
||||||
|
|
||||||
|
```go
|
||||||
|
func New(config ...Config) Storage
|
||||||
|
func (s *Storage) Get(key string) ([]byte, error)
|
||||||
|
func (s *Storage) Set(key string, val []byte, exp time.Duration) error
|
||||||
|
func (s *Storage) Delete(key string) error
|
||||||
|
func (s *Storage) Reset() error
|
||||||
|
func (s *Storage) Close() error
|
||||||
|
func (s *Storage) Conn() driver.Client
|
||||||
|
func (s *Storage) GetSchemaInfo() *SchemaInfo
|
||||||
|
```
|
||||||
|
|
||||||
|
### Installation
|
||||||
|
|
||||||
|
Aerospike is tested on the 2 last [Go versions](https://golang.org/dl/) with support for modules. So make sure to initialize one first if you didn't do that yet:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
go mod init github.com/<user>/<repo>
|
||||||
|
```
|
||||||
|
|
||||||
|
And then install the aerospike implementation:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
go get github.com/gofiber/storage/aerospike
|
||||||
|
```
|
||||||
|
|
||||||
|
### Examples
|
||||||
|
|
||||||
|
Import the storage package.
|
||||||
|
|
||||||
|
```go
|
||||||
|
import "github.com/gofiber/storage/aerospike"
|
||||||
|
```
|
||||||
|
|
||||||
|
You can use the following possibilities to create a storage:
|
||||||
|
|
||||||
|
```go
|
||||||
|
// Initialize default config
|
||||||
|
store := aerospike.New()
|
||||||
|
|
||||||
|
// Initialize custom config
|
||||||
|
store := aerospike.New(aerospike.Config{
|
||||||
|
Hosts: []*aerospike.Host{aerospike.NewHost("localhost", 3000)},
|
||||||
|
Namespace: "test", // Default namespace
|
||||||
|
SetName: "fiber",
|
||||||
|
Reset: false,
|
||||||
|
Expiration: 1 * time.Hour,
|
||||||
|
SchemaVersion: 1,
|
||||||
|
SchemaDescription: "Default Fiber storage schema",
|
||||||
|
ForceSchemaUpdate: false,
|
||||||
|
})
|
||||||
|
```
|
||||||
|
|
||||||
|
### Config
|
||||||
|
|
||||||
|
```go
|
||||||
|
type Config struct {
|
||||||
|
// Hosts is a list of Aerospike server hosts
|
||||||
|
Hosts []*aerospike.Host
|
||||||
|
|
||||||
|
// Namespace is the Aerospike namespace
|
||||||
|
Namespace string
|
||||||
|
|
||||||
|
// Set is the Aerospike set
|
||||||
|
SetName string
|
||||||
|
|
||||||
|
// Reset clears any existing keys in existing Set
|
||||||
|
Reset bool
|
||||||
|
|
||||||
|
// Expiration is the default expiration time of entries
|
||||||
|
Expiration time.Duration
|
||||||
|
|
||||||
|
// SchemaVersion indicates the schema version to use
|
||||||
|
SchemaVersion int
|
||||||
|
|
||||||
|
// SchemaDescription provides additional info about the schema
|
||||||
|
SchemaDescription string
|
||||||
|
|
||||||
|
// ForceSchemaUpdate forces schema update even if version matches
|
||||||
|
ForceSchemaUpdate bool
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### Default Config
|
||||||
|
Used only for optional fields
|
||||||
|
```go
|
||||||
|
var ConfigDefault = Config{
|
||||||
|
Hosts: []*aerospike.Host{aerospike.NewHost("localhost", 3000)},
|
||||||
|
Namespace: "test", // Default namespace
|
||||||
|
SetName: "fiber",
|
||||||
|
Reset: false,
|
||||||
|
Expiration: 1 * time.Hour,
|
||||||
|
SchemaVersion: 1,
|
||||||
|
SchemaDescription: "Default Fiber storage schema",
|
||||||
|
ForceSchemaUpdate: false,
|
||||||
|
}
|
||||||
|
```
|
300
aerospike/aerospike.go
Normal file
300
aerospike/aerospike.go
Normal file
@@ -0,0 +1,300 @@
|
|||||||
|
package aerospike
|
||||||
|
|
||||||
|
import (
|
||||||
|
"log"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"github.com/aerospike/aerospike-client-go/v8"
|
||||||
|
)
|
||||||
|
|
||||||
|
// Storage interface that is implemented by storage drivers
|
||||||
|
type Storage struct {
|
||||||
|
client *aerospike.Client
|
||||||
|
namespace string
|
||||||
|
setName string
|
||||||
|
reset bool
|
||||||
|
expiration time.Duration
|
||||||
|
schemaInfo *SchemaInfo
|
||||||
|
}
|
||||||
|
|
||||||
|
// SchemaInfo holds information about the schema structure
|
||||||
|
type SchemaInfo struct {
|
||||||
|
Version int
|
||||||
|
CreatedAt time.Time
|
||||||
|
UpdatedAt time.Time
|
||||||
|
Description string
|
||||||
|
}
|
||||||
|
|
||||||
|
// New creates a new storage
|
||||||
|
func New(config ...Config) *Storage {
|
||||||
|
|
||||||
|
// Set default config
|
||||||
|
cfg := configDefault(config...)
|
||||||
|
|
||||||
|
// connect to the host
|
||||||
|
cp := aerospike.NewClientPolicy()
|
||||||
|
cp.Timeout = cfg.InitialConnectionTimeout
|
||||||
|
|
||||||
|
// Create client
|
||||||
|
client, err := aerospike.NewClientWithPolicyAndHost(cp, cfg.Hosts...)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create storage
|
||||||
|
store := &Storage{
|
||||||
|
client: client,
|
||||||
|
namespace: cfg.Namespace,
|
||||||
|
setName: cfg.SetName,
|
||||||
|
reset: cfg.Reset,
|
||||||
|
expiration: cfg.Expiration,
|
||||||
|
}
|
||||||
|
|
||||||
|
// Reset keys if set
|
||||||
|
if cfg.Reset {
|
||||||
|
if err := store.Reset(); err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check and create schema
|
||||||
|
if err := store.createOrVerifySchema(cfg.SchemaVersion, cfg.SchemaDescription, cfg.ForceSchemaUpdate); err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// No additional GC needed as Aerospike handles TTL internally
|
||||||
|
|
||||||
|
return store
|
||||||
|
}
|
||||||
|
|
||||||
|
// createOrVerifySchema checks if schema exists and creates or updates if needed
|
||||||
|
func (s *Storage) createOrVerifySchema(version int, description string, forceUpdate bool) error {
|
||||||
|
|
||||||
|
// Schema info is stored with a special key
|
||||||
|
schemaKey, err := aerospike.NewKey(s.namespace, s.setName, "_schema_info")
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
// Try to get existing schema
|
||||||
|
record, err := s.client.Get(nil, schemaKey, "version", "created_at", "updated_at", "description")
|
||||||
|
if err != nil {
|
||||||
|
if err.Matches(aerospike.ErrKeyNotFound.ResultCode) {
|
||||||
|
// Schema doesn't exist, create it
|
||||||
|
return s.createSchema(schemaKey, version, description)
|
||||||
|
}
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
// Schema exists, check version
|
||||||
|
existingVersion, _ := record.Bins["version"].(int)
|
||||||
|
existingDescription, _ := record.Bins["description"].(string)
|
||||||
|
|
||||||
|
if existingVersion < version || forceUpdate {
|
||||||
|
// Update schema if version is higher or force update is true
|
||||||
|
return s.updateSchema(schemaKey, version, description, existingVersion)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Load existing schema info
|
||||||
|
createdAtStr, _ := record.Bins["created_at"].(string)
|
||||||
|
updatedAtStr, _ := record.Bins["updated_at"].(string)
|
||||||
|
|
||||||
|
createdAt, _ := time.Parse(time.RFC3339, createdAtStr)
|
||||||
|
updatedAt, _ := time.Parse(time.RFC3339, updatedAtStr)
|
||||||
|
|
||||||
|
// Store schema info
|
||||||
|
s.schemaInfo = &SchemaInfo{
|
||||||
|
Version: existingVersion,
|
||||||
|
CreatedAt: createdAt,
|
||||||
|
UpdatedAt: updatedAt,
|
||||||
|
Description: existingDescription,
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// createSchema creates a new schema
|
||||||
|
func (s *Storage) createSchema(schemaKey *aerospike.Key, version int, description string) error {
|
||||||
|
|
||||||
|
now := time.Now()
|
||||||
|
nowStr := now.Format(time.RFC3339)
|
||||||
|
|
||||||
|
// Create schema record
|
||||||
|
bins := aerospike.BinMap{
|
||||||
|
"version": version,
|
||||||
|
"created_at": nowStr,
|
||||||
|
"updated_at": nowStr,
|
||||||
|
"description": description,
|
||||||
|
}
|
||||||
|
|
||||||
|
// Never expire the schema info
|
||||||
|
writePolicy := aerospike.NewWritePolicy(0, 0)
|
||||||
|
|
||||||
|
// Store in Aerospike
|
||||||
|
err := s.client.Put(writePolicy, schemaKey, bins)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
// Store schema info
|
||||||
|
s.schemaInfo = &SchemaInfo{
|
||||||
|
Version: version,
|
||||||
|
CreatedAt: now,
|
||||||
|
UpdatedAt: now,
|
||||||
|
Description: description,
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// updateSchema updates an existing schema
|
||||||
|
func (s *Storage) updateSchema(schemaKey *aerospike.Key, version int, description string, oldVersion int) error {
|
||||||
|
now := time.Now()
|
||||||
|
nowStr := now.Format(time.RFC3339)
|
||||||
|
|
||||||
|
// Update schema record
|
||||||
|
bins := aerospike.BinMap{
|
||||||
|
"version": version,
|
||||||
|
"updated_at": nowStr,
|
||||||
|
"description": description,
|
||||||
|
}
|
||||||
|
|
||||||
|
// Never expire the schema info
|
||||||
|
writePolicy := aerospike.NewWritePolicy(0, 0)
|
||||||
|
|
||||||
|
// Store in Aerospike
|
||||||
|
err := s.client.Put(writePolicy, schemaKey, bins)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get creation date (it shouldn't change on update)
|
||||||
|
createdAtRecord, err := s.client.Get(nil, schemaKey, "created_at")
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
createdAtStr, _ := createdAtRecord.Bins["created_at"].(string)
|
||||||
|
createdAt, _ := time.Parse(time.RFC3339, createdAtStr)
|
||||||
|
|
||||||
|
// Store schema info
|
||||||
|
s.schemaInfo = &SchemaInfo{
|
||||||
|
Version: version,
|
||||||
|
CreatedAt: createdAt,
|
||||||
|
UpdatedAt: now,
|
||||||
|
Description: description,
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// GetSchemaInfo returns the current schema information
|
||||||
|
func (s *Storage) GetSchemaInfo() *SchemaInfo {
|
||||||
|
return s.schemaInfo
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get value by key
|
||||||
|
func (s *Storage) Get(key string) ([]byte, error) {
|
||||||
|
k, err := aerospike.NewKey(s.namespace, s.setName, key)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
record, err := s.client.Get(nil, k, "value")
|
||||||
|
if err != nil {
|
||||||
|
if err.Matches(aerospike.ErrKeyNotFound.ResultCode) {
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
data, ok := record.Bins["value"].([]byte)
|
||||||
|
if !ok {
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
return data, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// Set key with value
|
||||||
|
func (s *Storage) Set(key string, val []byte, exp time.Duration) error {
|
||||||
|
k, err := aerospike.NewKey(s.namespace, s.setName, key)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
expiration := s.expiration
|
||||||
|
if exp != 0 {
|
||||||
|
expiration = exp
|
||||||
|
}
|
||||||
|
|
||||||
|
// Convert to seconds with a minimum of 1
|
||||||
|
ttl := uint32(expiration.Seconds())
|
||||||
|
if ttl < 1 {
|
||||||
|
ttl = 1
|
||||||
|
}
|
||||||
|
|
||||||
|
writePolicy := aerospike.NewWritePolicy(0, ttl)
|
||||||
|
bins := aerospike.BinMap{
|
||||||
|
"value": val,
|
||||||
|
}
|
||||||
|
|
||||||
|
return s.client.Put(writePolicy, k, bins)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Delete key
|
||||||
|
func (s *Storage) Delete(key string) error {
|
||||||
|
k, err := aerospike.NewKey(s.namespace, s.setName, key)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
_, err = s.client.Delete(nil, k)
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
// Reset all keys
|
||||||
|
func (s *Storage) Reset() error {
|
||||||
|
// Use ScanAll which returns a Recordset
|
||||||
|
scanPolicy := aerospike.NewScanPolicy()
|
||||||
|
// Note: ConcurrentNodes no longer exists in v8
|
||||||
|
|
||||||
|
recordset, err := s.client.ScanAll(scanPolicy, s.namespace, s.setName)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
// Ensure recordset is closed when we're done
|
||||||
|
defer func() {
|
||||||
|
if err := recordset.Close(); err != nil {
|
||||||
|
log.Printf("Error closing recordset: %v\n", err)
|
||||||
|
}
|
||||||
|
}()
|
||||||
|
|
||||||
|
// Create a write policy for deletes
|
||||||
|
writePolicy := aerospike.NewWritePolicy(0, 0)
|
||||||
|
|
||||||
|
// Iterate through all records and delete them
|
||||||
|
for result := range recordset.Results() {
|
||||||
|
if result.Err != nil {
|
||||||
|
// Log the error but continue with other records
|
||||||
|
log.Printf("Error scanning: %v\n", result.Err)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
// Delete the record
|
||||||
|
_, err = s.client.Delete(writePolicy, result.Record.Key)
|
||||||
|
if err != nil {
|
||||||
|
// Log the error but continue with other records
|
||||||
|
log.Printf("Error deleting key %v: %v\n", result.Record.Key, err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// Close the storage
|
||||||
|
func (s *Storage) Close() error {
|
||||||
|
s.client.Close()
|
||||||
|
return nil
|
||||||
|
}
|
248
aerospike/aerospike_test.go
Normal file
248
aerospike/aerospike_test.go
Normal file
@@ -0,0 +1,248 @@
|
|||||||
|
package aerospike
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"os"
|
||||||
|
"testing"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"github.com/aerospike/aerospike-client-go/v8"
|
||||||
|
"github.com/stretchr/testify/require"
|
||||||
|
"github.com/testcontainers/testcontainers-go"
|
||||||
|
"github.com/testcontainers/testcontainers-go/wait"
|
||||||
|
)
|
||||||
|
|
||||||
|
const (
|
||||||
|
// aerospikeImage is the default image used for running Aerospike in tests.
|
||||||
|
aerospikeImage = "aerospike/aerospike-server:latest"
|
||||||
|
aerospikeImageEnvVar string = "TEST_AEROSPIKE_IMAGE"
|
||||||
|
aerospikePort = "3000/tcp"
|
||||||
|
fabricPort = "3001/tcp"
|
||||||
|
heartbeatPort = "3002/tcp"
|
||||||
|
infoPort = "3003/tcp"
|
||||||
|
aerospikeReadyLog = "migrations: complete"
|
||||||
|
aerospikeNamespace = "test"
|
||||||
|
)
|
||||||
|
|
||||||
|
// startAerospikeContainer starts an Aerospike container for testing
|
||||||
|
func startAerospikeContainer(t testing.TB, ctx context.Context) testcontainers.Container {
|
||||||
|
t.Helper()
|
||||||
|
|
||||||
|
// Get custom image from env if specified
|
||||||
|
image := aerospikeImage
|
||||||
|
if envImage := os.Getenv(aerospikeImageEnvVar); envImage != "" {
|
||||||
|
image = envImage
|
||||||
|
}
|
||||||
|
|
||||||
|
// Container config
|
||||||
|
req := testcontainers.ContainerRequest{
|
||||||
|
Image: image,
|
||||||
|
ExposedPorts: []string{aerospikePort, fabricPort, heartbeatPort, infoPort},
|
||||||
|
WaitingFor: wait.ForAll(
|
||||||
|
wait.ForLog(aerospikeReadyLog),
|
||||||
|
wait.ForListeningPort(aerospikePort).WithStartupTimeout(5*time.Second),
|
||||||
|
wait.ForListeningPort(fabricPort).WithStartupTimeout(5*time.Second),
|
||||||
|
wait.ForListeningPort(heartbeatPort).WithStartupTimeout(5*time.Second),
|
||||||
|
),
|
||||||
|
Cmd: []string{
|
||||||
|
"--config-file",
|
||||||
|
"/etc/aerospike/aerospike.conf",
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
// Start container
|
||||||
|
ctr, err := testcontainers.GenericContainer(ctx, testcontainers.GenericContainerRequest{
|
||||||
|
ContainerRequest: req,
|
||||||
|
Started: true,
|
||||||
|
})
|
||||||
|
testcontainers.CleanupContainer(t, ctr)
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
return ctr
|
||||||
|
}
|
||||||
|
|
||||||
|
// newTestStore creates a client connected to the test container
|
||||||
|
func newTestStore(t testing.TB) *Storage {
|
||||||
|
t.Helper()
|
||||||
|
|
||||||
|
c := startAerospikeContainer(t, context.Background())
|
||||||
|
|
||||||
|
// Extract host and port
|
||||||
|
host, err := c.Host(context.TODO())
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
port, err := c.MappedPort(context.TODO(), aerospikePort)
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
return New(Config{
|
||||||
|
Hosts: []*aerospike.Host{aerospike.NewHost(host, port.Int())},
|
||||||
|
Reset: true,
|
||||||
|
Namespace: aerospikeNamespace,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
// Test_AeroSpikeDB_Get tests the Get method
|
||||||
|
func Test_AeroSpikeDB_Get(t *testing.T) {
|
||||||
|
var (
|
||||||
|
key = "john"
|
||||||
|
val = []byte("doe")
|
||||||
|
)
|
||||||
|
|
||||||
|
testStore := newTestStore(t)
|
||||||
|
defer testStore.Close()
|
||||||
|
|
||||||
|
// Set a value
|
||||||
|
err := testStore.Set(key, val, 0)
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
// Get the value
|
||||||
|
retrievedVal, err := testStore.Get(key)
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Equal(t, val, retrievedVal)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Test_AeroSpikeDB_Delete tests the Delete method
|
||||||
|
func Test_AeroSpikeDB_Delete(t *testing.T) {
|
||||||
|
|
||||||
|
var (
|
||||||
|
key = "john"
|
||||||
|
val = []byte("doe")
|
||||||
|
)
|
||||||
|
|
||||||
|
testStore := newTestStore(t)
|
||||||
|
defer testStore.Close()
|
||||||
|
|
||||||
|
// Set a value
|
||||||
|
err := testStore.Set(key, val, 0)
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
// Delete the value
|
||||||
|
err = testStore.Delete(key)
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
// Try to get the deleted value
|
||||||
|
retrievedVal, err := testStore.Get(key)
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Nil(t, retrievedVal)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Test_AeroSpikeDB_SetWithExpiration tests the Set method with expiration
|
||||||
|
func Test_AeroSpikeDB_SetWithExpiration(t *testing.T) {
|
||||||
|
var (
|
||||||
|
key = "temp"
|
||||||
|
val = []byte("value")
|
||||||
|
)
|
||||||
|
|
||||||
|
testStore := newTestStore(t)
|
||||||
|
defer testStore.Close()
|
||||||
|
|
||||||
|
// Set a value with 1 second expiration
|
||||||
|
err := testStore.Set(key, val, 1*time.Second)
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
// Verify the value exists initially
|
||||||
|
retrievedVal, err := testStore.Get(key)
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Equal(t, val, retrievedVal)
|
||||||
|
|
||||||
|
// Wait for expiration
|
||||||
|
time.Sleep(2 * time.Second)
|
||||||
|
|
||||||
|
// Verify the value is gone
|
||||||
|
retrievedVal, err = testStore.Get(key)
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Nil(t, retrievedVal)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Test_AeroSpikeDB_Reset tests the Reset method
|
||||||
|
func Test_AeroSpikeDB_Reset(t *testing.T) {
|
||||||
|
|
||||||
|
var (
|
||||||
|
key1 = "john"
|
||||||
|
val1 = []byte("doe")
|
||||||
|
key2 = "jane"
|
||||||
|
val2 = []byte("smith")
|
||||||
|
)
|
||||||
|
|
||||||
|
testStore := newTestStore(t)
|
||||||
|
defer testStore.Close()
|
||||||
|
|
||||||
|
// Set multiple values
|
||||||
|
err := testStore.Set(key1, val1, 0)
|
||||||
|
require.NoError(t, err)
|
||||||
|
err = testStore.Set(key2, val2, 0)
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
// Reset the store
|
||||||
|
err = testStore.Reset()
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
// Ensure keys are deleted
|
||||||
|
retrievedVal1, err := testStore.Get(key1)
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Nil(t, retrievedVal1)
|
||||||
|
|
||||||
|
retrievedVal2, err := testStore.Get(key2)
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Nil(t, retrievedVal2)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Test_AeroSpikeDB_GetSchemaInfo tests the GetSchemaInfo method
|
||||||
|
func Test_AeroSpikeDB_GetSchemaInfo(t *testing.T) {
|
||||||
|
|
||||||
|
testStore := newTestStore(t)
|
||||||
|
defer testStore.Close()
|
||||||
|
|
||||||
|
// Get schema info
|
||||||
|
schemaInfo := testStore.GetSchemaInfo()
|
||||||
|
require.NotNil(t, schemaInfo)
|
||||||
|
require.GreaterOrEqual(t, schemaInfo.Version, 1)
|
||||||
|
}
|
||||||
|
|
||||||
|
func Benchmark_AeroSpikeDB_Set(b *testing.B) {
|
||||||
|
b.ReportAllocs()
|
||||||
|
b.ResetTimer()
|
||||||
|
|
||||||
|
testStore := newTestStore(b)
|
||||||
|
defer testStore.Close()
|
||||||
|
|
||||||
|
var err error
|
||||||
|
for i := 0; i < b.N; i++ {
|
||||||
|
err = testStore.Set("john", []byte("doe"), 0)
|
||||||
|
}
|
||||||
|
|
||||||
|
require.NoError(b, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
func Benchmark_AeroSpikeDB_Get(b *testing.B) {
|
||||||
|
testStore := newTestStore(b)
|
||||||
|
defer testStore.Close()
|
||||||
|
|
||||||
|
err := testStore.Set("john", []byte("doe"), 0)
|
||||||
|
require.NoError(b, err)
|
||||||
|
|
||||||
|
b.ReportAllocs()
|
||||||
|
b.ResetTimer()
|
||||||
|
|
||||||
|
for i := 0; i < b.N; i++ {
|
||||||
|
_, err = testStore.Get("john")
|
||||||
|
}
|
||||||
|
|
||||||
|
require.NoError(b, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
func Benchmark_AeroSpikeDB_SetAndDelete(b *testing.B) {
|
||||||
|
b.ReportAllocs()
|
||||||
|
b.ResetTimer()
|
||||||
|
|
||||||
|
testStore := newTestStore(b)
|
||||||
|
defer testStore.Close()
|
||||||
|
|
||||||
|
var err error
|
||||||
|
for i := 0; i < b.N; i++ {
|
||||||
|
_ = testStore.Set("john", []byte("doe"), 0)
|
||||||
|
err = testStore.Delete("john")
|
||||||
|
}
|
||||||
|
|
||||||
|
require.NoError(b, err)
|
||||||
|
}
|
89
aerospike/config.go
Normal file
89
aerospike/config.go
Normal file
@@ -0,0 +1,89 @@
|
|||||||
|
package aerospike
|
||||||
|
|
||||||
|
import (
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"github.com/aerospike/aerospike-client-go/v8"
|
||||||
|
)
|
||||||
|
|
||||||
|
// Config defines the config for storage.
|
||||||
|
type Config struct {
|
||||||
|
// Hosts is a list of Aerospike server hosts
|
||||||
|
Hosts []*aerospike.Host
|
||||||
|
|
||||||
|
// Namespace is the Aerospike namespace
|
||||||
|
Namespace string
|
||||||
|
|
||||||
|
// SetName is the Aerospike Set name
|
||||||
|
SetName string
|
||||||
|
|
||||||
|
// Reset clears any existing keys in existing Set
|
||||||
|
Reset bool
|
||||||
|
|
||||||
|
// Expiration is the default expiration time of entries
|
||||||
|
Expiration time.Duration
|
||||||
|
|
||||||
|
// SchemaVersion indicates the schema version to use
|
||||||
|
SchemaVersion int
|
||||||
|
|
||||||
|
// SchemaDescription provides additional info about the schema
|
||||||
|
SchemaDescription string
|
||||||
|
|
||||||
|
// ForceSchemaUpdate forces schema update even if version matches
|
||||||
|
ForceSchemaUpdate bool
|
||||||
|
|
||||||
|
// Initial host connection timeout duration. The timeout when opening a connection
|
||||||
|
// to the server host for the first time.
|
||||||
|
InitialConnectionTimeout time.Duration
|
||||||
|
}
|
||||||
|
|
||||||
|
// ConfigDefault is the default config
|
||||||
|
var ConfigDefault = Config{
|
||||||
|
Hosts: []*aerospike.Host{aerospike.NewHost("localhost", 3000)},
|
||||||
|
Namespace: "test", // Default namespace
|
||||||
|
SetName: "fiber",
|
||||||
|
Reset: false,
|
||||||
|
Expiration: 1 * time.Hour,
|
||||||
|
SchemaVersion: 1,
|
||||||
|
SchemaDescription: "Default Fiber storage schema",
|
||||||
|
ForceSchemaUpdate: false,
|
||||||
|
InitialConnectionTimeout: 10 * time.Second,
|
||||||
|
}
|
||||||
|
|
||||||
|
// Helper function to set default values
|
||||||
|
func configDefault(config ...Config) Config {
|
||||||
|
// Return default config if nothing provided
|
||||||
|
if len(config) < 1 {
|
||||||
|
return ConfigDefault
|
||||||
|
}
|
||||||
|
|
||||||
|
// Override default config
|
||||||
|
cfg := config[0]
|
||||||
|
|
||||||
|
// Set default values for missing fields
|
||||||
|
if cfg.Hosts == nil {
|
||||||
|
cfg.Hosts = ConfigDefault.Hosts
|
||||||
|
}
|
||||||
|
if cfg.Namespace == "" {
|
||||||
|
cfg.Namespace = ConfigDefault.Namespace
|
||||||
|
}
|
||||||
|
if cfg.SetName == "" {
|
||||||
|
cfg.SetName = ConfigDefault.SetName
|
||||||
|
}
|
||||||
|
// Reset is a boolean, so we can't check for zero value
|
||||||
|
// It's maintained as-is from user config
|
||||||
|
if cfg.Expiration == 0 {
|
||||||
|
cfg.Expiration = ConfigDefault.Expiration
|
||||||
|
}
|
||||||
|
if cfg.SchemaVersion == 0 {
|
||||||
|
cfg.SchemaVersion = ConfigDefault.SchemaVersion
|
||||||
|
}
|
||||||
|
if cfg.SchemaDescription == "" {
|
||||||
|
cfg.SchemaDescription = ConfigDefault.SchemaDescription
|
||||||
|
}
|
||||||
|
if cfg.InitialConnectionTimeout == 0 {
|
||||||
|
cfg.InitialConnectionTimeout = ConfigDefault.InitialConnectionTimeout
|
||||||
|
}
|
||||||
|
|
||||||
|
return cfg
|
||||||
|
}
|
67
aerospike/go.mod
Normal file
67
aerospike/go.mod
Normal file
@@ -0,0 +1,67 @@
|
|||||||
|
module github.com/gofiber/storage/aerospike
|
||||||
|
|
||||||
|
go 1.23.0
|
||||||
|
|
||||||
|
require (
|
||||||
|
github.com/aerospike/aerospike-client-go/v8 v8.2.1
|
||||||
|
github.com/stretchr/testify v1.10.0
|
||||||
|
github.com/testcontainers/testcontainers-go v0.36.0
|
||||||
|
)
|
||||||
|
|
||||||
|
require (
|
||||||
|
dario.cat/mergo v1.0.1 // indirect
|
||||||
|
github.com/Azure/go-ansiterm v0.0.0-20250102033503-faa5f7b0171c // indirect
|
||||||
|
github.com/Microsoft/go-winio v0.6.2 // indirect
|
||||||
|
github.com/cenkalti/backoff/v4 v4.3.0 // indirect
|
||||||
|
github.com/containerd/log v0.1.0 // indirect
|
||||||
|
github.com/containerd/platforms v0.2.1 // indirect
|
||||||
|
github.com/cpuguy83/dockercfg v0.3.2 // indirect
|
||||||
|
github.com/davecgh/go-spew v1.1.1 // indirect
|
||||||
|
github.com/distribution/reference v0.6.0 // indirect
|
||||||
|
github.com/docker/docker v28.0.4+incompatible // indirect
|
||||||
|
github.com/docker/go-connections v0.5.0 // indirect
|
||||||
|
github.com/docker/go-units v0.5.0 // indirect
|
||||||
|
github.com/ebitengine/purego v0.8.2 // indirect
|
||||||
|
github.com/felixge/httpsnoop v1.0.4 // indirect
|
||||||
|
github.com/go-logr/logr v1.4.2 // indirect
|
||||||
|
github.com/go-logr/stdr v1.2.2 // indirect
|
||||||
|
github.com/go-ole/go-ole v1.3.0 // indirect
|
||||||
|
github.com/gogo/protobuf v1.3.2 // indirect
|
||||||
|
github.com/google/uuid v1.6.0 // indirect
|
||||||
|
github.com/klauspost/compress v1.18.0 // indirect
|
||||||
|
github.com/lufia/plan9stats v0.0.0-20250317134145-8bc96cf8fc35 // indirect
|
||||||
|
github.com/magiconair/properties v1.8.10 // indirect
|
||||||
|
github.com/moby/docker-image-spec v1.3.1 // indirect
|
||||||
|
github.com/moby/patternmatcher v0.6.0 // indirect
|
||||||
|
github.com/moby/sys/sequential v0.6.0 // indirect
|
||||||
|
github.com/moby/sys/user v0.4.0 // indirect
|
||||||
|
github.com/moby/sys/userns v0.1.0 // indirect
|
||||||
|
github.com/moby/term v0.5.2 // indirect
|
||||||
|
github.com/morikuni/aec v1.0.0 // indirect
|
||||||
|
github.com/opencontainers/go-digest v1.0.0 // indirect
|
||||||
|
github.com/opencontainers/image-spec v1.1.1 // indirect
|
||||||
|
github.com/pkg/errors v0.9.1 // indirect
|
||||||
|
github.com/pmezard/go-difflib v1.0.0 // indirect
|
||||||
|
github.com/power-devops/perfstat v0.0.0-20240221224432-82ca36839d55 // indirect
|
||||||
|
github.com/rogpeppe/go-internal v1.14.1 // indirect
|
||||||
|
github.com/shirou/gopsutil/v4 v4.25.3 // indirect
|
||||||
|
github.com/sirupsen/logrus v1.9.3 // indirect
|
||||||
|
github.com/tklauser/go-sysconf v0.3.15 // indirect
|
||||||
|
github.com/tklauser/numcpus v0.10.0 // indirect
|
||||||
|
github.com/wadey/gocovmerge v0.0.0-20160331181800-b5bfa59ec0ad // indirect
|
||||||
|
github.com/yuin/gopher-lua v1.1.1 // indirect
|
||||||
|
github.com/yusufpapurcu/wmi v1.2.4 // indirect
|
||||||
|
go.opentelemetry.io/auto/sdk v1.1.0 // indirect
|
||||||
|
go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.60.0 // indirect
|
||||||
|
go.opentelemetry.io/otel v1.35.0 // indirect
|
||||||
|
go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.35.0 // indirect
|
||||||
|
go.opentelemetry.io/otel/metric v1.35.0 // indirect
|
||||||
|
go.opentelemetry.io/otel/trace v1.35.0 // indirect
|
||||||
|
go.opentelemetry.io/proto/otlp v1.5.0 // indirect
|
||||||
|
golang.org/x/crypto v0.37.0 // indirect
|
||||||
|
golang.org/x/sync v0.13.0 // indirect
|
||||||
|
golang.org/x/sys v0.32.0 // indirect
|
||||||
|
golang.org/x/tools v0.32.0 // indirect
|
||||||
|
google.golang.org/protobuf v1.36.5 // indirect
|
||||||
|
gopkg.in/yaml.v3 v3.0.1 // indirect
|
||||||
|
)
|
203
aerospike/go.sum
Normal file
203
aerospike/go.sum
Normal file
@@ -0,0 +1,203 @@
|
|||||||
|
dario.cat/mergo v1.0.1 h1:Ra4+bf83h2ztPIQYNP99R6m+Y7KfnARDfID+a+vLl4s=
|
||||||
|
dario.cat/mergo v1.0.1/go.mod h1:uNxQE+84aUszobStD9th8a29P2fMDhsBdgRYvZOxGmk=
|
||||||
|
github.com/AdaLogics/go-fuzz-headers v0.0.0-20230811130428-ced1acdcaa24 h1:bvDV9vkmnHYOMsOr4WLk+Vo07yKIzd94sVoIqshQ4bU=
|
||||||
|
github.com/AdaLogics/go-fuzz-headers v0.0.0-20230811130428-ced1acdcaa24/go.mod h1:8o94RPi1/7XTJvwPpRSzSUedZrtlirdB3r9Z20bi2f8=
|
||||||
|
github.com/Azure/go-ansiterm v0.0.0-20250102033503-faa5f7b0171c h1:udKWzYgxTojEKWjV8V+WSxDXJ4NFATAsZjh8iIbsQIg=
|
||||||
|
github.com/Azure/go-ansiterm v0.0.0-20250102033503-faa5f7b0171c/go.mod h1:xomTg63KZ2rFqZQzSB4Vz2SUXa1BpHTVz9L5PTmPC4E=
|
||||||
|
github.com/Microsoft/go-winio v0.6.2 h1:F2VQgta7ecxGYO8k3ZZz3RS8fVIXVxONVUPlNERoyfY=
|
||||||
|
github.com/Microsoft/go-winio v0.6.2/go.mod h1:yd8OoFMLzJbo9gZq8j5qaps8bJ9aShtEA8Ipt1oGCvU=
|
||||||
|
github.com/aerospike/aerospike-client-go/v8 v8.2.1 h1:Vxp+E1Sj+r5o67x+BP8FE07DVwo7x1AHWzfnQU1wzIU=
|
||||||
|
github.com/aerospike/aerospike-client-go/v8 v8.2.1/go.mod h1:H6CzKDoHxBj1yY/oQPci1bUIbEx2ATQtJ2GtZ+N64Wg=
|
||||||
|
github.com/cenkalti/backoff/v4 v4.3.0 h1:MyRJ/UdXutAwSAT+s3wNd7MfTIcy71VQueUuFK343L8=
|
||||||
|
github.com/cenkalti/backoff/v4 v4.3.0/go.mod h1:Y3VNntkOUPxTVeUxJ/G5vcM//AlwfmyYozVcomhLiZE=
|
||||||
|
github.com/containerd/log v0.1.0 h1:TCJt7ioM2cr/tfR8GPbGf9/VRAX8D2B4PjzCpfX540I=
|
||||||
|
github.com/containerd/log v0.1.0/go.mod h1:VRRf09a7mHDIRezVKTRCrOq78v577GXq3bSa3EhrzVo=
|
||||||
|
github.com/containerd/platforms v0.2.1 h1:zvwtM3rz2YHPQsF2CHYM8+KtB5dvhISiXh5ZpSBQv6A=
|
||||||
|
github.com/containerd/platforms v0.2.1/go.mod h1:XHCb+2/hzowdiut9rkudds9bE5yJ7npe7dG/wG+uFPw=
|
||||||
|
github.com/cpuguy83/dockercfg v0.3.2 h1:DlJTyZGBDlXqUZ2Dk2Q3xHs/FtnooJJVaad2S9GKorA=
|
||||||
|
github.com/cpuguy83/dockercfg v0.3.2/go.mod h1:sugsbF4//dDlL/i+S+rtpIWp+5h0BHJHfjj5/jFyUJc=
|
||||||
|
github.com/creack/pty v1.1.18 h1:n56/Zwd5o6whRC5PMGretI4IdRLlmBXYNjScPaBgsbY=
|
||||||
|
github.com/creack/pty v1.1.18/go.mod h1:MOBLtS5ELjhRRrroQr9kyvTxUAFNvYEK993ew/Vr4O4=
|
||||||
|
github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
||||||
|
github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c=
|
||||||
|
github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
||||||
|
github.com/distribution/reference v0.6.0 h1:0IXCQ5g4/QMHHkarYzh5l+u8T3t73zM5QvfrDyIgxBk=
|
||||||
|
github.com/distribution/reference v0.6.0/go.mod h1:BbU0aIcezP1/5jX/8MP0YiH4SdvB5Y4f/wlDRiLyi3E=
|
||||||
|
github.com/docker/docker v28.0.4+incompatible h1:JNNkBctYKurkw6FrHfKqY0nKIDf5nrbxjVBtS+cdcok=
|
||||||
|
github.com/docker/docker v28.0.4+incompatible/go.mod h1:eEKB0N0r5NX/I1kEveEz05bcu8tLC/8azJZsviup8Sk=
|
||||||
|
github.com/docker/go-connections v0.5.0 h1:USnMq7hx7gwdVZq1L49hLXaFtUdTADjXGp+uj1Br63c=
|
||||||
|
github.com/docker/go-connections v0.5.0/go.mod h1:ov60Kzw0kKElRwhNs9UlUHAE/F9Fe6GLaXnqyDdmEXc=
|
||||||
|
github.com/docker/go-units v0.5.0 h1:69rxXcBk27SvSaaxTtLh/8llcHD8vYHT7WSdRZ/jvr4=
|
||||||
|
github.com/docker/go-units v0.5.0/go.mod h1:fgPhTUdO+D/Jk86RDLlptpiXQzgHJF7gydDDbaIK4Dk=
|
||||||
|
github.com/ebitengine/purego v0.8.2 h1:jPPGWs2sZ1UgOSgD2bClL0MJIqu58nOmIcBuXr62z1I=
|
||||||
|
github.com/ebitengine/purego v0.8.2/go.mod h1:iIjxzd6CiRiOG0UyXP+V1+jWqUXVjPKLAI0mRfJZTmQ=
|
||||||
|
github.com/felixge/httpsnoop v1.0.4 h1:NFTV2Zj1bL4mc9sqWACXbQFVBBg2W3GPvqp8/ESS2Wg=
|
||||||
|
github.com/felixge/httpsnoop v1.0.4/go.mod h1:m8KPJKqk1gH5J9DgRY2ASl2lWCfGKXixSwevea8zH2U=
|
||||||
|
github.com/go-logr/logr v1.2.2/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbVz/1A=
|
||||||
|
github.com/go-logr/logr v1.4.2 h1:6pFjapn8bFcIbiKo3XT4j/BhANplGihG6tvd+8rYgrY=
|
||||||
|
github.com/go-logr/logr v1.4.2/go.mod h1:9T104GzyrTigFIr8wt5mBrctHMim0Nb2HLGrmQ40KvY=
|
||||||
|
github.com/go-logr/stdr v1.2.2 h1:hSWxHoqTgW2S2qGc0LTAI563KZ5YKYRhT3MFKZMbjag=
|
||||||
|
github.com/go-logr/stdr v1.2.2/go.mod h1:mMo/vtBO5dYbehREoey6XUKy/eSumjCCveDpRre4VKE=
|
||||||
|
github.com/go-ole/go-ole v1.2.6/go.mod h1:pprOEPIfldk/42T2oK7lQ4v4JSDwmV0As9GaiUsvbm0=
|
||||||
|
github.com/go-ole/go-ole v1.3.0 h1:Dt6ye7+vXGIKZ7Xtk4s6/xVdGDQynvom7xCFEdWr6uE=
|
||||||
|
github.com/go-ole/go-ole v1.3.0/go.mod h1:5LS6F96DhAwUc7C+1HLexzMXY1xGRSryjyPPKW6zv78=
|
||||||
|
github.com/go-task/slim-sprig/v3 v3.0.0 h1:sUs3vkvUymDpBKi3qH1YSqBQk9+9D/8M2mN1vB6EwHI=
|
||||||
|
github.com/go-task/slim-sprig/v3 v3.0.0/go.mod h1:W848ghGpv3Qj3dhTPRyJypKRiqCdHZiAzKg9hl15HA8=
|
||||||
|
github.com/gogo/protobuf v1.3.2 h1:Ov1cvc58UF3b5XjBnZv7+opcTcQFZebYjWzi34vdm4Q=
|
||||||
|
github.com/gogo/protobuf v1.3.2/go.mod h1:P1XiOD3dCwIKUDQYPy72D8LYyHL2YPYrpS2s69NZV8Q=
|
||||||
|
github.com/google/go-cmp v0.7.0 h1:wk8382ETsv4JYUZwIsn6YpYiWiBsYLSJiTsyBybVuN8=
|
||||||
|
github.com/google/go-cmp v0.7.0/go.mod h1:pXiqmnSA92OHEEa9HXL2W4E7lf9JzCmGVUdgjX3N/iU=
|
||||||
|
github.com/google/pprof v0.0.0-20241210010833-40e02aabc2ad h1:a6HEuzUHeKH6hwfN/ZoQgRgVIWFJljSWa/zetS2WTvg=
|
||||||
|
github.com/google/pprof v0.0.0-20241210010833-40e02aabc2ad/go.mod h1:vavhavw2zAxS5dIdcRluK6cSGGPlZynqzFM8NdvU144=
|
||||||
|
github.com/google/uuid v1.6.0 h1:NIvaJDMOsjHA8n1jAhLSgzrAzy1Hgr+hNrb57e+94F0=
|
||||||
|
github.com/google/uuid v1.6.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo=
|
||||||
|
github.com/grpc-ecosystem/grpc-gateway/v2 v2.25.1 h1:VNqngBF40hVlDloBruUehVYC3ArSgIyScOAyMRqBxRg=
|
||||||
|
github.com/grpc-ecosystem/grpc-gateway/v2 v2.25.1/go.mod h1:RBRO7fro65R6tjKzYgLAFo0t1QEXY1Dp+i/bvpRiqiQ=
|
||||||
|
github.com/kisielk/errcheck v1.5.0/go.mod h1:pFxgyoBC7bSaBwPgfKdkLd5X25qrDl4LWUI2bnpBCr8=
|
||||||
|
github.com/kisielk/gotool v1.0.0/go.mod h1:XhKaO+MFFWcvkIS/tQcRk01m1F5IRFswLeQ+oQHNcck=
|
||||||
|
github.com/klauspost/compress v1.18.0 h1:c/Cqfb0r+Yi+JtIEq73FWXVkRonBlf0CRNYc8Zttxdo=
|
||||||
|
github.com/klauspost/compress v1.18.0/go.mod h1:2Pp+KzxcywXVXMr50+X0Q/Lsb43OQHYWRCY2AiWywWQ=
|
||||||
|
github.com/kr/pretty v0.3.1 h1:flRD4NNwYAUpkphVc1HcthR4KEIFJ65n8Mw5qdRn3LE=
|
||||||
|
github.com/kr/pretty v0.3.1/go.mod h1:hoEshYVHaxMs3cyo3Yncou5ZscifuDolrwPKZanG3xk=
|
||||||
|
github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY=
|
||||||
|
github.com/kr/text v0.2.0/go.mod h1:eLer722TekiGuMkidMxC/pM04lWEeraHUUmBw8l2grE=
|
||||||
|
github.com/lufia/plan9stats v0.0.0-20250317134145-8bc96cf8fc35 h1:PpXWgLPs+Fqr325bN2FD2ISlRRztXibcX6e8f5FR5Dc=
|
||||||
|
github.com/lufia/plan9stats v0.0.0-20250317134145-8bc96cf8fc35/go.mod h1:autxFIvghDt3jPTLoqZ9OZ7s9qTGNAWmYCjVFWPX/zg=
|
||||||
|
github.com/magiconair/properties v1.8.10 h1:s31yESBquKXCV9a/ScB3ESkOjUYYv+X0rg8SYxI99mE=
|
||||||
|
github.com/magiconair/properties v1.8.10/go.mod h1:Dhd985XPs7jluiymwWYZ0G4Z61jb3vdS329zhj2hYo0=
|
||||||
|
github.com/moby/docker-image-spec v1.3.1 h1:jMKff3w6PgbfSa69GfNg+zN/XLhfXJGnEx3Nl2EsFP0=
|
||||||
|
github.com/moby/docker-image-spec v1.3.1/go.mod h1:eKmb5VW8vQEh/BAr2yvVNvuiJuY6UIocYsFu/DxxRpo=
|
||||||
|
github.com/moby/patternmatcher v0.6.0 h1:GmP9lR19aU5GqSSFko+5pRqHi+Ohk1O69aFiKkVGiPk=
|
||||||
|
github.com/moby/patternmatcher v0.6.0/go.mod h1:hDPoyOpDY7OrrMDLaYoY3hf52gNCR/YOUYxkhApJIxc=
|
||||||
|
github.com/moby/sys/sequential v0.6.0 h1:qrx7XFUd/5DxtqcoH1h438hF5TmOvzC/lspjy7zgvCU=
|
||||||
|
github.com/moby/sys/sequential v0.6.0/go.mod h1:uyv8EUTrca5PnDsdMGXhZe6CCe8U/UiTWd+lL+7b/Ko=
|
||||||
|
github.com/moby/sys/user v0.4.0 h1:jhcMKit7SA80hivmFJcbB1vqmw//wU61Zdui2eQXuMs=
|
||||||
|
github.com/moby/sys/user v0.4.0/go.mod h1:bG+tYYYJgaMtRKgEmuueC0hJEAZWwtIbZTB+85uoHjs=
|
||||||
|
github.com/moby/sys/userns v0.1.0 h1:tVLXkFOxVu9A64/yh59slHVv9ahO9UIev4JZusOLG/g=
|
||||||
|
github.com/moby/sys/userns v0.1.0/go.mod h1:IHUYgu/kao6N8YZlp9Cf444ySSvCmDlmzUcYfDHOl28=
|
||||||
|
github.com/moby/term v0.5.2 h1:6qk3FJAFDs6i/q3W/pQ97SX192qKfZgGjCQqfCJkgzQ=
|
||||||
|
github.com/moby/term v0.5.2/go.mod h1:d3djjFCrjnB+fl8NJux+EJzu0msscUP+f8it8hPkFLc=
|
||||||
|
github.com/morikuni/aec v1.0.0 h1:nP9CBfwrvYnBRgY6qfDQkygYDmYwOilePFkwzv4dU8A=
|
||||||
|
github.com/morikuni/aec v1.0.0/go.mod h1:BbKIizmSmc5MMPqRYbxO4ZU0S0+P200+tUnFx7PXmsc=
|
||||||
|
github.com/onsi/ginkgo/v2 v2.22.2 h1:/3X8Panh8/WwhU/3Ssa6rCKqPLuAkVY2I0RoyDLySlU=
|
||||||
|
github.com/onsi/ginkgo/v2 v2.22.2/go.mod h1:oeMosUL+8LtarXBHu/c0bx2D/K9zyQ6uX3cTyztHwsk=
|
||||||
|
github.com/onsi/gomega v1.36.2 h1:koNYke6TVk6ZmnyHrCXba/T/MoLBXFjeC1PtvYgw0A8=
|
||||||
|
github.com/onsi/gomega v1.36.2/go.mod h1:DdwyADRjrc825LhMEkD76cHR5+pUnjhUN8GlHlRPHzY=
|
||||||
|
github.com/opencontainers/go-digest v1.0.0 h1:apOUWs51W5PlhuyGyz9FCeeBIOUDA/6nW8Oi/yOhh5U=
|
||||||
|
github.com/opencontainers/go-digest v1.0.0/go.mod h1:0JzlMkj0TRzQZfJkVvzbP0HBR3IKzErnv2BNG4W4MAM=
|
||||||
|
github.com/opencontainers/image-spec v1.1.1 h1:y0fUlFfIZhPF1W537XOLg0/fcx6zcHCJwooC2xJA040=
|
||||||
|
github.com/opencontainers/image-spec v1.1.1/go.mod h1:qpqAh3Dmcf36wStyyWU+kCeDgrGnAve2nCC8+7h8Q0M=
|
||||||
|
github.com/pkg/errors v0.9.1 h1:FEBLx1zS214owpjy7qsBeixbURkuhQAwrK5UwLGTwt4=
|
||||||
|
github.com/pkg/errors v0.9.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
|
||||||
|
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
|
||||||
|
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
|
||||||
|
github.com/power-devops/perfstat v0.0.0-20240221224432-82ca36839d55 h1:o4JXh1EVt9k/+g42oCprj/FisM4qX9L3sZB3upGN2ZU=
|
||||||
|
github.com/power-devops/perfstat v0.0.0-20240221224432-82ca36839d55/go.mod h1:OmDBASR4679mdNQnz2pUhc2G8CO2JrUAVFDRBDP/hJE=
|
||||||
|
github.com/rogpeppe/go-internal v1.14.1 h1:UQB4HGPB6osV0SQTLymcB4TgvyWu6ZyliaW0tI/otEQ=
|
||||||
|
github.com/rogpeppe/go-internal v1.14.1/go.mod h1:MaRKkUm5W0goXpeCfT7UZI6fk/L7L7so1lCWt35ZSgc=
|
||||||
|
github.com/shirou/gopsutil/v4 v4.25.3 h1:SeA68lsu8gLggyMbmCn8cmp97V1TI9ld9sVzAUcKcKE=
|
||||||
|
github.com/shirou/gopsutil/v4 v4.25.3/go.mod h1:xbuxyoZj+UsgnZrENu3lQivsngRR5BdjbJwf2fv4szA=
|
||||||
|
github.com/sirupsen/logrus v1.9.3 h1:dueUQJ1C2q9oE3F7wvmSGAaVtTmUizReu6fjN8uqzbQ=
|
||||||
|
github.com/sirupsen/logrus v1.9.3/go.mod h1:naHLuLoDiP4jHNo9R0sCBMtWGeIprob74mVsIT4qYEQ=
|
||||||
|
github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
|
||||||
|
github.com/stretchr/objx v0.5.2 h1:xuMeJ0Sdp5ZMRXx/aWO6RZxdr3beISkG5/G/aIRr3pY=
|
||||||
|
github.com/stretchr/objx v0.5.2/go.mod h1:FRsXN1f5AsAjCGJKqEizvkpNtU+EGNCLh3NxZ/8L+MA=
|
||||||
|
github.com/stretchr/testify v1.7.0/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
|
||||||
|
github.com/stretchr/testify v1.10.0 h1:Xv5erBjTwe/5IxqUQTdXv5kgmIvbHo3QQyRwhJsOfJA=
|
||||||
|
github.com/stretchr/testify v1.10.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY=
|
||||||
|
github.com/testcontainers/testcontainers-go v0.36.0 h1:YpffyLuHtdp5EUsI5mT4sRw8GZhO/5ozyDT1xWGXt00=
|
||||||
|
github.com/testcontainers/testcontainers-go v0.36.0/go.mod h1:yk73GVJ0KUZIHUtFna6MO7QS144qYpoY8lEEtU9Hed0=
|
||||||
|
github.com/tklauser/go-sysconf v0.3.15 h1:VE89k0criAymJ/Os65CSn1IXaol+1wrsFHEB8Ol49K4=
|
||||||
|
github.com/tklauser/go-sysconf v0.3.15/go.mod h1:Dmjwr6tYFIseJw7a3dRLJfsHAMXZ3nEnL/aZY+0IuI4=
|
||||||
|
github.com/tklauser/numcpus v0.10.0 h1:18njr6LDBk1zuna922MgdjQuJFjrdppsZG60sHGfjso=
|
||||||
|
github.com/tklauser/numcpus v0.10.0/go.mod h1:BiTKazU708GQTYF4mB+cmlpT2Is1gLk7XVuEeem8LsQ=
|
||||||
|
github.com/wadey/gocovmerge v0.0.0-20160331181800-b5bfa59ec0ad h1:W0LEBv82YCGEtcmPA3uNZBI33/qF//HAAs3MawDjRa0=
|
||||||
|
github.com/wadey/gocovmerge v0.0.0-20160331181800-b5bfa59ec0ad/go.mod h1:Hy8o65+MXnS6EwGElrSRjUzQDLXreJlzYLlWiHtt8hM=
|
||||||
|
github.com/yuin/goldmark v1.1.27/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
|
||||||
|
github.com/yuin/goldmark v1.2.1/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
|
||||||
|
github.com/yuin/gopher-lua v1.1.1 h1:kYKnWBjvbNP4XLT3+bPEwAXJx262OhaHDWDVOPjL46M=
|
||||||
|
github.com/yuin/gopher-lua v1.1.1/go.mod h1:GBR0iDaNXjAgGg9zfCvksxSRnQx76gclCIb7kdAd1Pw=
|
||||||
|
github.com/yusufpapurcu/wmi v1.2.4 h1:zFUKzehAFReQwLys1b/iSMl+JQGSCSjtVqQn9bBrPo0=
|
||||||
|
github.com/yusufpapurcu/wmi v1.2.4/go.mod h1:SBZ9tNy3G9/m5Oi98Zks0QjeHVDvuK0qfxQmPyzfmi0=
|
||||||
|
go.opentelemetry.io/auto/sdk v1.1.0 h1:cH53jehLUN6UFLY71z+NDOiNJqDdPRaXzTel0sJySYA=
|
||||||
|
go.opentelemetry.io/auto/sdk v1.1.0/go.mod h1:3wSPjt5PWp2RhlCcmmOial7AvC4DQqZb7a7wCow3W8A=
|
||||||
|
go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.60.0 h1:sbiXRNDSWJOTobXh5HyQKjq6wUC5tNybqjIqDpAY4CU=
|
||||||
|
go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.60.0/go.mod h1:69uWxva0WgAA/4bu2Yy70SLDBwZXuQ6PbBpbsa5iZrQ=
|
||||||
|
go.opentelemetry.io/otel v1.35.0 h1:xKWKPxrxB6OtMCbmMY021CqC45J+3Onta9MqjhnusiQ=
|
||||||
|
go.opentelemetry.io/otel v1.35.0/go.mod h1:UEqy8Zp11hpkUrL73gSlELM0DupHoiq72dR+Zqel/+Y=
|
||||||
|
go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.35.0 h1:1fTNlAIJZGWLP5FVu0fikVry1IsiUnXjf7QFvoNN3Xw=
|
||||||
|
go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.35.0/go.mod h1:zjPK58DtkqQFn+YUMbx0M2XV3QgKU0gS9LeGohREyK4=
|
||||||
|
go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp v1.19.0 h1:IeMeyr1aBvBiPVYihXIaeIZba6b8E1bYp7lbdxK8CQg=
|
||||||
|
go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp v1.19.0/go.mod h1:oVdCUtjq9MK9BlS7TtucsQwUcXcymNiEDjgDD2jMtZU=
|
||||||
|
go.opentelemetry.io/otel/metric v1.35.0 h1:0znxYu2SNyuMSQT4Y9WDWej0VpcsxkuklLa4/siN90M=
|
||||||
|
go.opentelemetry.io/otel/metric v1.35.0/go.mod h1:nKVFgxBZ2fReX6IlyW28MgZojkoAkJGaE8CpgeAU3oE=
|
||||||
|
go.opentelemetry.io/otel/sdk v1.35.0 h1:iPctf8iprVySXSKJffSS79eOjl9pvxV9ZqOWT0QejKY=
|
||||||
|
go.opentelemetry.io/otel/sdk v1.35.0/go.mod h1:+ga1bZliga3DxJ3CQGg3updiaAJoNECOgJREo9KHGQg=
|
||||||
|
go.opentelemetry.io/otel/sdk/metric v1.35.0 h1:1RriWBmCKgkeHEhM7a2uMjMUfP7MsOF5JpUCaEqEI9o=
|
||||||
|
go.opentelemetry.io/otel/sdk/metric v1.35.0/go.mod h1:is6XYCUMpcKi+ZsOvfluY5YstFnhW0BidkR+gL+qN+w=
|
||||||
|
go.opentelemetry.io/otel/trace v1.35.0 h1:dPpEfJu1sDIqruz7BHFG3c7528f6ddfSWfFDVt/xgMs=
|
||||||
|
go.opentelemetry.io/otel/trace v1.35.0/go.mod h1:WUk7DtFp1Aw2MkvqGdwiXYDZZNvA/1J8o6xRXLrIkyc=
|
||||||
|
go.opentelemetry.io/proto/otlp v1.5.0 h1:xJvq7gMzB31/d406fB8U5CBdyQGw4P399D1aQWU/3i4=
|
||||||
|
go.opentelemetry.io/proto/otlp v1.5.0/go.mod h1:keN8WnHxOy8PG0rQZjJJ5A2ebUoafqWp0eVQ4yIXvJ4=
|
||||||
|
golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w=
|
||||||
|
golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI=
|
||||||
|
golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto=
|
||||||
|
golang.org/x/crypto v0.37.0 h1:kJNSjF/Xp7kU0iB2Z+9viTPMW4EqqsrywMXLJOOsXSE=
|
||||||
|
golang.org/x/crypto v0.37.0/go.mod h1:vg+k43peMZ0pUMhYmVAWysMK35e6ioLh3wB8ZCAfbVc=
|
||||||
|
golang.org/x/mod v0.2.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA=
|
||||||
|
golang.org/x/mod v0.3.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA=
|
||||||
|
golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg=
|
||||||
|
golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
|
||||||
|
golang.org/x/net v0.0.0-20200226121028-0de0cce0169b/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
|
||||||
|
golang.org/x/net v0.0.0-20201021035429-f5854403a974/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU=
|
||||||
|
golang.org/x/net v0.39.0 h1:ZCu7HMWDxpXpaiKdhzIfaltL9Lp31x/3fCP11bc6/fY=
|
||||||
|
golang.org/x/net v0.39.0/go.mod h1:X7NRbYVEA+ewNkCNyJ513WmMdQ3BineSwVtN2zD/d+E=
|
||||||
|
golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
|
golang.org/x/sync v0.0.0-20190911185100-cd5d95a43a6e/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
|
golang.org/x/sync v0.0.0-20201020160332-67f06af15bc9/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
|
golang.org/x/sync v0.13.0 h1:AauUjRAJ9OSnvULf/ARrrVywoJDy0YS2AwQ98I37610=
|
||||||
|
golang.org/x/sync v0.13.0/go.mod h1:1dzgHSNfp02xaA81J2MS99Qcpr2w7fw1gpm99rleRqA=
|
||||||
|
golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
|
||||||
|
golang.org/x/sys v0.0.0-20190412213103-97732733099d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||||
|
golang.org/x/sys v0.0.0-20190916202348-b4ddaad3f8a3/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||||
|
golang.org/x/sys v0.0.0-20200930185726-fdedc70b468f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||||
|
golang.org/x/sys v0.0.0-20201204225414-ed752295db88/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||||
|
golang.org/x/sys v0.0.0-20210616094352-59db8d763f22/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
||||||
|
golang.org/x/sys v0.0.0-20220715151400-c0bba94af5f8/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
||||||
|
golang.org/x/sys v0.1.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
||||||
|
golang.org/x/sys v0.32.0 h1:s77OFDvIQeibCmezSnk/q6iAfkdiQaJi4VzroCFrN20=
|
||||||
|
golang.org/x/sys v0.32.0/go.mod h1:BJP2sWEmIv4KK5OTEluFJCKSidICx8ciO85XgH3Ak8k=
|
||||||
|
golang.org/x/term v0.31.0 h1:erwDkOK1Msy6offm1mOgvspSkslFnIGsFnxOKoufg3o=
|
||||||
|
golang.org/x/term v0.31.0/go.mod h1:R4BeIy7D95HzImkxGkTW1UQTtP54tio2RyHz7PwK0aw=
|
||||||
|
golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
|
||||||
|
golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ=
|
||||||
|
golang.org/x/text v0.24.0 h1:dd5Bzh4yt5KYA8f9CJHCP4FB4D51c2c6JvN37xJJkJ0=
|
||||||
|
golang.org/x/text v0.24.0/go.mod h1:L8rBsPeo2pSS+xqN0d5u2ikmjtmoJbDBT1b7nHvFCdU=
|
||||||
|
golang.org/x/time v0.0.0-20220210224613-90d013bbcef8 h1:vVKdlvoWBphwdxWKrFZEuM0kGgGLxUOYcY4U/2Vjg44=
|
||||||
|
golang.org/x/time v0.0.0-20220210224613-90d013bbcef8/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ=
|
||||||
|
golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ=
|
||||||
|
golang.org/x/tools v0.0.0-20191119224855-298f0cb1881e/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo=
|
||||||
|
golang.org/x/tools v0.0.0-20200619180055-7c47624df98f/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE=
|
||||||
|
golang.org/x/tools v0.0.0-20210106214847-113979e3529a/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA=
|
||||||
|
golang.org/x/tools v0.32.0 h1:Q7N1vhpkQv7ybVzLFtTjvQya2ewbwNDZzUgfXGqtMWU=
|
||||||
|
golang.org/x/tools v0.32.0/go.mod h1:ZxrU41P/wAbZD8EDa6dDCa6XfpkhJ7HFMjHJXfBDu8s=
|
||||||
|
golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
||||||
|
golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
||||||
|
golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
||||||
|
golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
||||||
|
google.golang.org/genproto/googleapis/api v0.0.0-20250102185135-69823020774d h1:H8tOf8XM88HvKqLTxe755haY6r1fqqzLbEnfrmLXlSA=
|
||||||
|
google.golang.org/genproto/googleapis/api v0.0.0-20250102185135-69823020774d/go.mod h1:2v7Z7gP2ZUOGsaFyxATQSRoBnKygqVq2Cwnvom7QiqY=
|
||||||
|
google.golang.org/genproto/googleapis/rpc v0.0.0-20250102185135-69823020774d h1:xJJRGY7TJcvIlpSrN3K6LAWgNFUILlO+OMAqtg9aqnw=
|
||||||
|
google.golang.org/genproto/googleapis/rpc v0.0.0-20250102185135-69823020774d/go.mod h1:3ENsm/5D1mzDyhpzeRi1NR784I0BcofWBoSc5QqqMK4=
|
||||||
|
google.golang.org/grpc v1.69.2 h1:U3S9QEtbXC0bYNvRtcoklF3xGtLViumSYxWykJS+7AU=
|
||||||
|
google.golang.org/grpc v1.69.2/go.mod h1:vyjdE6jLBI76dgpDojsFGNaHlxdjXN9ghpnd2o7JGZ4=
|
||||||
|
google.golang.org/protobuf v1.36.5 h1:tPhr+woSbjfYvY6/GPufUoYizxw1cF/yFoxJ2fmpwlM=
|
||||||
|
google.golang.org/protobuf v1.36.5/go.mod h1:9fA7Ob0pmnwhb644+1+CVWFRbNajQ6iRojtC/QF5bRE=
|
||||||
|
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
||||||
|
gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c h1:Hei/4ADfdWqJk1ZMxUNpqntNwaWcugrBjAiHlqqRiVk=
|
||||||
|
gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c/go.mod h1:JHkPIbrfpd72SG/EVd6muEfDQjcINNoR0C8j2r3qZ4Q=
|
||||||
|
gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
||||||
|
gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA=
|
||||||
|
gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
||||||
|
gotest.tools/v3 v3.5.1 h1:EENdUnS3pdur5nybKYIh2Vfgc8IUNBjxDPSjtiJcOzU=
|
||||||
|
gotest.tools/v3 v3.5.1/go.mod h1:isy3WKz7GK6uNw/sbHzfKBLvlvXwUyV06n6brMxxopU=
|
@@ -6,8 +6,6 @@ title: ArangoDB
|
|||||||

|

|
||||||
[](https://gofiber.io/discord)
|
[](https://gofiber.io/discord)
|
||||||

|

|
||||||

|
|
||||||

|
|
||||||
|
|
||||||
A ArangoDB storage driver using `arangodb/go-driver` and [arangodb/go-driver](https://github.com/arangodb/go-driver).
|
A ArangoDB storage driver using `arangodb/go-driver` and [arangodb/go-driver](https://github.com/arangodb/go-driver).
|
||||||
|
|
||||||
@@ -35,7 +33,7 @@ ArangoDB is tested on the 2 last (1.14/1.15) [Go versions](https://golang.org/dl
|
|||||||
```bash
|
```bash
|
||||||
go mod init github.com/<user>/<repo>
|
go mod init github.com/<user>/<repo>
|
||||||
```
|
```
|
||||||
And then install the mysql implementation:
|
And then install the arangodb implementation:
|
||||||
```bash
|
```bash
|
||||||
go get github.com/gofiber/storage/arangodb/v2
|
go get github.com/gofiber/storage/arangodb/v2
|
||||||
```
|
```
|
||||||
|
@@ -3,15 +3,15 @@ module github.com/gofiber/storage/arangodb/v2
|
|||||||
go 1.19
|
go 1.19
|
||||||
|
|
||||||
require (
|
require (
|
||||||
github.com/arangodb/go-driver v1.6.2
|
github.com/arangodb/go-driver v1.6.6
|
||||||
github.com/gofiber/utils/v2 v2.0.0-beta.3
|
github.com/gofiber/utils/v2 v2.0.0-beta.3
|
||||||
github.com/stretchr/testify v1.9.0
|
github.com/stretchr/testify v1.10.0
|
||||||
)
|
)
|
||||||
|
|
||||||
require (
|
require (
|
||||||
github.com/arangodb/go-velocypack v0.0.0-20200318135517-5af53c29c67e // indirect
|
github.com/arangodb/go-velocypack v0.0.0-20200318135517-5af53c29c67e // indirect
|
||||||
github.com/davecgh/go-spew v1.1.1 // indirect
|
github.com/davecgh/go-spew v1.1.1 // indirect
|
||||||
github.com/google/uuid v1.3.1 // indirect
|
github.com/google/uuid v1.6.0 // indirect
|
||||||
github.com/pkg/errors v0.9.1 // indirect
|
github.com/pkg/errors v0.9.1 // indirect
|
||||||
github.com/pmezard/go-difflib v1.0.0 // indirect
|
github.com/pmezard/go-difflib v1.0.0 // indirect
|
||||||
gopkg.in/yaml.v3 v3.0.1 // indirect
|
gopkg.in/yaml.v3 v3.0.1 // indirect
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
github.com/arangodb/go-driver v1.6.2 h1:3o4inejwR7VMmsKvQJ6hepx4au9sUT6C/RDrXykuD1g=
|
github.com/arangodb/go-driver v1.6.6 h1:yL1ybRCKqY+eREnVuJ/GYNYowoyy/g0fiUvL3fKNtJM=
|
||||||
github.com/arangodb/go-driver v1.6.2/go.mod h1:2BCE6y3DNSLqIXnDvf4CR6WdzZZloYudEy+sasimLiQ=
|
github.com/arangodb/go-driver v1.6.6/go.mod h1:ZWyW3T8YPA1weGxohGtW4lFjJmpr9aHNTTbaiD5bBhI=
|
||||||
github.com/arangodb/go-velocypack v0.0.0-20200318135517-5af53c29c67e h1:Xg+hGrY2LcQBbxd0ZFdbGSyRKTYMZCfBbw/pMJFOk1g=
|
github.com/arangodb/go-velocypack v0.0.0-20200318135517-5af53c29c67e h1:Xg+hGrY2LcQBbxd0ZFdbGSyRKTYMZCfBbw/pMJFOk1g=
|
||||||
github.com/arangodb/go-velocypack v0.0.0-20200318135517-5af53c29c67e/go.mod h1:mq7Shfa/CaixoDxiyAAc5jZ6CVBAyPaNQCGS7mkj4Ho=
|
github.com/arangodb/go-velocypack v0.0.0-20200318135517-5af53c29c67e/go.mod h1:mq7Shfa/CaixoDxiyAAc5jZ6CVBAyPaNQCGS7mkj4Ho=
|
||||||
github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
||||||
@@ -7,16 +7,16 @@ github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c
|
|||||||
github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
||||||
github.com/gofiber/utils/v2 v2.0.0-beta.3 h1:pfOhUDDVjBJpkWv6C5jaDyYLvpui7zQ97zpyFFsUOKw=
|
github.com/gofiber/utils/v2 v2.0.0-beta.3 h1:pfOhUDDVjBJpkWv6C5jaDyYLvpui7zQ97zpyFFsUOKw=
|
||||||
github.com/gofiber/utils/v2 v2.0.0-beta.3/go.mod h1:jsl17+MsKfwJjM3ONCE9Rzji/j8XNbwjhUVTjzgfDCo=
|
github.com/gofiber/utils/v2 v2.0.0-beta.3/go.mod h1:jsl17+MsKfwJjM3ONCE9Rzji/j8XNbwjhUVTjzgfDCo=
|
||||||
github.com/google/uuid v1.3.1 h1:KjJaJ9iWZ3jOFZIf1Lqf4laDRCasjl0BCmnEGxkdLb4=
|
github.com/google/uuid v1.6.0 h1:NIvaJDMOsjHA8n1jAhLSgzrAzy1Hgr+hNrb57e+94F0=
|
||||||
github.com/google/uuid v1.3.1/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo=
|
github.com/google/uuid v1.6.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo=
|
||||||
github.com/pkg/errors v0.9.1 h1:FEBLx1zS214owpjy7qsBeixbURkuhQAwrK5UwLGTwt4=
|
github.com/pkg/errors v0.9.1 h1:FEBLx1zS214owpjy7qsBeixbURkuhQAwrK5UwLGTwt4=
|
||||||
github.com/pkg/errors v0.9.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
|
github.com/pkg/errors v0.9.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
|
||||||
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
|
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
|
||||||
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
|
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
|
||||||
github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
|
github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
|
||||||
github.com/stretchr/testify v1.5.1/go.mod h1:5W2xD1RspED5o8YsWQXVCued0rvSQ+mT+I5cxcmMvtA=
|
github.com/stretchr/testify v1.5.1/go.mod h1:5W2xD1RspED5o8YsWQXVCued0rvSQ+mT+I5cxcmMvtA=
|
||||||
github.com/stretchr/testify v1.9.0 h1:HtqpIVDClZ4nwg75+f6Lvsy/wHu+3BoSGCbBAcpTsTg=
|
github.com/stretchr/testify v1.10.0 h1:Xv5erBjTwe/5IxqUQTdXv5kgmIvbHo3QQyRwhJsOfJA=
|
||||||
github.com/stretchr/testify v1.9.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY=
|
github.com/stretchr/testify v1.10.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY=
|
||||||
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405 h1:yhCVgyC4o1eVCa2tZl7eS0r+SDo693bJlVdllGtEeKM=
|
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405 h1:yhCVgyC4o1eVCa2tZl7eS0r+SDo693bJlVdllGtEeKM=
|
||||||
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
||||||
gopkg.in/yaml.v2 v2.2.2/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
|
gopkg.in/yaml.v2 v2.2.2/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
|
||||||
|
@@ -6,8 +6,6 @@ title: Azure Blob
|
|||||||

|

|
||||||
[](https://gofiber.io/discord)
|
[](https://gofiber.io/discord)
|
||||||

|

|
||||||

|
|
||||||

|
|
||||||
|
|
||||||
[Azure Blob storage](https://azure.microsoft.com/en-us/products/storage/blobs/#overview) is Microsoft's object storage solution for the cloud.
|
[Azure Blob storage](https://azure.microsoft.com/en-us/products/storage/blobs/#overview) is Microsoft's object storage solution for the cloud.
|
||||||
|
|
||||||
|
@@ -1,31 +1,49 @@
|
|||||||
package azureblob
|
package azureblob
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"context"
|
||||||
"os"
|
"os"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/Azure/azure-sdk-for-go/sdk/storage/azblob/bloberror"
|
"github.com/Azure/azure-sdk-for-go/sdk/storage/azblob/bloberror"
|
||||||
"github.com/stretchr/testify/require"
|
"github.com/stretchr/testify/require"
|
||||||
|
"github.com/testcontainers/testcontainers-go"
|
||||||
|
"github.com/testcontainers/testcontainers-go/modules/azure/azurite"
|
||||||
)
|
)
|
||||||
|
|
||||||
var testStore *Storage
|
const (
|
||||||
|
// azuriteImage is the default image used for running azurite in tests.
|
||||||
|
azuriteImage = "mcr.microsoft.com/azure-storage/azurite:latest"
|
||||||
|
azuriteImageEnvVar = "TEST_AZURITE_IMAGE"
|
||||||
|
)
|
||||||
|
|
||||||
func TestMain(m *testing.M) {
|
func newTestStore(t testing.TB) *Storage {
|
||||||
testStore = New(Config{
|
t.Helper()
|
||||||
Account: "devstoreaccount1",
|
|
||||||
|
img := azuriteImage
|
||||||
|
if imgFromEnv := os.Getenv(azuriteImageEnvVar); imgFromEnv != "" {
|
||||||
|
img = imgFromEnv
|
||||||
|
}
|
||||||
|
|
||||||
|
ctx := context.Background()
|
||||||
|
|
||||||
|
c, err := azurite.Run(ctx, img)
|
||||||
|
testcontainers.CleanupContainer(t, c)
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
serviceURL, err := c.BlobServiceURL(ctx)
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
return New(Config{
|
||||||
|
Account: azurite.AccountName,
|
||||||
Container: "test",
|
Container: "test",
|
||||||
Endpoint: "http://127.0.0.1:10000/devstoreaccount1",
|
Endpoint: serviceURL + "/" + azurite.AccountName,
|
||||||
Credentials: Credentials{
|
Credentials: Credentials{
|
||||||
Account: "devstoreaccount1",
|
Account: azurite.AccountName,
|
||||||
Key: "Eby8vdM02xNOcqFlqUwJPLlmEtlCDXJ1OUzFT50uSRZ6IFsuFq2UVErCz4I6tq/K1SZFPTOtr/KBHBeksoGMGw==",
|
Key: azurite.AccountKey,
|
||||||
},
|
},
|
||||||
Reset: true,
|
Reset: true,
|
||||||
})
|
})
|
||||||
|
|
||||||
code := m.Run()
|
|
||||||
|
|
||||||
_ = testStore.Close()
|
|
||||||
os.Exit(code)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func Test_AzureBlob_Get(t *testing.T) {
|
func Test_AzureBlob_Get(t *testing.T) {
|
||||||
@@ -34,6 +52,9 @@ func Test_AzureBlob_Get(t *testing.T) {
|
|||||||
val = []byte("doe")
|
val = []byte("doe")
|
||||||
)
|
)
|
||||||
|
|
||||||
|
testStore := newTestStore(t)
|
||||||
|
defer testStore.Close()
|
||||||
|
|
||||||
err := testStore.Set(key, val, 0)
|
err := testStore.Set(key, val, 0)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
@@ -48,6 +69,9 @@ func Test_AzureBlob_Set(t *testing.T) {
|
|||||||
val = []byte("doe")
|
val = []byte("doe")
|
||||||
)
|
)
|
||||||
|
|
||||||
|
testStore := newTestStore(t)
|
||||||
|
defer testStore.Close()
|
||||||
|
|
||||||
err := testStore.Set(key, val, 0)
|
err := testStore.Set(key, val, 0)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
}
|
}
|
||||||
@@ -58,6 +82,9 @@ func Test_AzureBlob_Delete(t *testing.T) {
|
|||||||
val = []byte("doe")
|
val = []byte("doe")
|
||||||
)
|
)
|
||||||
|
|
||||||
|
testStore := newTestStore(t)
|
||||||
|
defer testStore.Close()
|
||||||
|
|
||||||
err := testStore.Set(key, val, 0)
|
err := testStore.Set(key, val, 0)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
@@ -80,6 +107,9 @@ func Test_AzureBlob_Override(t *testing.T) {
|
|||||||
val = []byte("doe")
|
val = []byte("doe")
|
||||||
)
|
)
|
||||||
|
|
||||||
|
testStore := newTestStore(t)
|
||||||
|
defer testStore.Close()
|
||||||
|
|
||||||
err := testStore.Set(key, val, 0)
|
err := testStore.Set(key, val, 0)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
@@ -88,6 +118,9 @@ func Test_AzureBlob_Override(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func Test_AzureBlob_Get_NotExist(t *testing.T) {
|
func Test_AzureBlob_Get_NotExist(t *testing.T) {
|
||||||
|
testStore := newTestStore(t)
|
||||||
|
defer testStore.Close()
|
||||||
|
|
||||||
result, err := testStore.Get("notexist")
|
result, err := testStore.Get("notexist")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if bloberror.HasCode(err, bloberror.BlobNotFound) {
|
if bloberror.HasCode(err, bloberror.BlobNotFound) {
|
||||||
@@ -101,6 +134,9 @@ func Test_AzureBlob_Get_NotExist(t *testing.T) {
|
|||||||
func Test_AzureBlob_Reset(t *testing.T) {
|
func Test_AzureBlob_Reset(t *testing.T) {
|
||||||
val := []byte("doe")
|
val := []byte("doe")
|
||||||
|
|
||||||
|
testStore := newTestStore(t)
|
||||||
|
defer testStore.Close()
|
||||||
|
|
||||||
err := testStore.Set("john1", val, 0)
|
err := testStore.Set("john1", val, 0)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
@@ -129,15 +165,22 @@ func Test_AzureBlob_Reset(t *testing.T) {
|
|||||||
require.Zero(t, len(result))
|
require.Zero(t, len(result))
|
||||||
}
|
}
|
||||||
|
|
||||||
func Test_S3_Conn(t *testing.T) {
|
func Test_AzureBlob_Conn(t *testing.T) {
|
||||||
|
testStore := newTestStore(t)
|
||||||
|
defer testStore.Close()
|
||||||
|
|
||||||
require.True(t, testStore.Conn() != nil)
|
require.True(t, testStore.Conn() != nil)
|
||||||
}
|
}
|
||||||
|
|
||||||
func Test_AzureBlob_Close(t *testing.T) {
|
func Test_AzureBlob_Close(t *testing.T) {
|
||||||
require.Nil(t, testStore.Close())
|
testStore := newTestStore(t)
|
||||||
|
require.NoError(t, testStore.Close())
|
||||||
}
|
}
|
||||||
|
|
||||||
func Benchmark_AzureBlob_Set(b *testing.B) {
|
func Benchmark_AzureBlob_Set(b *testing.B) {
|
||||||
|
testStore := newTestStore(b)
|
||||||
|
defer testStore.Close()
|
||||||
|
|
||||||
b.ReportAllocs()
|
b.ReportAllocs()
|
||||||
b.ResetTimer()
|
b.ResetTimer()
|
||||||
|
|
||||||
@@ -150,6 +193,9 @@ func Benchmark_AzureBlob_Set(b *testing.B) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func Benchmark_AzureBlob_Get(b *testing.B) {
|
func Benchmark_AzureBlob_Get(b *testing.B) {
|
||||||
|
testStore := newTestStore(b)
|
||||||
|
defer testStore.Close()
|
||||||
|
|
||||||
err := testStore.Set("john", []byte("doe"), 0)
|
err := testStore.Set("john", []byte("doe"), 0)
|
||||||
require.NoError(b, err)
|
require.NoError(b, err)
|
||||||
|
|
||||||
@@ -164,6 +210,9 @@ func Benchmark_AzureBlob_Get(b *testing.B) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func Benchmark_AzureBlob_SetAndDelete(b *testing.B) {
|
func Benchmark_AzureBlob_SetAndDelete(b *testing.B) {
|
||||||
|
testStore := newTestStore(b)
|
||||||
|
defer testStore.Close()
|
||||||
|
|
||||||
b.ReportAllocs()
|
b.ReportAllocs()
|
||||||
b.ResetTimer()
|
b.ResetTimer()
|
||||||
|
|
||||||
|
@@ -1,18 +1,69 @@
|
|||||||
module github.com/gofiber/storage/azureblob/v2
|
module github.com/gofiber/storage/azureblob/v2
|
||||||
|
|
||||||
go 1.19
|
go 1.23.0
|
||||||
|
|
||||||
require (
|
require (
|
||||||
github.com/Azure/azure-sdk-for-go/sdk/storage/azblob v1.4.0
|
github.com/Azure/azure-sdk-for-go/sdk/storage/azblob v1.6.1
|
||||||
github.com/stretchr/testify v1.9.0
|
github.com/stretchr/testify v1.10.0
|
||||||
|
github.com/testcontainers/testcontainers-go v0.36.0
|
||||||
|
github.com/testcontainers/testcontainers-go/modules/azure v0.36.0
|
||||||
)
|
)
|
||||||
|
|
||||||
require (
|
require (
|
||||||
github.com/Azure/azure-sdk-for-go/sdk/azcore v1.13.0 // indirect
|
dario.cat/mergo v1.0.1 // indirect
|
||||||
github.com/Azure/azure-sdk-for-go/sdk/internal v1.10.0 // indirect
|
github.com/Azure/azure-sdk-for-go/sdk/azcore v1.18.0 // indirect
|
||||||
|
github.com/Azure/azure-sdk-for-go/sdk/internal v1.11.1 // indirect
|
||||||
|
github.com/Azure/go-ansiterm v0.0.0-20210617225240-d185dfc1b5a1 // indirect
|
||||||
|
github.com/Microsoft/go-winio v0.6.2 // indirect
|
||||||
|
github.com/cenkalti/backoff/v4 v4.2.1 // indirect
|
||||||
|
github.com/containerd/log v0.1.0 // indirect
|
||||||
|
github.com/containerd/platforms v0.2.1 // indirect
|
||||||
|
github.com/cpuguy83/dockercfg v0.3.2 // indirect
|
||||||
github.com/davecgh/go-spew v1.1.1 // indirect
|
github.com/davecgh/go-spew v1.1.1 // indirect
|
||||||
|
github.com/distribution/reference v0.6.0 // indirect
|
||||||
|
github.com/docker/docker v28.0.1+incompatible // indirect
|
||||||
|
github.com/docker/go-connections v0.5.0 // indirect
|
||||||
|
github.com/docker/go-units v0.5.0 // indirect
|
||||||
|
github.com/ebitengine/purego v0.8.2 // indirect
|
||||||
|
github.com/felixge/httpsnoop v1.0.4 // indirect
|
||||||
|
github.com/go-logr/logr v1.4.2 // indirect
|
||||||
|
github.com/go-logr/stdr v1.2.2 // indirect
|
||||||
|
github.com/go-ole/go-ole v1.2.6 // indirect
|
||||||
|
github.com/gogo/protobuf v1.3.2 // indirect
|
||||||
|
github.com/google/uuid v1.6.0 // indirect
|
||||||
|
github.com/klauspost/compress v1.17.6 // indirect
|
||||||
|
github.com/lufia/plan9stats v0.0.0-20211012122336-39d0f177ccd0 // indirect
|
||||||
|
github.com/magiconair/properties v1.8.9 // indirect
|
||||||
|
github.com/moby/docker-image-spec v1.3.1 // indirect
|
||||||
|
github.com/moby/patternmatcher v0.6.0 // indirect
|
||||||
|
github.com/moby/sys/sequential v0.5.0 // indirect
|
||||||
|
github.com/moby/sys/user v0.1.0 // indirect
|
||||||
|
github.com/moby/sys/userns v0.1.0 // indirect
|
||||||
|
github.com/moby/term v0.5.0 // indirect
|
||||||
|
github.com/morikuni/aec v1.0.0 // indirect
|
||||||
|
github.com/opencontainers/go-digest v1.0.0 // indirect
|
||||||
|
github.com/opencontainers/image-spec v1.1.1 // indirect
|
||||||
|
github.com/pkg/errors v0.9.1 // indirect
|
||||||
github.com/pmezard/go-difflib v1.0.0 // indirect
|
github.com/pmezard/go-difflib v1.0.0 // indirect
|
||||||
golang.org/x/net v0.27.0 // indirect
|
github.com/power-devops/perfstat v0.0.0-20210106213030-5aafc221ea8c // indirect
|
||||||
golang.org/x/text v0.16.0 // indirect
|
github.com/shirou/gopsutil/v4 v4.25.1 // indirect
|
||||||
|
github.com/sirupsen/logrus v1.9.3 // indirect
|
||||||
|
github.com/tklauser/go-sysconf v0.3.12 // indirect
|
||||||
|
github.com/tklauser/numcpus v0.6.1 // indirect
|
||||||
|
github.com/yusufpapurcu/wmi v1.2.4 // indirect
|
||||||
|
go.opentelemetry.io/auto/sdk v1.1.0 // indirect
|
||||||
|
go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.49.0 // indirect
|
||||||
|
go.opentelemetry.io/otel v1.35.0 // indirect
|
||||||
|
go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.35.0 // indirect
|
||||||
|
go.opentelemetry.io/otel/metric v1.35.0 // indirect
|
||||||
|
go.opentelemetry.io/otel/sdk v1.35.0 // indirect
|
||||||
|
go.opentelemetry.io/otel/trace v1.35.0 // indirect
|
||||||
|
go.opentelemetry.io/proto/otlp v1.5.0 // indirect
|
||||||
|
golang.org/x/crypto v0.37.0 // indirect
|
||||||
|
golang.org/x/net v0.39.0 // indirect
|
||||||
|
golang.org/x/sys v0.32.0 // indirect
|
||||||
|
golang.org/x/text v0.24.0 // indirect
|
||||||
|
google.golang.org/genproto/googleapis/rpc v0.0.0-20250324211829-b45e905df463 // indirect
|
||||||
|
google.golang.org/protobuf v1.36.6 // indirect
|
||||||
gopkg.in/yaml.v3 v3.0.1 // indirect
|
gopkg.in/yaml.v3 v3.0.1 // indirect
|
||||||
)
|
)
|
||||||
|
214
azureblob/go.sum
214
azureblob/go.sum
@@ -1,32 +1,208 @@
|
|||||||
github.com/Azure/azure-sdk-for-go/sdk/azcore v1.13.0 h1:GJHeeA2N7xrG3q30L2UXDyuWRzDM900/65j70wcM4Ww=
|
dario.cat/mergo v1.0.1 h1:Ra4+bf83h2ztPIQYNP99R6m+Y7KfnARDfID+a+vLl4s=
|
||||||
github.com/Azure/azure-sdk-for-go/sdk/azcore v1.13.0/go.mod h1:l38EPgmsp71HHLq9j7De57JcKOWPyhrsW1Awm1JS6K0=
|
dario.cat/mergo v1.0.1/go.mod h1:uNxQE+84aUszobStD9th8a29P2fMDhsBdgRYvZOxGmk=
|
||||||
github.com/Azure/azure-sdk-for-go/sdk/azidentity v1.7.0 h1:tfLQ34V6F7tVSwoTf/4lH5sE0o6eCJuNDTmH09nDpbc=
|
github.com/AdaLogics/go-fuzz-headers v0.0.0-20230811130428-ced1acdcaa24 h1:bvDV9vkmnHYOMsOr4WLk+Vo07yKIzd94sVoIqshQ4bU=
|
||||||
github.com/Azure/azure-sdk-for-go/sdk/internal v1.10.0 h1:ywEEhmNahHBihViHepv3xPBn1663uRv2t2q/ESv9seY=
|
github.com/AdaLogics/go-fuzz-headers v0.0.0-20230811130428-ced1acdcaa24/go.mod h1:8o94RPi1/7XTJvwPpRSzSUedZrtlirdB3r9Z20bi2f8=
|
||||||
github.com/Azure/azure-sdk-for-go/sdk/internal v1.10.0/go.mod h1:iZDifYGJTIgIIkYRNWPENUnqx6bJ2xnSDFI2tjwZNuY=
|
github.com/Azure/azure-sdk-for-go/sdk/azcore v1.18.0 h1:Gt0j3wceWMwPmiazCa8MzMA0MfhmPIz0Qp0FJ6qcM0U=
|
||||||
github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/storage/armstorage v1.6.0 h1:PiSrjRPpkQNjrM8H0WwKMnZUdu1RGMtd/LdGKUrOo+c=
|
github.com/Azure/azure-sdk-for-go/sdk/azcore v1.18.0/go.mod h1:Ot/6aikWnKWi4l9QB7qVSwa8iMphQNqkWALMoNT3rzM=
|
||||||
github.com/Azure/azure-sdk-for-go/sdk/storage/azblob v1.4.0 h1:Be6KInmFEKV81c0pOAEbRYehLMwmmGI1exuFj248AMk=
|
github.com/Azure/azure-sdk-for-go/sdk/azidentity v1.9.0 h1:OVoM452qUFBrX+URdH3VpR299ma4kfom0yB0URYky9g=
|
||||||
github.com/Azure/azure-sdk-for-go/sdk/storage/azblob v1.4.0/go.mod h1:WCPBHsOXfBVnivScjs2ypRfimjEW0qPVLGgJkZlrIOA=
|
github.com/Azure/azure-sdk-for-go/sdk/azidentity v1.9.0/go.mod h1:kUjrAo8bgEwLeZ/CmHqNl3Z/kPm7y6FKfxxK0izYUg4=
|
||||||
github.com/AzureAD/microsoft-authentication-library-for-go v1.2.2 h1:XHOnouVk1mxXfQidrMEnLlPk9UMeRtyBTnEFtxkV0kU=
|
github.com/Azure/azure-sdk-for-go/sdk/data/aztables v1.3.0 h1:NnE8y/opvxowwNcSNHubQUiSSEhfk3dmooLGAOmPuKs=
|
||||||
|
github.com/Azure/azure-sdk-for-go/sdk/data/aztables v1.3.0/go.mod h1:GhHzPHiiHxZloo6WvKu9X7krmSAKTyGoIwoKMbrKTTA=
|
||||||
|
github.com/Azure/azure-sdk-for-go/sdk/internal v1.11.1 h1:FPKJS1T+clwv+OLGt13a8UjqeRuh0O4SJ3lUriThc+4=
|
||||||
|
github.com/Azure/azure-sdk-for-go/sdk/internal v1.11.1/go.mod h1:j2chePtV91HrC22tGoRX3sGY42uF13WzmmV80/OdVAA=
|
||||||
|
github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/storage/armstorage v1.8.0 h1:LR0kAX9ykz8G4YgLCaRDVJ3+n43R8MneB5dTy2konZo=
|
||||||
|
github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/storage/armstorage v1.8.0/go.mod h1:DWAciXemNf++PQJLeXUB4HHH5OpsAh12HZnu2wXE1jA=
|
||||||
|
github.com/Azure/azure-sdk-for-go/sdk/storage/azblob v1.6.1 h1:lhZdRq7TIx0GJQvSyX2Si406vrYsov2FXGp/RnSEtcs=
|
||||||
|
github.com/Azure/azure-sdk-for-go/sdk/storage/azblob v1.6.1/go.mod h1:8cl44BDmi+effbARHMQjgOKA2AYvcohNm7KEt42mSV8=
|
||||||
|
github.com/Azure/azure-sdk-for-go/sdk/storage/azqueue v1.0.0 h1:lJwNFV+xYjHREUTHJKx/ZF6CJSt9znxmLw9DqSTvyRU=
|
||||||
|
github.com/Azure/azure-sdk-for-go/sdk/storage/azqueue v1.0.0/go.mod h1:GfT0aGew8Qj5yiQVqOO5v7N8fanbJGyUoHqXg56qcVY=
|
||||||
|
github.com/Azure/go-ansiterm v0.0.0-20210617225240-d185dfc1b5a1 h1:UQHMgLO+TxOElx5B5HZ4hJQsoJ/PvUvKRhJHDQXO8P8=
|
||||||
|
github.com/Azure/go-ansiterm v0.0.0-20210617225240-d185dfc1b5a1/go.mod h1:xomTg63KZ2rFqZQzSB4Vz2SUXa1BpHTVz9L5PTmPC4E=
|
||||||
|
github.com/AzureAD/microsoft-authentication-library-for-go v1.4.2 h1:oygO0locgZJe7PpYPXT5A29ZkwJaPqcva7BVeemZOZs=
|
||||||
|
github.com/AzureAD/microsoft-authentication-library-for-go v1.4.2/go.mod h1:wP83P5OoQ5p6ip3ScPr0BAq0BvuPAvacpEuSzyouqAI=
|
||||||
|
github.com/Microsoft/go-winio v0.6.2 h1:F2VQgta7ecxGYO8k3ZZz3RS8fVIXVxONVUPlNERoyfY=
|
||||||
|
github.com/Microsoft/go-winio v0.6.2/go.mod h1:yd8OoFMLzJbo9gZq8j5qaps8bJ9aShtEA8Ipt1oGCvU=
|
||||||
|
github.com/cenkalti/backoff/v4 v4.2.1 h1:y4OZtCnogmCPw98Zjyt5a6+QwPLGkiQsYW5oUqylYbM=
|
||||||
|
github.com/cenkalti/backoff/v4 v4.2.1/go.mod h1:Y3VNntkOUPxTVeUxJ/G5vcM//AlwfmyYozVcomhLiZE=
|
||||||
|
github.com/containerd/log v0.1.0 h1:TCJt7ioM2cr/tfR8GPbGf9/VRAX8D2B4PjzCpfX540I=
|
||||||
|
github.com/containerd/log v0.1.0/go.mod h1:VRRf09a7mHDIRezVKTRCrOq78v577GXq3bSa3EhrzVo=
|
||||||
|
github.com/containerd/platforms v0.2.1 h1:zvwtM3rz2YHPQsF2CHYM8+KtB5dvhISiXh5ZpSBQv6A=
|
||||||
|
github.com/containerd/platforms v0.2.1/go.mod h1:XHCb+2/hzowdiut9rkudds9bE5yJ7npe7dG/wG+uFPw=
|
||||||
|
github.com/cpuguy83/dockercfg v0.3.2 h1:DlJTyZGBDlXqUZ2Dk2Q3xHs/FtnooJJVaad2S9GKorA=
|
||||||
|
github.com/cpuguy83/dockercfg v0.3.2/go.mod h1:sugsbF4//dDlL/i+S+rtpIWp+5h0BHJHfjj5/jFyUJc=
|
||||||
|
github.com/creack/pty v1.1.18 h1:n56/Zwd5o6whRC5PMGretI4IdRLlmBXYNjScPaBgsbY=
|
||||||
|
github.com/creack/pty v1.1.18/go.mod h1:MOBLtS5ELjhRRrroQr9kyvTxUAFNvYEK993ew/Vr4O4=
|
||||||
|
github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
||||||
github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c=
|
github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c=
|
||||||
github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
||||||
github.com/golang-jwt/jwt/v5 v5.2.1 h1:OuVbFODueb089Lh128TAcimifWaLhJwVflnrgM17wHk=
|
github.com/distribution/reference v0.6.0 h1:0IXCQ5g4/QMHHkarYzh5l+u8T3t73zM5QvfrDyIgxBk=
|
||||||
|
github.com/distribution/reference v0.6.0/go.mod h1:BbU0aIcezP1/5jX/8MP0YiH4SdvB5Y4f/wlDRiLyi3E=
|
||||||
|
github.com/docker/docker v28.0.1+incompatible h1:FCHjSRdXhNRFjlHMTv4jUNlIBbTeRjrWfeFuJp7jpo0=
|
||||||
|
github.com/docker/docker v28.0.1+incompatible/go.mod h1:eEKB0N0r5NX/I1kEveEz05bcu8tLC/8azJZsviup8Sk=
|
||||||
|
github.com/docker/go-connections v0.5.0 h1:USnMq7hx7gwdVZq1L49hLXaFtUdTADjXGp+uj1Br63c=
|
||||||
|
github.com/docker/go-connections v0.5.0/go.mod h1:ov60Kzw0kKElRwhNs9UlUHAE/F9Fe6GLaXnqyDdmEXc=
|
||||||
|
github.com/docker/go-units v0.5.0 h1:69rxXcBk27SvSaaxTtLh/8llcHD8vYHT7WSdRZ/jvr4=
|
||||||
|
github.com/docker/go-units v0.5.0/go.mod h1:fgPhTUdO+D/Jk86RDLlptpiXQzgHJF7gydDDbaIK4Dk=
|
||||||
|
github.com/ebitengine/purego v0.8.2 h1:jPPGWs2sZ1UgOSgD2bClL0MJIqu58nOmIcBuXr62z1I=
|
||||||
|
github.com/ebitengine/purego v0.8.2/go.mod h1:iIjxzd6CiRiOG0UyXP+V1+jWqUXVjPKLAI0mRfJZTmQ=
|
||||||
|
github.com/felixge/httpsnoop v1.0.4 h1:NFTV2Zj1bL4mc9sqWACXbQFVBBg2W3GPvqp8/ESS2Wg=
|
||||||
|
github.com/felixge/httpsnoop v1.0.4/go.mod h1:m8KPJKqk1gH5J9DgRY2ASl2lWCfGKXixSwevea8zH2U=
|
||||||
|
github.com/go-logr/logr v1.2.2/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbVz/1A=
|
||||||
|
github.com/go-logr/logr v1.4.2 h1:6pFjapn8bFcIbiKo3XT4j/BhANplGihG6tvd+8rYgrY=
|
||||||
|
github.com/go-logr/logr v1.4.2/go.mod h1:9T104GzyrTigFIr8wt5mBrctHMim0Nb2HLGrmQ40KvY=
|
||||||
|
github.com/go-logr/stdr v1.2.2 h1:hSWxHoqTgW2S2qGc0LTAI563KZ5YKYRhT3MFKZMbjag=
|
||||||
|
github.com/go-logr/stdr v1.2.2/go.mod h1:mMo/vtBO5dYbehREoey6XUKy/eSumjCCveDpRre4VKE=
|
||||||
|
github.com/go-ole/go-ole v1.2.6 h1:/Fpf6oFPoeFik9ty7siob0G6Ke8QvQEuVcuChpwXzpY=
|
||||||
|
github.com/go-ole/go-ole v1.2.6/go.mod h1:pprOEPIfldk/42T2oK7lQ4v4JSDwmV0As9GaiUsvbm0=
|
||||||
|
github.com/gogo/protobuf v1.3.2 h1:Ov1cvc58UF3b5XjBnZv7+opcTcQFZebYjWzi34vdm4Q=
|
||||||
|
github.com/gogo/protobuf v1.3.2/go.mod h1:P1XiOD3dCwIKUDQYPy72D8LYyHL2YPYrpS2s69NZV8Q=
|
||||||
|
github.com/golang-jwt/jwt/v5 v5.2.2 h1:Rl4B7itRWVtYIHFrSNd7vhTiz9UpLdi6gZhZ3wEeDy8=
|
||||||
|
github.com/golang-jwt/jwt/v5 v5.2.2/go.mod h1:pqrtFR0X4osieyHYxtmOUWsAWrfe1Q5UVIyoH402zdk=
|
||||||
|
github.com/google/go-cmp v0.5.6/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
|
||||||
|
github.com/google/go-cmp v0.7.0 h1:wk8382ETsv4JYUZwIsn6YpYiWiBsYLSJiTsyBybVuN8=
|
||||||
|
github.com/google/go-cmp v0.7.0/go.mod h1:pXiqmnSA92OHEEa9HXL2W4E7lf9JzCmGVUdgjX3N/iU=
|
||||||
github.com/google/uuid v1.6.0 h1:NIvaJDMOsjHA8n1jAhLSgzrAzy1Hgr+hNrb57e+94F0=
|
github.com/google/uuid v1.6.0 h1:NIvaJDMOsjHA8n1jAhLSgzrAzy1Hgr+hNrb57e+94F0=
|
||||||
|
github.com/google/uuid v1.6.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo=
|
||||||
|
github.com/grpc-ecosystem/grpc-gateway/v2 v2.25.1 h1:VNqngBF40hVlDloBruUehVYC3ArSgIyScOAyMRqBxRg=
|
||||||
|
github.com/grpc-ecosystem/grpc-gateway/v2 v2.25.1/go.mod h1:RBRO7fro65R6tjKzYgLAFo0t1QEXY1Dp+i/bvpRiqiQ=
|
||||||
|
github.com/kisielk/errcheck v1.5.0/go.mod h1:pFxgyoBC7bSaBwPgfKdkLd5X25qrDl4LWUI2bnpBCr8=
|
||||||
|
github.com/kisielk/gotool v1.0.0/go.mod h1:XhKaO+MFFWcvkIS/tQcRk01m1F5IRFswLeQ+oQHNcck=
|
||||||
|
github.com/klauspost/compress v1.17.6 h1:60eq2E/jlfwQXtvZEeBUYADs+BwKBWURIY+Gj2eRGjI=
|
||||||
|
github.com/klauspost/compress v1.17.6/go.mod h1:/dCuZOvVtNoHsyb+cuJD3itjs3NbnF6KH9zAO4BDxPM=
|
||||||
github.com/kr/pretty v0.3.1 h1:flRD4NNwYAUpkphVc1HcthR4KEIFJ65n8Mw5qdRn3LE=
|
github.com/kr/pretty v0.3.1 h1:flRD4NNwYAUpkphVc1HcthR4KEIFJ65n8Mw5qdRn3LE=
|
||||||
|
github.com/kr/pretty v0.3.1/go.mod h1:hoEshYVHaxMs3cyo3Yncou5ZscifuDolrwPKZanG3xk=
|
||||||
github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY=
|
github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY=
|
||||||
|
github.com/kr/text v0.2.0/go.mod h1:eLer722TekiGuMkidMxC/pM04lWEeraHUUmBw8l2grE=
|
||||||
github.com/kylelemons/godebug v1.1.0 h1:RPNrshWIDI6G2gRW9EHilWtl7Z6Sb1BR0xunSBf0SNc=
|
github.com/kylelemons/godebug v1.1.0 h1:RPNrshWIDI6G2gRW9EHilWtl7Z6Sb1BR0xunSBf0SNc=
|
||||||
|
github.com/kylelemons/godebug v1.1.0/go.mod h1:9/0rRGxNHcop5bhtWyNeEfOS8JIWk580+fNqagV/RAw=
|
||||||
|
github.com/lufia/plan9stats v0.0.0-20211012122336-39d0f177ccd0 h1:6E+4a0GO5zZEnZ81pIr0yLvtUWk2if982qA3F3QD6H4=
|
||||||
|
github.com/lufia/plan9stats v0.0.0-20211012122336-39d0f177ccd0/go.mod h1:zJYVVT2jmtg6P3p1VtQj7WsuWi/y4VnjVBn7F8KPB3I=
|
||||||
|
github.com/magiconair/properties v1.8.9 h1:nWcCbLq1N2v/cpNsy5WvQ37Fb+YElfq20WJ/a8RkpQM=
|
||||||
|
github.com/magiconair/properties v1.8.9/go.mod h1:Dhd985XPs7jluiymwWYZ0G4Z61jb3vdS329zhj2hYo0=
|
||||||
|
github.com/moby/docker-image-spec v1.3.1 h1:jMKff3w6PgbfSa69GfNg+zN/XLhfXJGnEx3Nl2EsFP0=
|
||||||
|
github.com/moby/docker-image-spec v1.3.1/go.mod h1:eKmb5VW8vQEh/BAr2yvVNvuiJuY6UIocYsFu/DxxRpo=
|
||||||
|
github.com/moby/patternmatcher v0.6.0 h1:GmP9lR19aU5GqSSFko+5pRqHi+Ohk1O69aFiKkVGiPk=
|
||||||
|
github.com/moby/patternmatcher v0.6.0/go.mod h1:hDPoyOpDY7OrrMDLaYoY3hf52gNCR/YOUYxkhApJIxc=
|
||||||
|
github.com/moby/sys/sequential v0.5.0 h1:OPvI35Lzn9K04PBbCLW0g4LcFAJgHsvXsRyewg5lXtc=
|
||||||
|
github.com/moby/sys/sequential v0.5.0/go.mod h1:tH2cOOs5V9MlPiXcQzRC+eEyab644PWKGRYaaV5ZZlo=
|
||||||
|
github.com/moby/sys/user v0.1.0 h1:WmZ93f5Ux6het5iituh9x2zAG7NFY9Aqi49jjE1PaQg=
|
||||||
|
github.com/moby/sys/user v0.1.0/go.mod h1:fKJhFOnsCN6xZ5gSfbM6zaHGgDJMrqt9/reuj4T7MmU=
|
||||||
|
github.com/moby/sys/userns v0.1.0 h1:tVLXkFOxVu9A64/yh59slHVv9ahO9UIev4JZusOLG/g=
|
||||||
|
github.com/moby/sys/userns v0.1.0/go.mod h1:IHUYgu/kao6N8YZlp9Cf444ySSvCmDlmzUcYfDHOl28=
|
||||||
|
github.com/moby/term v0.5.0 h1:xt8Q1nalod/v7BqbG21f8mQPqH+xAaC9C3N3wfWbVP0=
|
||||||
|
github.com/moby/term v0.5.0/go.mod h1:8FzsFHVUBGZdbDsJw/ot+X+d5HLUbvklYLJ9uGfcI3Y=
|
||||||
|
github.com/morikuni/aec v1.0.0 h1:nP9CBfwrvYnBRgY6qfDQkygYDmYwOilePFkwzv4dU8A=
|
||||||
|
github.com/morikuni/aec v1.0.0/go.mod h1:BbKIizmSmc5MMPqRYbxO4ZU0S0+P200+tUnFx7PXmsc=
|
||||||
|
github.com/opencontainers/go-digest v1.0.0 h1:apOUWs51W5PlhuyGyz9FCeeBIOUDA/6nW8Oi/yOhh5U=
|
||||||
|
github.com/opencontainers/go-digest v1.0.0/go.mod h1:0JzlMkj0TRzQZfJkVvzbP0HBR3IKzErnv2BNG4W4MAM=
|
||||||
|
github.com/opencontainers/image-spec v1.1.1 h1:y0fUlFfIZhPF1W537XOLg0/fcx6zcHCJwooC2xJA040=
|
||||||
|
github.com/opencontainers/image-spec v1.1.1/go.mod h1:qpqAh3Dmcf36wStyyWU+kCeDgrGnAve2nCC8+7h8Q0M=
|
||||||
github.com/pkg/browser v0.0.0-20240102092130-5ac0b6a4141c h1:+mdjkGKdHQG3305AYmdv1U2eRNDiU2ErMBj1gwrq8eQ=
|
github.com/pkg/browser v0.0.0-20240102092130-5ac0b6a4141c h1:+mdjkGKdHQG3305AYmdv1U2eRNDiU2ErMBj1gwrq8eQ=
|
||||||
|
github.com/pkg/browser v0.0.0-20240102092130-5ac0b6a4141c/go.mod h1:7rwL4CYBLnjLxUqIJNnCWiEdr3bn6IUYi15bNlnbCCU=
|
||||||
|
github.com/pkg/errors v0.9.1 h1:FEBLx1zS214owpjy7qsBeixbURkuhQAwrK5UwLGTwt4=
|
||||||
|
github.com/pkg/errors v0.9.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
|
||||||
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
|
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
|
||||||
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
|
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
|
||||||
github.com/rogpeppe/go-internal v1.12.0 h1:exVL4IDcn6na9z1rAb56Vxr+CgyK3nn3O+epU5NdKM8=
|
github.com/power-devops/perfstat v0.0.0-20210106213030-5aafc221ea8c h1:ncq/mPwQF4JjgDlrVEn3C11VoGHZN7m8qihwgMEtzYw=
|
||||||
github.com/stretchr/testify v1.9.0 h1:HtqpIVDClZ4nwg75+f6Lvsy/wHu+3BoSGCbBAcpTsTg=
|
github.com/power-devops/perfstat v0.0.0-20210106213030-5aafc221ea8c/go.mod h1:OmDBASR4679mdNQnz2pUhc2G8CO2JrUAVFDRBDP/hJE=
|
||||||
github.com/stretchr/testify v1.9.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY=
|
github.com/rogpeppe/go-internal v1.13.1 h1:KvO1DLK/DRN07sQ1LQKScxyZJuNnedQ5/wKSR38lUII=
|
||||||
golang.org/x/crypto v0.25.0 h1:ypSNr+bnYL2YhwoMt2zPxHFmbAN1KZs/njMG3hxUp30=
|
github.com/rogpeppe/go-internal v1.13.1/go.mod h1:uMEvuHeurkdAXX61udpOXGD/AzZDWNMNyH2VO9fmH0o=
|
||||||
golang.org/x/net v0.27.0 h1:5K3Njcw06/l2y9vpGCSdcxWOYHOUk3dVNGDXN+FvAys=
|
github.com/shirou/gopsutil/v4 v4.25.1 h1:QSWkTc+fu9LTAWfkZwZ6j8MSUk4A2LV7rbH0ZqmLjXs=
|
||||||
golang.org/x/net v0.27.0/go.mod h1:dDi0PyhWNoiUOrAS8uXv/vnScO4wnHQO4mj9fn/RytE=
|
github.com/shirou/gopsutil/v4 v4.25.1/go.mod h1:RoUCUpndaJFtT+2zsZzzmhvbfGoDCJ7nFXKJf8GqJbI=
|
||||||
golang.org/x/sys v0.22.0 h1:RI27ohtqKCnwULzJLqkv897zojh5/DwS/ENaMzUOaWI=
|
github.com/sirupsen/logrus v1.9.3 h1:dueUQJ1C2q9oE3F7wvmSGAaVtTmUizReu6fjN8uqzbQ=
|
||||||
golang.org/x/text v0.16.0 h1:a94ExnEXNtEwYLGJSIUxnWoxoRz/ZcCsV63ROupILh4=
|
github.com/sirupsen/logrus v1.9.3/go.mod h1:naHLuLoDiP4jHNo9R0sCBMtWGeIprob74mVsIT4qYEQ=
|
||||||
golang.org/x/text v0.16.0/go.mod h1:GhwF1Be+LQoKShO3cGOHzqOgRrGaYc9AvblQOmPVHnI=
|
github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
|
||||||
|
github.com/stretchr/objx v0.5.2 h1:xuMeJ0Sdp5ZMRXx/aWO6RZxdr3beISkG5/G/aIRr3pY=
|
||||||
|
github.com/stretchr/objx v0.5.2/go.mod h1:FRsXN1f5AsAjCGJKqEizvkpNtU+EGNCLh3NxZ/8L+MA=
|
||||||
|
github.com/stretchr/testify v1.7.0/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
|
||||||
|
github.com/stretchr/testify v1.10.0 h1:Xv5erBjTwe/5IxqUQTdXv5kgmIvbHo3QQyRwhJsOfJA=
|
||||||
|
github.com/stretchr/testify v1.10.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY=
|
||||||
|
github.com/testcontainers/testcontainers-go v0.36.0 h1:YpffyLuHtdp5EUsI5mT4sRw8GZhO/5ozyDT1xWGXt00=
|
||||||
|
github.com/testcontainers/testcontainers-go v0.36.0/go.mod h1:yk73GVJ0KUZIHUtFna6MO7QS144qYpoY8lEEtU9Hed0=
|
||||||
|
github.com/testcontainers/testcontainers-go/modules/azure v0.36.0 h1:MXc1xGZqzXgKHFV/7dq5XtcTQS0DncmXAEL9RYyQ6Zk=
|
||||||
|
github.com/testcontainers/testcontainers-go/modules/azure v0.36.0/go.mod h1:3+4sxe1awBqZTJjGhaS/+zkURCvmqqAnbtGeVPzfvBs=
|
||||||
|
github.com/tklauser/go-sysconf v0.3.12 h1:0QaGUFOdQaIVdPgfITYzaTegZvdCjmYO52cSFAEVmqU=
|
||||||
|
github.com/tklauser/go-sysconf v0.3.12/go.mod h1:Ho14jnntGE1fpdOqQEEaiKRpvIavV0hSfmBq8nJbHYI=
|
||||||
|
github.com/tklauser/numcpus v0.6.1 h1:ng9scYS7az0Bk4OZLvrNXNSAO2Pxr1XXRAPyjhIx+Fk=
|
||||||
|
github.com/tklauser/numcpus v0.6.1/go.mod h1:1XfjsgE2zo8GVw7POkMbHENHzVg3GzmoZ9fESEdAacY=
|
||||||
|
github.com/yuin/goldmark v1.1.27/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
|
||||||
|
github.com/yuin/goldmark v1.2.1/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
|
||||||
|
github.com/yusufpapurcu/wmi v1.2.4 h1:zFUKzehAFReQwLys1b/iSMl+JQGSCSjtVqQn9bBrPo0=
|
||||||
|
github.com/yusufpapurcu/wmi v1.2.4/go.mod h1:SBZ9tNy3G9/m5Oi98Zks0QjeHVDvuK0qfxQmPyzfmi0=
|
||||||
|
go.opentelemetry.io/auto/sdk v1.1.0 h1:cH53jehLUN6UFLY71z+NDOiNJqDdPRaXzTel0sJySYA=
|
||||||
|
go.opentelemetry.io/auto/sdk v1.1.0/go.mod h1:3wSPjt5PWp2RhlCcmmOial7AvC4DQqZb7a7wCow3W8A=
|
||||||
|
go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.49.0 h1:jq9TW8u3so/bN+JPT166wjOI6/vQPF6Xe7nMNIltagk=
|
||||||
|
go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.49.0/go.mod h1:p8pYQP+m5XfbZm9fxtSKAbM6oIllS7s2AfxrChvc7iw=
|
||||||
|
go.opentelemetry.io/otel v1.35.0 h1:xKWKPxrxB6OtMCbmMY021CqC45J+3Onta9MqjhnusiQ=
|
||||||
|
go.opentelemetry.io/otel v1.35.0/go.mod h1:UEqy8Zp11hpkUrL73gSlELM0DupHoiq72dR+Zqel/+Y=
|
||||||
|
go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.35.0 h1:1fTNlAIJZGWLP5FVu0fikVry1IsiUnXjf7QFvoNN3Xw=
|
||||||
|
go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.35.0/go.mod h1:zjPK58DtkqQFn+YUMbx0M2XV3QgKU0gS9LeGohREyK4=
|
||||||
|
go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp v1.19.0 h1:IeMeyr1aBvBiPVYihXIaeIZba6b8E1bYp7lbdxK8CQg=
|
||||||
|
go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp v1.19.0/go.mod h1:oVdCUtjq9MK9BlS7TtucsQwUcXcymNiEDjgDD2jMtZU=
|
||||||
|
go.opentelemetry.io/otel/metric v1.35.0 h1:0znxYu2SNyuMSQT4Y9WDWej0VpcsxkuklLa4/siN90M=
|
||||||
|
go.opentelemetry.io/otel/metric v1.35.0/go.mod h1:nKVFgxBZ2fReX6IlyW28MgZojkoAkJGaE8CpgeAU3oE=
|
||||||
|
go.opentelemetry.io/otel/sdk v1.35.0 h1:iPctf8iprVySXSKJffSS79eOjl9pvxV9ZqOWT0QejKY=
|
||||||
|
go.opentelemetry.io/otel/sdk v1.35.0/go.mod h1:+ga1bZliga3DxJ3CQGg3updiaAJoNECOgJREo9KHGQg=
|
||||||
|
go.opentelemetry.io/otel/trace v1.35.0 h1:dPpEfJu1sDIqruz7BHFG3c7528f6ddfSWfFDVt/xgMs=
|
||||||
|
go.opentelemetry.io/otel/trace v1.35.0/go.mod h1:WUk7DtFp1Aw2MkvqGdwiXYDZZNvA/1J8o6xRXLrIkyc=
|
||||||
|
go.opentelemetry.io/proto/otlp v1.5.0 h1:xJvq7gMzB31/d406fB8U5CBdyQGw4P399D1aQWU/3i4=
|
||||||
|
go.opentelemetry.io/proto/otlp v1.5.0/go.mod h1:keN8WnHxOy8PG0rQZjJJ5A2ebUoafqWp0eVQ4yIXvJ4=
|
||||||
|
golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w=
|
||||||
|
golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI=
|
||||||
|
golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto=
|
||||||
|
golang.org/x/crypto v0.37.0 h1:kJNSjF/Xp7kU0iB2Z+9viTPMW4EqqsrywMXLJOOsXSE=
|
||||||
|
golang.org/x/crypto v0.37.0/go.mod h1:vg+k43peMZ0pUMhYmVAWysMK35e6ioLh3wB8ZCAfbVc=
|
||||||
|
golang.org/x/mod v0.2.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA=
|
||||||
|
golang.org/x/mod v0.3.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA=
|
||||||
|
golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg=
|
||||||
|
golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
|
||||||
|
golang.org/x/net v0.0.0-20200226121028-0de0cce0169b/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
|
||||||
|
golang.org/x/net v0.0.0-20201021035429-f5854403a974/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU=
|
||||||
|
golang.org/x/net v0.39.0 h1:ZCu7HMWDxpXpaiKdhzIfaltL9Lp31x/3fCP11bc6/fY=
|
||||||
|
golang.org/x/net v0.39.0/go.mod h1:X7NRbYVEA+ewNkCNyJ513WmMdQ3BineSwVtN2zD/d+E=
|
||||||
|
golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
|
golang.org/x/sync v0.0.0-20190911185100-cd5d95a43a6e/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
|
golang.org/x/sync v0.0.0-20201020160332-67f06af15bc9/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
|
golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
|
||||||
|
golang.org/x/sys v0.0.0-20190412213103-97732733099d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||||
|
golang.org/x/sys v0.0.0-20190916202348-b4ddaad3f8a3/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||||
|
golang.org/x/sys v0.0.0-20200930185726-fdedc70b468f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||||
|
golang.org/x/sys v0.0.0-20201204225414-ed752295db88/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||||
|
golang.org/x/sys v0.0.0-20210616094352-59db8d763f22/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
||||||
|
golang.org/x/sys v0.0.0-20220715151400-c0bba94af5f8/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
||||||
|
golang.org/x/sys v0.8.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
||||||
|
golang.org/x/sys v0.11.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
||||||
|
golang.org/x/sys v0.32.0 h1:s77OFDvIQeibCmezSnk/q6iAfkdiQaJi4VzroCFrN20=
|
||||||
|
golang.org/x/sys v0.32.0/go.mod h1:BJP2sWEmIv4KK5OTEluFJCKSidICx8ciO85XgH3Ak8k=
|
||||||
|
golang.org/x/term v0.31.0 h1:erwDkOK1Msy6offm1mOgvspSkslFnIGsFnxOKoufg3o=
|
||||||
|
golang.org/x/term v0.31.0/go.mod h1:R4BeIy7D95HzImkxGkTW1UQTtP54tio2RyHz7PwK0aw=
|
||||||
|
golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
|
||||||
|
golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ=
|
||||||
|
golang.org/x/text v0.24.0 h1:dd5Bzh4yt5KYA8f9CJHCP4FB4D51c2c6JvN37xJJkJ0=
|
||||||
|
golang.org/x/text v0.24.0/go.mod h1:L8rBsPeo2pSS+xqN0d5u2ikmjtmoJbDBT1b7nHvFCdU=
|
||||||
|
golang.org/x/time v0.0.0-20220210224613-90d013bbcef8 h1:vVKdlvoWBphwdxWKrFZEuM0kGgGLxUOYcY4U/2Vjg44=
|
||||||
|
golang.org/x/time v0.0.0-20220210224613-90d013bbcef8/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ=
|
||||||
|
golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ=
|
||||||
|
golang.org/x/tools v0.0.0-20191119224855-298f0cb1881e/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo=
|
||||||
|
golang.org/x/tools v0.0.0-20200619180055-7c47624df98f/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE=
|
||||||
|
golang.org/x/tools v0.0.0-20210106214847-113979e3529a/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA=
|
||||||
|
golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
||||||
|
golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
||||||
|
golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
||||||
|
golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
||||||
|
google.golang.org/genproto/googleapis/api v0.0.0-20250102185135-69823020774d h1:H8tOf8XM88HvKqLTxe755haY6r1fqqzLbEnfrmLXlSA=
|
||||||
|
google.golang.org/genproto/googleapis/api v0.0.0-20250102185135-69823020774d/go.mod h1:2v7Z7gP2ZUOGsaFyxATQSRoBnKygqVq2Cwnvom7QiqY=
|
||||||
|
google.golang.org/genproto/googleapis/rpc v0.0.0-20250324211829-b45e905df463 h1:e0AIkUUhxyBKh6ssZNrAMeqhA7RKUj42346d1y02i2g=
|
||||||
|
google.golang.org/genproto/googleapis/rpc v0.0.0-20250324211829-b45e905df463/go.mod h1:qQ0YXyHHx3XkvlzUtpXDkS29lDSafHMZBAZDc03LQ3A=
|
||||||
|
google.golang.org/grpc v1.69.2 h1:U3S9QEtbXC0bYNvRtcoklF3xGtLViumSYxWykJS+7AU=
|
||||||
|
google.golang.org/grpc v1.69.2/go.mod h1:vyjdE6jLBI76dgpDojsFGNaHlxdjXN9ghpnd2o7JGZ4=
|
||||||
|
google.golang.org/protobuf v1.36.6 h1:z1NpPI8ku2WgiWnf+t9wTPsn6eP1L7ksHUlkfLvd9xY=
|
||||||
|
google.golang.org/protobuf v1.36.6/go.mod h1:jduwjTPXsFjZGTmRluh+L6NjiWu7pchiJ2/5YcXBHnY=
|
||||||
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
||||||
gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c h1:Hei/4ADfdWqJk1ZMxUNpqntNwaWcugrBjAiHlqqRiVk=
|
gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c h1:Hei/4ADfdWqJk1ZMxUNpqntNwaWcugrBjAiHlqqRiVk=
|
||||||
|
gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c/go.mod h1:JHkPIbrfpd72SG/EVd6muEfDQjcINNoR0C8j2r3qZ4Q=
|
||||||
|
gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
||||||
gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA=
|
gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA=
|
||||||
gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
||||||
|
gotest.tools/v3 v3.5.1 h1:EENdUnS3pdur5nybKYIh2Vfgc8IUNBjxDPSjtiJcOzU=
|
||||||
|
gotest.tools/v3 v3.5.1/go.mod h1:isy3WKz7GK6uNw/sbHzfKBLvlvXwUyV06n6brMxxopU=
|
||||||
|
@@ -6,8 +6,6 @@ title: Badger
|
|||||||

|

|
||||||
[](https://gofiber.io/discord)
|
[](https://gofiber.io/discord)
|
||||||

|

|
||||||

|
|
||||||

|
|
||||||
|
|
||||||
A fast key-value DB using [dgraph-io/badger](https://github.com/dgraph-io/badger)
|
A fast key-value DB using [dgraph-io/badger](https://github.com/dgraph-io/badger)
|
||||||
|
|
||||||
|
@@ -5,7 +5,7 @@ go 1.19
|
|||||||
require (
|
require (
|
||||||
github.com/dgraph-io/badger/v3 v3.2103.5
|
github.com/dgraph-io/badger/v3 v3.2103.5
|
||||||
github.com/gofiber/utils/v2 v2.0.0-beta.3
|
github.com/gofiber/utils/v2 v2.0.0-beta.3
|
||||||
github.com/stretchr/testify v1.9.0
|
github.com/stretchr/testify v1.10.0
|
||||||
)
|
)
|
||||||
|
|
||||||
require (
|
require (
|
||||||
|
@@ -114,8 +114,8 @@ github.com/stretchr/testify v1.4.0/go.mod h1:j7eGeouHqKxXV5pUuKE4zz7dFj8WfuZ+81P
|
|||||||
github.com/stretchr/testify v1.7.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
|
github.com/stretchr/testify v1.7.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
|
||||||
github.com/stretchr/testify v1.8.0/go.mod h1:yNjHg4UonilssWZ8iaSj1OCr/vHnekPRkoO+kdMU+MU=
|
github.com/stretchr/testify v1.8.0/go.mod h1:yNjHg4UonilssWZ8iaSj1OCr/vHnekPRkoO+kdMU+MU=
|
||||||
github.com/stretchr/testify v1.8.1/go.mod h1:w2LPCIKwWwSfY2zedu0+kehJoqGctiVI29o6fzry7u4=
|
github.com/stretchr/testify v1.8.1/go.mod h1:w2LPCIKwWwSfY2zedu0+kehJoqGctiVI29o6fzry7u4=
|
||||||
github.com/stretchr/testify v1.9.0 h1:HtqpIVDClZ4nwg75+f6Lvsy/wHu+3BoSGCbBAcpTsTg=
|
github.com/stretchr/testify v1.10.0 h1:Xv5erBjTwe/5IxqUQTdXv5kgmIvbHo3QQyRwhJsOfJA=
|
||||||
github.com/stretchr/testify v1.9.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY=
|
github.com/stretchr/testify v1.10.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY=
|
||||||
github.com/ugorji/go/codec v0.0.0-20181204163529-d75b2dcb6bc8/go.mod h1:VFNgLljTbGfSG7qAOspJ7OScBnGdDN/yBr0sguwnwf0=
|
github.com/ugorji/go/codec v0.0.0-20181204163529-d75b2dcb6bc8/go.mod h1:VFNgLljTbGfSG7qAOspJ7OScBnGdDN/yBr0sguwnwf0=
|
||||||
github.com/xordataexchange/crypt v0.0.3-0.20170626215501-b2862e3d0a77/go.mod h1:aYKd//L2LvnjZzWKhF00oedf4jCCReLcmhLdhm1A27Q=
|
github.com/xordataexchange/crypt v0.0.3-0.20170626215501-b2862e3d0a77/go.mod h1:aYKd//L2LvnjZzWKhF00oedf4jCCReLcmhLdhm1A27Q=
|
||||||
github.com/yuin/goldmark v1.1.27/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
|
github.com/yuin/goldmark v1.1.27/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
|
||||||
|
@@ -6,8 +6,6 @@ title: Bbolt
|
|||||||

|

|
||||||
[](https://gofiber.io/discord)
|
[](https://gofiber.io/discord)
|
||||||

|

|
||||||

|
|
||||||

|
|
||||||
|
|
||||||
A Bbolt storage driver using [etcd-io/bbolt](https://github.com/etcd-io/bbolt). Bolt is a pure Go key/value store inspired by [Howard Chu's](https://twitter.com/hyc_symas) [LMDB project](https://www.symas.com/symas-embedded-database-lmdb). The goal of the project is to provide a simple, fast, and reliable database for projects that don't require a full database server such as Postgres or MySQL.
|
A Bbolt storage driver using [etcd-io/bbolt](https://github.com/etcd-io/bbolt). Bolt is a pure Go key/value store inspired by [Howard Chu's](https://twitter.com/hyc_symas) [LMDB project](https://www.symas.com/symas-embedded-database-lmdb). The goal of the project is to provide a simple, fast, and reliable database for projects that don't require a full database server such as Postgres or MySQL.
|
||||||
|
|
||||||
|
@@ -4,7 +4,7 @@ go 1.19
|
|||||||
|
|
||||||
require (
|
require (
|
||||||
github.com/gofiber/utils/v2 v2.0.0-beta.3
|
github.com/gofiber/utils/v2 v2.0.0-beta.3
|
||||||
github.com/stretchr/testify v1.9.0
|
github.com/stretchr/testify v1.10.0
|
||||||
go.etcd.io/bbolt v1.3.9
|
go.etcd.io/bbolt v1.3.9
|
||||||
)
|
)
|
||||||
|
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user