{"id":37020698,"url":"https://github.com/serkanalgl/hydro-raindrop-java","last_synced_at":"2026-01-14T02:25:04.333Z","repository":{"id":57722688,"uuid":"140326951","full_name":"serkanalgl/hydro-raindrop-java","owner":"serkanalgl","description":"This java library provides a suite of convenience functions intended to simplify the integration of Hydro's Raindrop authentication into your project.","archived":false,"fork":false,"pushed_at":"2018-07-27T07:01:28.000Z","size":52,"stargazers_count":8,"open_issues_count":0,"forks_count":1,"subscribers_count":3,"default_branch":"master","last_synced_at":"2024-01-29T21:00:54.837Z","etag":null,"topics":["2fa","authentication","blockchain","hydro","java","mfa","raindrop","sdk-java"],"latest_commit_sha":null,"homepage":null,"language":"Java","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/serkanalgl.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2018-07-09T18:31:04.000Z","updated_at":"2023-04-01T02:06:41.000Z","dependencies_parsed_at":"2022-08-28T10:11:32.928Z","dependency_job_id":null,"html_url":"https://github.com/serkanalgl/hydro-raindrop-java","commit_stats":null,"previous_names":[],"tags_count":1,"template":false,"template_full_name":null,"purl":"pkg:github/serkanalgl/hydro-raindrop-java","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/serkanalgl%2Fhydro-raindrop-java","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/serkanalgl%2Fhydro-raindrop-java/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/serkanalgl%2Fhydro-raindrop-java/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/serkanalgl%2Fhydro-raindrop-java/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/serkanalgl","download_url":"https://codeload.github.com/serkanalgl/hydro-raindrop-java/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/serkanalgl%2Fhydro-raindrop-java/sbom","scorecard":{"id":812717,"data":{"date":"2025-08-11","repo":{"name":"github.com/serkanalgl/hydro-raindrop-java","commit":"a9b2f82bde76ab40e6bcdb3f8b2ab86f72f45970"},"scorecard":{"version":"v5.2.1-40-gf6ed084d","commit":"f6ed084d17c9236477efd66e5b258b9d4cc7b389"},"score":1.3,"checks":[{"name":"Code-Review","score":0,"reason":"Found 0/11 approved changesets -- score normalized to 0","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/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#code-review"}},{"name":"Packaging","score":-1,"reason":"packaging workflow not 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/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#packaging"}},{"name":"Binary-Artifacts","score":10,"reason":"no binaries found in the repo","details":null,"documentation":{"short":"Determines if the project has generated executable (binary) artifacts in the source repository.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#binary-artifacts"}},{"name":"SAST","score":0,"reason":"no SAST tool detected","details":["Warn: no pull requests merged into dev branch"],"documentation":{"short":"Determines if the project uses static code analysis.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#sast"}},{"name":"Pinned-Dependencies","score":-1,"reason":"no dependencies found","details":null,"documentation":{"short":"Determines if the project has declared and pinned the dependencies of its build process.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#pinned-dependencies"}},{"name":"Maintained","score":0,"reason":"0 commit(s) and 0 issue activity found in the last 90 days -- score normalized to 0","details":null,"documentation":{"short":"Determines if the project is \"actively maintained\".","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#maintained"}},{"name":"Dangerous-Workflow","score":-1,"reason":"no workflows found","details":null,"documentation":{"short":"Determines if the project's GitHub Action workflows avoid dangerous patterns.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#dangerous-workflow"}},{"name":"Token-Permissions","score":-1,"reason":"No tokens found","details":null,"documentation":{"short":"Determines if the project's workflows follow the principle of least privilege.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#token-permissions"}},{"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/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#cii-best-practices"}},{"name":"Security-Policy","score":0,"reason":"security policy file not detected","details":["Warn: no security policy file detected","Warn: no security file to analyze","Warn: no security file to analyze","Warn: no security file to analyze"],"documentation":{"short":"Determines if the project has published a security policy.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#security-policy"}},{"name":"Fuzzing","score":0,"reason":"project is not fuzzed","details":["Warn: no fuzzer integrations found"],"documentation":{"short":"Determines if the project uses fuzzing.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#fuzzing"}},{"name":"Signed-Releases","score":-1,"reason":"no releases found","details":null,"documentation":{"short":"Determines if the project cryptographically signs release artifacts.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#signed-releases"}},{"name":"Branch-Protection","score":0,"reason":"branch protection not enabled on development/release branches","details":["Warn: branch protection not enabled for branch 'master'"],"documentation":{"short":"Determines if the default and release branches are protected with GitHub's branch protection settings.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#branch-protection"}},{"name":"License","score":0,"reason":"license file not detected","details":["Warn: project does not have a license file"],"documentation":{"short":"Determines if the project has defined a license.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#license"}},{"name":"Vulnerabilities","score":0,"reason":"69 existing vulnerabilities detected","details":["Warn: Project is vulnerable to: GHSA-h46c-h94j-95f3","Warn: Project is vulnerable to: GHSA-wf8f-6423-gfxg","Warn: Project is vulnerable to: GHSA-27xj-rqx5-2255","Warn: Project is vulnerable to: GHSA-288c-cq4h-88gq","Warn: Project is vulnerable to: GHSA-4gq5-ch57-c2mg","Warn: Project is vulnerable to: GHSA-4w82-r329-3q67","Warn: Project is vulnerable to: GHSA-57j2-w4cx-62h2","Warn: Project is vulnerable to: GHSA-58pp-9c76-5625","Warn: Project is vulnerable to: GHSA-5949-rw7g-wx7w","Warn: Project is vulnerable to: GHSA-5p34-5m6p-p58g","Warn: Project is vulnerable to: GHSA-5r5r-6hpj-8gg9","Warn: Project is vulnerable to: GHSA-5ww9-j83m-q7qx","Warn: Project is vulnerable to: GHSA-645p-88qh-w398","Warn: Project is vulnerable to: GHSA-6fpp-rgj9-8rwc","Warn: Project is vulnerable to: GHSA-6wqp-v4v6-c87c","Warn: Project is vulnerable to: GHSA-758m-v56v-grj4","Warn: Project is vulnerable to: GHSA-85cw-hj65-qqv9","Warn: Project is vulnerable to: GHSA-89qr-369f-5m5x","Warn: Project is vulnerable to: GHSA-8c4j-34r4-xr8g","Warn: Project is vulnerable to: GHSA-8w26-6f25-cm9x","Warn: Project is vulnerable to: GHSA-95cm-88f5-f2c7","Warn: Project is vulnerable to: GHSA-9gph-22xh-8x98","Warn: Project is vulnerable to: GHSA-9m6f-7xcq-8vf8","Warn: Project is vulnerable to: GHSA-9mxf-g3x6-wv74","Warn: Project is vulnerable to: GHSA-9vvp-fxw6-jcxr","Warn: Project is vulnerable to: GHSA-c265-37vj-cwcc","Warn: Project is vulnerable to: GHSA-c2q3-4qrh-fm48","Warn: Project is vulnerable to: GHSA-c8hm-7hpq-7jhg","Warn: Project is vulnerable to: GHSA-cf6r-3wgc-h863","Warn: Project is vulnerable to: GHSA-cjjf-94ff-43w7","Warn: Project is vulnerable to: GHSA-cmfg-87vq-g5g4","Warn: Project is vulnerable to: GHSA-cvm9-fjm9-3572","Warn: Project is vulnerable to: GHSA-f3j5-rmmp-3fc5","Warn: Project is vulnerable to: GHSA-f9hv-mg5h-xcw9","Warn: Project is vulnerable to: GHSA-f9xh-2qgp-cq57","Warn: Project is vulnerable to: GHSA-fmmc-742q-jg75","Warn: Project is vulnerable to: GHSA-fqwf-pjwf-7vqv","Warn: Project is vulnerable to: GHSA-gjmw-vf9h-g25v","Warn: Project is vulnerable to: GHSA-gwp4-hfv6-p7hw","Warn: Project is vulnerable to: GHSA-gww7-p5w4-wrfv","Warn: Project is vulnerable to: GHSA-h3cw-g4mq-c5x2","Warn: Project is vulnerable to: GHSA-h4rc-386g-6m85","Warn: Project is vulnerable to: GHSA-h822-r4r5-v8jg","Warn: Project is vulnerable to: GHSA-j823-4qch-3rgm","Warn: Project is vulnerable to: GHSA-jjjh-jjxp-wpff","Warn: Project is vulnerable to: GHSA-m6x4-97wx-4q27","Warn: Project is vulnerable to: GHSA-mc6h-4qgp-37qh","Warn: Project is vulnerable to: GHSA-mph4-vhrx-mv67","Warn: Project is vulnerable to: GHSA-mx7p-6679-8g3q","Warn: Project is vulnerable to: GHSA-mx9v-gmh4-mgqw","Warn: Project is vulnerable to: GHSA-p43x-xfjf-5jhr","Warn: Project is vulnerable to: GHSA-q93h-jc49-78gg","Warn: Project is vulnerable to: GHSA-qjw2-hr98-qgfh","Warn: Project is vulnerable to: GHSA-qmqc-x3r4-6v39","Warn: Project is vulnerable to: GHSA-qr7j-h6gg-jmgc","Warn: Project is vulnerable to: GHSA-r3gr-cxrf-hg25","Warn: Project is vulnerable to: GHSA-r695-7vr9-jgc2","Warn: Project is vulnerable to: GHSA-rf6r-2c4q-2vwg","Warn: Project is vulnerable to: GHSA-rgv9-q543-rqg4","Warn: Project is vulnerable to: GHSA-rpr3-cw39-3pxh","Warn: Project is vulnerable to: GHSA-v3xw-c963-f5hc","Warn: Project is vulnerable to: GHSA-v585-23hc-c647","Warn: Project is vulnerable to: GHSA-vfqx-33qm-g869","Warn: Project is vulnerable to: GHSA-wh8g-3j2c-rqj5","Warn: Project is vulnerable to: GHSA-x2w5-5m2g-7h5m","Warn: Project is vulnerable to: GHSA-j288-q9x7-2f5v","Warn: Project is vulnerable to: GHSA-7r82-7xv7-xcpj","Warn: Project is vulnerable to: GHSA-3vqj-43w4-2q58","Warn: Project is vulnerable to: GHSA-4jq9-2xhw-jpx7"],"documentation":{"short":"Determines if the project has open, known unfixed vulnerabilities.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#vulnerabilities"}}]},"last_synced_at":"2025-08-23T13:32:39.236Z","repository_id":57722688,"created_at":"2025-08-23T13:32:39.236Z","updated_at":"2025-08-23T13:32:39.236Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":28408711,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-01-14T01:52:23.358Z","status":"online","status_checked_at":"2026-01-14T02:00:06.678Z","response_time":107,"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":["2fa","authentication","blockchain","hydro","java","mfa","raindrop","sdk-java"],"created_at":"2026-01-14T02:25:03.820Z","updated_at":"2026-01-14T02:25:04.327Z","avatar_url":"https://github.com/serkanalgl.png","language":"Java","readme":"# Java library for Hydro Raindrop Api\n\n\u003cimg src=\"https://github.com/serkanalgl/hydro-raindrop-java/blob/master/hydro_logo.png\"\u003e\n\n## Introduction\n\n\u003cp\u003eThis java library provides a suite of convenience functions intended to simplify the integration of Hydro's Raindrop authentication into your project.\u003c/p\u003e\n\n\u003cp\u003eOffical Raindrop API documentation is available \u003ca href=\"https://www.hydrogenplatform.com/docs/hydro/v1/\"\u003ehere\u003c/a\u003e\u003c/p\u003e\n\n## Dependency\n\n- \u003ca href=\"https://github.com/serkanalgl/hydro-oauth2-java\"\u003ehydro-oauth2-java 1.0.0\u003c/a\u003e\n- unirest-java 1.4.9\n\n\n## Compilation\n\n- Java 1.8\n- Maven 3\n\n\n## Installation\n\n### Recommended\n\nAdd below dependency into your pom.xml\n\n```\n\u003cdependency\u003e\n    \u003cgroupId\u003ecom.github.serkanalgl\u003c/groupId\u003e\n    \u003cartifactId\u003ehydro-raindrop-java\u003c/artifactId\u003e\n    \u003cversion\u003e1.0.0\u003c/version\u003e\n\u003c/dependency\u003e\n```\n\n\n### Manual\n\nYou can also install manually:\n\n```shell\ngit clone https://github.com/serkanalgl/hydro-raindrop-java.git\ncd hydro-raindrop-java\nmvn clean install\n```\n\n## Usage\n \n## Client-side Raindrop\nFirst, you should initialize RaindropPartnerConfig with Builder and then create a new RaindropClient instance with it.\n\n```java\n\ntry{\n\n    RaindropPartnerConfig config = new RaindropPartnerConfig.Builder(\"client id\", \"client secret\", Environment.PRODUCTION)\n        .setApplicationId(\"application id\")\n        .build(); \n          \n    RaindropClient client = new Raindrop().client(config);\n    \n}catch (Exception e) {\n    //something went wrong\n}\n  \n```\n\nTo create a new RaindropPartnerConfig object, you must pass the following parameters:\n\n  - `clientId` (required): Your OAuth id for the Hydro API\n  - `clientSecret` (required): Your OAuth secret for the Hydro API\n  - `environment` (default: SANDBOX): `Environment.SANDBOX` | `Environment.PRODUCTION`\n  - `applicationId` (required): Your application id for the Hydro API  \n  \n\n### RaindropClient Functions\n\n#### `registerUser(String hydroId)`\nTo register a user, you will need to collect the HydroID that identifies them on the Hydro app and map it to your application. \n\n```java\n\ntry{\n\n    BaseResponse response = client.registerUser(hydroId); \n    \n}catch (RaindropException e) {\n    //something went wrong\n}\n                 \n```\n\n- `BaseResponse`\n    - `response.getStatus()` : Returns a 200 if the user has been successfully mapped to your application. \n    - `response.getMessage()`: Success/Error message\n\n\n#### `generateMessage()`\nThis method generates 6-digit number using with SecureRandom. You should show this number to your users. The user will type into the hydro mobile app.\n\n```java\n\ntry{\n\n    Integer message = client.generateMessage(); \n    \n}catch (RaindropException e) {\n    //something went wrong\n}\n                 \n```\n\n\n#### `verifySignature(String hydroId, Integer message)`\nWhen the users enter that message into their mobile device, the API will verify that the correct user signed the message against the information stored on the blockchain.\n\n```java\n\ntry{\n\n    VerifySignature response = client.verifySignature(hydroId, message); \n    \n}catch (RaindropException e) {\n    //something went worng\n}\n                 \n```\n\n- `VerifySignature`\n    - `response.isVerified()`: Successful verifications will return `true`\n    - `response.getVerificationId()`: Returns a UUID for this verification attempt.\n    - `response.getTimestamp()`: The time of this verification attempt.\n\n\n#### `deleteUser(String hydroId)`\nFor a variety of reasons, a user may want to disable MFA or may delete their account on your platform.\n\n```java\n\ntry{\n\n    BaseResponse response = client.deleteUser(hydroId); \n    \n}catch (RaindropException e) {\n    //something went wrong\n}\n                 \n```\n\n- `BaseResponse`\n    - `response.getStatus()` : Returns a 200 deleting their mapping to your application. \n    - `response.getMessage()`: Success/Error message\n\n\n## Server-side Raindrop\nFirst, you should initialize RaindropPartnerConfig with Builder and then create a new RaindropServer instance with it.\n\n```java\n\ntry{\n\n    RaindropPartnerConfig config = new RaindropPartnerConfig.Builder(\"client id\", \"client secret\", Environment.PRODUCTION).build(); \n        \n    RaindropServer server = new Raindrop().server(config);\n    \n}catch (Exception e) {\n    //something went wrong\n}\n  \n```\n\nTo create a new `RaindropPartnerConfig` object, you must pass the following parameters:\n\n  - `clientId` (required): Your OAuth id for the Hydro API\n  - `clientSecret` (required): Your OAuth secret for the Hydro API\n  - `environment` (default: SANDBOX): `Environment.SANDBOX` | `Environment.PRODUCTION`\n  \n\n### RaindropServer Functions\n\n#### `whitelist(String address)`\nAdd address to whitelist ( be careful, for security purposes, the id will only be generated one time. ) The hydroAddressId should be stored on your databasse.\n\n```java\n\ntry{\n\n    String address = \"0x...\"; //The user’s Ethereum/Hydro address\n\n    Whitelist whitelist = server.whitelist(address); \n    \n}catch (RaindropException e) {\n    //something went wrong\n}\n                 \n```\n\n- `Whitelist`\n    - `whitelist.getStatus()` : Returns a 200 if the address has been whitelisted. \n    - `whitelist.getMessage()`: Success/Error message\n    - `whitelist.getHydroAddressId()`: The authenticating user’s newly assigned address id\n    - `whitelist.getTransactionHash()`: The hash of the transaction whitelisting the user\n\n\n\n\n#### `challenge(String hydroAddressId)`\nAfter being whitelisted, each user must authenticate through the Server-side Raindrop process once every 24 hours to retain access to the protected system.\n\n```java\n\ntry{\n\n    Challenge challenge = server.challenge(hydroAddressId);\n    \n}catch (RaindropException e) {\n    //something went wrong\n}\n                 \n```\n\n- `Challenge`\n    - `challenge.getStatus()` : Returns a 200 if challenge response is success. \n    - `challenge.getMessage()`: Success/Error message\n    - `challenge.getAmount()`: The challenge amount\n    - `challenge.getChallenge()`: The challenge string\n    - `challenge.getPartnerId()`: The unique identifier assigned to your firm\n    - `challenge.getTransactionHash()`: The hash of the transaction that updates the user’s raindrop requirements\n\nYou will need to relay these values to the authenticating user who will send them to a \u003ca href=\"https://www.hydrogenplatform.com/docs/hydro/v1/#Smart-Contract\"\u003eHydro smart contract\u003c/a\u003e, so treat them accordingly.\n\n\n#### `authenticate(String hydroAddressId)`\nOnce the raindrop has been completed by the end user and confirmed in the blockchain, the final authentication check can be performed.\n\n```java\n\ntry{\n\n    Authenticate authenticate = server.authenticate(hydroAddressId);\n    \n}catch (RaindropException e) {\n    //something went wrong\n}\n                 \n```\n\n- `Authenticate`\n    - `authenticate.isAuthenticated()`: Returns `true` if authenticated\n    - `authenticate.getAuthenticationId()`: A UUID for this verification attempt.\n    - `authenticate.getTimestamp()`: The time of this verification attempt.\n\n\n\n## Generic Functions for Client and Server\n\n### `transactionStatus(String transactionHash)`\nCertain methods in the Hydro API trigger transactions on the Ethereum blockchain. Transactions take time to be confirmed, so rather than waiting for confirmation, these methods will return a transaction_hash as soon as our internal logic has completed successfully and the appropriate transaction has been broadcast to the Ethereum network.\n\nExample code for Raindrop Client:\n```java\n\ntry{\n\n    RaindropPartnerConfig config = new RaindropPartnerConfig.Builder(\"client id\", \"client secret\", Environment.PRODUCTION)\n        .setApplicationId(\"application id\")\n        .build(); \n              \n    RaindropClient client = new Raindrop().client(config);\n\n    TransactionStatus transactionStatus = client.transactionStatus(\"0x....\");\n    \n}catch (RaindropException e) {\n    //something went wrong\n}\n                 \n```\n\n\nExample code for Raindrop Server:\n```java\n\ntry{\n\n    RaindropPartnerConfig config = new RaindropPartnerConfig.Builder(\"client id\", \"client secret\", Environment.PRODUCTION).build(); \n            \n    RaindropServer server = new Raindrop().server(config);\n\n    TransactionStatus transactionStatus = server.transactionStatus(\"0x....\");\n    \n}catch (RaindropException e) {\n    //something went wrong\n}\n                 \n```\n\n- `TransactionStatus`\n    - `transactionStatus.isCompleted()`: Indication of whether the transaction has been confirmed\n    - `transactionStatus.getTransactionHash()`: The transaction hash\n\n\n\n\n## Contact\n\nIf you have any further question/suggestion/issue, do not hesitate to contact me.\n\nserkanalgl@gmail.com\n\n\n## Donate\n\n### Ethereum \u003cbr /\u003e\n\n\u003cimg src=\"https://github.com/serkanalgl/hydro-raindrop-java/blob/master/qr.png\"\u003e\n\n\n## Copyright\n\nCopyright (c) 2018, Under MIT licence Serkan Algül. All rights reserved.\n","funding_links":[],"categories":[],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fserkanalgl%2Fhydro-raindrop-java","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fserkanalgl%2Fhydro-raindrop-java","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fserkanalgl%2Fhydro-raindrop-java/lists"}