{"id":46549336,"url":"https://github.com/hailuand/corgimq","last_synced_at":"2026-03-07T03:01:32.008Z","repository":{"id":226779199,"uuid":"760219247","full_name":"hailuand/corgimq","owner":"hailuand","description":"A lightweight Java message queue library built on your RDBMS.","archived":false,"fork":false,"pushed_at":"2026-02-16T23:40:46.000Z","size":1034,"stargazers_count":4,"open_issues_count":2,"forks_count":1,"subscribers_count":1,"default_branch":"main","last_synced_at":"2026-02-17T05:38:58.469Z","etag":null,"topics":["database","jdbc","message-queue","rdbms"],"latest_commit_sha":null,"homepage":"","language":"Java","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"apache-2.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/hailuand.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":"CODE_OF_CONDUCT.md","threat_model":null,"audit":null,"citation":null,"codeowners":".github/CODEOWNERS","security":"SECURITY.md","support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null}},"created_at":"2024-02-20T02:16:19.000Z","updated_at":"2026-02-16T23:28:11.000Z","dependencies_parsed_at":"2026-01-12T19:02:30.070Z","dependency_job_id":null,"html_url":"https://github.com/hailuand/corgimq","commit_stats":null,"previous_names":["hailuand/corgimq"],"tags_count":5,"template":false,"template_full_name":null,"purl":"pkg:github/hailuand/corgimq","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/hailuand%2Fcorgimq","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/hailuand%2Fcorgimq/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/hailuand%2Fcorgimq/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/hailuand%2Fcorgimq/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/hailuand","download_url":"https://codeload.github.com/hailuand/corgimq/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/hailuand%2Fcorgimq/sbom","scorecard":{"id":326410,"data":{"date":"2025-08-11T12:25:14Z","repo":{"name":"github.com/hailuand/corgimq","commit":"ec7a049a5d91998b4f50abe1e0e8cc7073fb8136"},"scorecard":{"version":"v4.13.1","commit":"49c0eed3a423f00c872b5c3c9f1bbca9e8aae799"},"score":7.6,"checks":[{"name":"Binary-Artifacts","score":9,"reason":"binaries present in source code","details":["Warn: binary detected: .mvn/wrapper/maven-wrapper.jar:1"],"documentation":{"short":"Determines if the project has generated executable (binary) artifacts in the source repository.","url":"https://github.com/ossf/scorecard/blob/49c0eed3a423f00c872b5c3c9f1bbca9e8aae799/docs/checks.md#binary-artifacts"}},{"name":"Branch-Protection","score":8,"reason":"branch protection is not maximal on development and all release branches","details":["Info: 'force pushes' disabled on branch 'main'","Info: 'allow deletion' disabled on branch 'main'","Info: status checks require up-to-date branches for 'main'","Info: 'last push approval' enabled on branch 'main'","Info: status check found to merge onto on branch 'main'","Warn: number of required reviewers is only 1 on branch 'main'","Warn: settings do not apply to administrators on branch 'main'","Info: codeowner review is required on branch 'main'","Warn: codeowners branch protection is being ignored - but no codeowners file found in repo"],"documentation":{"short":"Determines if the default and release branches are protected with GitHub's branch protection settings.","url":"https://github.com/ossf/scorecard/blob/49c0eed3a423f00c872b5c3c9f1bbca9e8aae799/docs/checks.md#branch-protection"}},{"name":"CI-Tests","score":10,"reason":"15 out of 15 merged PRs checked by a CI test -- score normalized to 10","details":null,"documentation":{"short":"Determines if the project runs tests before pull requests are merged.","url":"https://github.com/ossf/scorecard/blob/49c0eed3a423f00c872b5c3c9f1bbca9e8aae799/docs/checks.md#ci-tests"}},{"name":"CII-Best-Practices","score":0,"reason":"no effort to earn an OpenSSF best practices badge detected","details":null,"documentation":{"short":"Determines if the project has an OpenSSF (formerly CII) Best Practices Badge.","url":"https://github.com/ossf/scorecard/blob/49c0eed3a423f00c872b5c3c9f1bbca9e8aae799/docs/checks.md#cii-best-practices"}},{"name":"Code-Review","score":-1,"reason":"found no human review activity in the last 15 changesets","details":null,"documentation":{"short":"Determines if the project requires human code review before pull requests (aka merge requests) are merged.","url":"https://github.com/ossf/scorecard/blob/49c0eed3a423f00c872b5c3c9f1bbca9e8aae799/docs/checks.md#code-review"}},{"name":"Contributors","score":0,"reason":"0 different organizations found -- score normalized to 0","details":["Warn: no contributors have an org or company"],"documentation":{"short":"Determines if the project has a set of contributors from multiple organizations (e.g., companies).","url":"https://github.com/ossf/scorecard/blob/49c0eed3a423f00c872b5c3c9f1bbca9e8aae799/docs/checks.md#contributors"}},{"name":"Dangerous-Workflow","score":10,"reason":"no dangerous workflow patterns detected","details":null,"documentation":{"short":"Determines if the project's GitHub Action workflows avoid dangerous patterns.","url":"https://github.com/ossf/scorecard/blob/49c0eed3a423f00c872b5c3c9f1bbca9e8aae799/docs/checks.md#dangerous-workflow"}},{"name":"Dependency-Update-Tool","score":10,"reason":"update tool detected","details":["Info: tool 'Dependabot' is used: .github/dependabot.yaml:1"],"documentation":{"short":"Determines if the project uses a dependency update tool.","url":"https://github.com/ossf/scorecard/blob/49c0eed3a423f00c872b5c3c9f1bbca9e8aae799/docs/checks.md#dependency-update-tool"}},{"name":"Fuzzing","score":0,"reason":"project is not fuzzed","details":["Warn: no OSSFuzz integration found: Follow the steps in https://github.com/google/oss-fuzz to integrate fuzzing for your project.\nOver time, try to add fuzzing for more functionalities of your project. (High effort)","Warn: no OneFuzz integration found: Follow the steps in https://github.com/microsoft/onefuzz to start fuzzing for your project.\nOver time, try to add fuzzing for more functionalities of your project. (High effort)","Warn: no GoBuiltInFuzzer integration found: Follow the steps in https://go.dev/doc/fuzz/ to enable fuzzing on your project.\nOver time, try to add fuzzing for more functionalities of your project. (Medium effort)","Warn: no PythonAtherisFuzzer integration found: Follow the steps in https://github.com/google/atheris to enable fuzzing on your project.\nOver time, try to add fuzzing for more functionalities of your project. (Medium effort)","Warn: no CLibFuzzer integration found: Follow the steps in https://llvm.org/docs/LibFuzzer.html to enable fuzzing on your project.\nOver time, try to add fuzzing for more functionalities of your project. (Medium effort)","Warn: no CppLibFuzzer integration found: Follow the steps in https://llvm.org/docs/LibFuzzer.html to enable fuzzing on your project.\nOver time, try to add fuzzing for more functionalities of your project. (Medium effort)","Warn: no SwiftLibFuzzer integration found: Follow the steps in https://google.github.io/oss-fuzz/getting-started/new-project-guide/swift-lang/ to enable fuzzing on your project.\nOver time, try to add fuzzing for more functionalities of your project. (Medium effort)","Warn: no RustCargoFuzzer integration found: Follow the steps in https://rust-fuzz.github.io/book/cargo-fuzz.html to enable fuzzing on your project.\nOver time, try to add fuzzing for more functionalities of your project. (Medium effort)","Warn: no JavaJazzerFuzzer integration found: Follow the steps in https://github.com/CodeIntelligenceTesting/jazzer to enable fuzzing on your project.\nOver time, try to add fuzzing for more functionalities of your project. (Medium effort)","Warn: no ClusterFuzzLite integration found: Follow the steps in https://github.com/google/clusterfuzzlite to integrate fuzzing as part of CI.\nOver time, try to add fuzzing for more functionalities of your project. (High effort)","Warn: no HaskellPropertyBasedTesting integration found: Use one of the following frameworks to fuzz your project:\nQuickCheck: https://hackage.haskell.org/package/QuickCheck\nhedgehog: https://hedgehog.qa/\nvalidity: https://github.com/NorfairKing/validity\nsmallcheck: https://hackage.haskell.org/package/smallcheck\nhspec: https://hspec.github.io/\ntasty: https://hackage.haskell.org/package/tasty (High effort)","Warn: no TypeScriptPropertyBasedTesting integration found: Use fast-check: https://github.com/dubzzz/fast-check (High effort)","Warn: no JavaScriptPropertyBasedTesting integration found: Use fast-check: https://github.com/dubzzz/fast-check (High effort)"],"documentation":{"short":"Determines if the project uses fuzzing.","url":"https://github.com/ossf/scorecard/blob/49c0eed3a423f00c872b5c3c9f1bbca9e8aae799/docs/checks.md#fuzzing"}},{"name":"License","score":10,"reason":"license file detected","details":["Info: License file found in expected location: LICENSE:1","Info: FSF or OSI recognized license: LICENSE:1"],"documentation":{"short":"Determines if the project has defined a license.","url":"https://github.com/ossf/scorecard/blob/49c0eed3a423f00c872b5c3c9f1bbca9e8aae799/docs/checks.md#license"}},{"name":"Maintained","score":10,"reason":"30 commit(s) out of 30 and 0 issue activity out of 0 found in the last 90 days -- score normalized to 10","details":null,"documentation":{"short":"Determines if the project is \"actively maintained\".","url":"https://github.com/ossf/scorecard/blob/49c0eed3a423f00c872b5c3c9f1bbca9e8aae799/docs/checks.md#maintained"}},{"name":"Packaging","score":-1,"reason":"no published package detected","details":["Warn: no GitHub/GitLab publishing workflow detected"],"documentation":{"short":"Determines if the project is published as a package that others can easily download, install, easily update, and uninstall.","url":"https://github.com/ossf/scorecard/blob/49c0eed3a423f00c872b5c3c9f1bbca9e8aae799/docs/checks.md#packaging"}},{"name":"Pinned-Dependencies","score":8,"reason":"dependency not pinned by hash detected -- score normalized to 8","details":["Warn: third-party GitHubAction not pinned by hash: .github/workflows/dependabot-automation.yaml:15: update your workflow using https://app.stepsecurity.io/secureworkflow/hailuand/corgimq/dependabot-automation.yaml/main?enable=pin","Info:   9 out of   9 GitHub-owned GitHubAction dependencies pinned","Info:   6 out of   7 third-party GitHubAction dependencies pinned"],"documentation":{"short":"Determines if the project has declared and pinned the dependencies of its build process.","url":"https://github.com/ossf/scorecard/blob/49c0eed3a423f00c872b5c3c9f1bbca9e8aae799/docs/checks.md#pinned-dependencies"}},{"name":"SAST","score":10,"reason":"SAST tool is run on all commits","details":["Info: all commits (30) are checked with a SAST tool","Info: SAST tool detected: CodeQL"],"documentation":{"short":"Determines if the project uses static code analysis.","url":"https://github.com/ossf/scorecard/blob/49c0eed3a423f00c872b5c3c9f1bbca9e8aae799/docs/checks.md#sast"}},{"name":"Security-Policy","score":10,"reason":"security policy file detected","details":["Info: security policy file detected: SECURITY.md:1","Info: Found linked content: SECURITY.md:1","Info: Found disclosure, vulnerability, and/or timelines in security policy: SECURITY.md:1","Info: Found text in security policy: SECURITY.md:1"],"documentation":{"short":"Determines if the project has published a security policy.","url":"https://github.com/ossf/scorecard/blob/49c0eed3a423f00c872b5c3c9f1bbca9e8aae799/docs/checks.md#security-policy"}},{"name":"Signed-Releases","score":-1,"reason":"no releases found","details":["Warn: no GitHub releases found"],"documentation":{"short":"Determines if the project cryptographically signs release artifacts.","url":"https://github.com/ossf/scorecard/blob/49c0eed3a423f00c872b5c3c9f1bbca9e8aae799/docs/checks.md#signed-releases"}},{"name":"Token-Permissions","score":0,"reason":"detected GitHub workflow tokens with excessive permissions","details":["Info: topLevel 'contents' permission set to 'read': .github/workflows/codeql.yaml:12","Info: jobLevel 'actions' permission set to 'read': .github/workflows/codeql.yaml:21","Info: jobLevel 'contents' permission set to 'read': .github/workflows/codeql.yaml:22","Warn: topLevel 'contents' permission set to 'write': .github/workflows/dependabot-automation.yaml:5: Visit https://app.stepsecurity.io/secureworkflow/hailuand/corgimq/dependabot-automation.yaml/main?enable=permissions\nTick the 'Restrict permissions for GITHUB_TOKEN'\nUntick other options\nNOTE: If you want to resolve multiple issues at once, you can visit https://app.stepsecurity.io/securerepo instead. (Low effort)","Info: topLevel 'contents' permission set to 'read': .github/workflows/maven.yaml:10","Warn: jobLevel 'contents' permission set to 'write': .github/workflows/maven.yaml:15: Verify which permissions are needed and consider whether you can reduce them. (High effort)","Warn: jobLevel 'checks' permission set to 'write': .github/workflows/maven.yaml:16: Verify which permissions are needed and consider whether you can reduce them. (High effort)","Info: topLevel permissions set to 'read-all': .github/workflows/ossf.yaml:9"],"documentation":{"short":"Determines if the project's workflows follow the principle of least privilege.","url":"https://github.com/ossf/scorecard/blob/49c0eed3a423f00c872b5c3c9f1bbca9e8aae799/docs/checks.md#token-permissions"}},{"name":"Vulnerabilities","score":10,"reason":"no vulnerabilities detected","details":null,"documentation":{"short":"Determines if the project has open, known unfixed vulnerabilities.","url":"https://github.com/ossf/scorecard/blob/49c0eed3a423f00c872b5c3c9f1bbca9e8aae799/docs/checks.md#vulnerabilities"}}]},"last_synced_at":"2025-08-18T02:35:09.989Z","repository_id":226779199,"created_at":"2025-08-18T02:35:09.989Z","updated_at":"2025-08-18T02:35:09.989Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":30206336,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-03-06T19:07:06.838Z","status":"online","status_checked_at":"2026-03-07T02:00:06.765Z","response_time":53,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["database","jdbc","message-queue","rdbms"],"created_at":"2026-03-07T03:01:31.311Z","updated_at":"2026-03-07T03:01:31.984Z","avatar_url":"https://github.com/hailuand.png","language":"Java","funding_links":[],"categories":[],"sub_categories":[],"readme":"# Corgi Message Queue (CorgiMQ)\n\n![mascot.jpg](mascot.jpg)\n\n| Workflow     | Status                                                                                                                                                                                                                                                               |\n|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|\n| Build \u0026 test | ![build](https://github.com/hailuand/corgio-mq/actions/workflows/maven.yaml/badge.svg) [![codecov](https://codecov.io/github/hailuand/corgimq/graph/badge.svg?token=NYQYU42L1U)](https://codecov.io/github/hailuand/corgimq)                                         |\n| Quality      | [![OpenSSF Scorecard](https://api.securityscorecards.dev/projects/github.com/hailuand/corgimq/badge)](https://securityscorecards.dev/viewer/?uri=github.com/hailuand/corgimq) ![codeql](https://github.com/hailuand/corgimq/actions/workflows/codeql.yaml/badge.svg) |\n| Packages     | [![Maven Central Version](https://img.shields.io/maven-central/v/io.github.hailuand/corgimq?color=blue)](https://central.sonatype.com/artifact/io.github.hailuand/corgimq)                                                                                           |\n| Docs         | [![License](https://img.shields.io/badge/License-Apache_2.0-blue.svg)](https://opensource.org/licenses/Apache-2.0)  [![javadoc](https://javadoc.io/badge2/io.github.hailuand/corgimq/javadoc.svg)](https://javadoc.io/doc/io.github.hailuand/corgimq)                |\n\n\nA lightweight message queue library built using Java's JDBC API. Similar in spirit to [AWS SQS](https://aws.amazon.com/sqs/)\nand [Redis Simple Message Queue](https://github.com/smrchy/rsmq), but entirely on top of your DBMS.\n\n---\n\n### Features\n- Lightweight: bring **just your DBMS.** :rocket:\n- Batteries included: sensible out-of-the-box defaults with a few optional knobs to get you dangerous _fast_. :battery:\n- Transactional: shared access of JDBC `Connection` available to provide transactional message handling. :handshake:\n- Auditable: audit information in the queue captures if, when, and who has read a message. :detective:\n- Guaranteed **exactly-once delivery** of a message to a reader - if someone's currently reading it, no one else receives it.\n- Messages remain in queue until removed.\n\n---\n\n### Index\n* [Compatibility](#compatibility)\n* [Benchmarks](#-benchmarks)\n* [Get started](#-get-started)\n  * [Creating a queue](#creating-a-queue)\n  * [Pushing messages](#pushing-messages)\n  * [Reading messages](#reading-messages)\n* [Configuration](#-configuration)\n* [Notes](#-notes)\n* [References](#references)\n\n---\n\n### Compatibility\n\n#### Java\n| CorgiMQ Version | JDK |\n|---------------|-----|\n| `0.1+`        | 21  |\n\n\n#### RDBMS\nRDBMS in this list have been tested for library compatibility and are included in the test suites.\n\n| DBMS                 | Status             |\n|----------------------|--------------------|\n| H2                   | :white_check_mark: |\n| CockroachDB          | :white_check_mark: |\n| MySQL                | :white_check_mark: |\n| Microsoft SQL Server | :white_check_mark: |\n| Oracle DB            | :microscope:       |\n| Postgres             | :white_check_mark: |\n\n---\n\n### 🧪 Benchmarks\nBenchmarks are available here: [GitHub Pages - JMH Benchmark](https://hailuand.github.io/corgimq/dev/bench/)\n\nBenchmarking is performed using [Java Microbenchmark Harness](https://github.com/openjdk/jmh), measuring throughput of public API methods.\n\nWhile a benchmark suite is provided, it does not guarantee similar results when used in all environments. Users are encouraged to run their own benchmarks and test\nfor their own use cases.\n\n### 🚀 Get started\n#### Creating a queue\nA message queue is managed by an instance of `MessageQueue`.\n\n```java\nConnection conn = // ...\nMessageQueue messageQueue = MessageQueue.of(MessageQueueConfig.of(\"poneglyphs\"), conn); // Name of queue, table will have '_q' suffix\nmessageQueue.createTableWithSchemaIfNotExists();\n```\n\n```\npostgres=# \\dt mq.*\n           List of relations\n Schema |     Name     | Type  |  Owner\n--------+--------------+-------+---------\n mq     | poneglyphs_q | table | shanks\n(1 row)\n```\n\n#### Pushing messages\nOnce a `MessageQueue` is created, data to enqueue is wrapped as a `Message`. A `Message` is enqueued with `push(List)`:\n\n```java\nMessage message1 = Message.of(\"Whole Cake Island\");\nMessage message2 = Message.of(\"Zou\");\nmessageQueue.push(List.of(message1, message2));\n```\n\nTable after push:\n\n```\npostgres=# select * from mq.poneglyphs_q;\n                  id                  |        data       |        message_time        | read_count | read_by | processing_time\n--------------------------------------+-----------------+----------------------------+------------+---------+-----------------\n 9245867e-f7f1-40e4-9142-bb1457aff9ec | Whole Cake Island | 2024-02-27 10:12:57.486346 |          0 |         |\n a174f9d1-d3a9-4583-9396-d3ed575a4ebf | Zou               | 2024-02-27 10:12:57.486346 |          0 |         |\n(2 rows)\n```\n\n#### Reading messages\nUnread `Message`s in the queue are read in ascending `message_time` with an instance of `MessageHandler`:\n\n```java\nMessageHandler messageHandler = MessageHandler.of(messageQueue, MessageHandlerConfig.of(1)); // Read one message at a time\nSupplier\u003cConnection\u003e connectionSupplier = // Code to acquire a connection to database\nmessageHandler.listen(connectionSupplier, messageHandlerBatch -\u003e {\n    for (Message message : messageHandlerBatch.messages()) {\n        System.out.printf(\"Shanks - we found a road poneglyph at %s!%n\", message.data());\n    }\n    return messageBatch.messages(); // List of Messages to be popped\n    });\n// \"Shanks - we found a road poneglyph at Whole Cake Island!\"\n```\n\nTable after handler execution:\n```\npostgres=# select * from mq.poneglyphs_q;\n                  id                  |        data       |        message_time        | read_count | read_by  |      processing_time\n--------------------------------------+-----------------+----------------------------+------------+----------+----------------------------\n a174f9d1-d3a9-4583-9396-d3ed575a4ebf | Zou               | 2024-02-27 10:12:57.486346 |          0 |          |\n 9245867e-f7f1-40e4-9142-bb1457aff9ec | Whole Cake Island | 2024-02-27 10:12:57.486346 |          1 | beckman  | 2024-02-27 10:14:29.911197\n(2 rows)\n```\nAfter read, `Messages` have their `read_count`, `read_by`, and `processing_time` updated. Subsequent \ncalls to `listen()` no longer receive them.\n\n---\n\n### ⚙️ Configuration\n#### Message queue\n\n🔤 `queueName`\n\nName of message queue. Each queue has its own table within the `mq` schema, suffixed with `_q`.\n\n#### Message handler\n\n🔢 `messageBatchSize`\n\nMaximum number of `Message`s to serve to a `MessageHandler` in a single batch. \n\n_Default:_ `10`\n\n### ✏️ Notes\n#### Locking\nA `Message` currently being read by a `MessageHandler` has its row locked until the function completes. If multiple\n`MessageHandler`s are operating on the same queue, locked rows are skipped to prevent the same message being received\nby different handlers. This is achieved using the RDBMS's `SELECT FOR UPDATE` command. Thus, it's important to consider the\nisolation level configured by the `Connection` provided - `READ COMMITTED` or stronger.\n\n#### Transactional message handling\nThe transaction's `Connection` can be accessed through the `MessageHandlerBatch` argument passed to the\n`Function`'s input:\n```java\nMessageHandler messageHandler = MessageHandler.of(messageQueue, MessageHandlerConfig.of(1));\nSupplier\u003cConnection\u003e connectionSupplier = // ...\nmessageHandler.listen(connectionSupplier, messageHandlerBatch -\u003e {\n    try(Statement statement : messageHandlerBatch.transactionConnection()) {\n        // Do something with Statement to participate in transaction\n    } catch (SQLException e) {\n        throw new RuntimeException(e);\n    }\n    \n    return messageBatch.messages();\n    });\n```\n\n---\n\n### References\n- https://adriano.fyi/posts/2023-09-24-choose-postgres-queue-technology/\n- https://dagster.io/blog/skip-kafka-use-postgres-message-queue\n- https://mcfunley.com/choose-boring-technology\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fhailuand%2Fcorgimq","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fhailuand%2Fcorgimq","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fhailuand%2Fcorgimq/lists"}