{"id":13581941,"url":"https://github.com/haproxytech/dataplaneapi","last_synced_at":"2026-04-03T12:04:41.022Z","repository":{"id":37821061,"uuid":"186656753","full_name":"haproxytech/dataplaneapi","owner":"haproxytech","description":"HAProxy Data Plane API","archived":false,"fork":false,"pushed_at":"2026-03-05T16:19:35.000Z","size":34188,"stargazers_count":366,"open_issues_count":70,"forks_count":86,"subscribers_count":18,"default_branch":"master","last_synced_at":"2026-03-05T18:49:52.231Z","etag":null,"topics":["dataplane","haproxy","haproxy-configuration","sidecar"],"latest_commit_sha":null,"homepage":"https://www.haproxy.com/documentation/dataplaneapi/","language":"Go","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/haproxytech.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":"CONTRIBUTING.md","funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"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":"2019-05-14T16:05:21.000Z","updated_at":"2026-03-05T16:11:05.000Z","dependencies_parsed_at":"2023-12-14T13:36:27.463Z","dependency_job_id":"241d2af2-080d-4868-88ac-e3ff274835f1","html_url":"https://github.com/haproxytech/dataplaneapi","commit_stats":null,"previous_names":[],"tags_count":146,"template":false,"template_full_name":null,"purl":"pkg:github/haproxytech/dataplaneapi","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/haproxytech%2Fdataplaneapi","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/haproxytech%2Fdataplaneapi/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/haproxytech%2Fdataplaneapi/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/haproxytech%2Fdataplaneapi/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/haproxytech","download_url":"https://codeload.github.com/haproxytech/dataplaneapi/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/haproxytech%2Fdataplaneapi/sbom","scorecard":{"id":455453,"data":{"date":"2025-08-11","repo":{"name":"github.com/haproxytech/dataplaneapi","commit":"6d654c58bc51147bd17ffd0f69e61681e7d4450b"},"scorecard":{"version":"v5.2.1-40-gf6ed084d","commit":"f6ed084d17c9236477efd66e5b258b9d4cc7b389"},"score":4.8,"checks":[{"name":"Code-Review","score":0,"reason":"Found 1/29 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":"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/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#dangerous-workflow"}},{"name":"Maintained","score":10,"reason":"22 commit(s) and 4 issue activity 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/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#maintained"}},{"name":"Token-Permissions","score":0,"reason":"detected GitHub workflow tokens with excessive permissions","details":["Warn: no topLevel permission defined: .github/workflows/.goreleaser.yml:1","Warn: no topLevel permission defined: .github/workflows/build.yml:1","Warn: no topLevel permission defined: .github/workflows/check.yml:1","Warn: no topLevel permission defined: .github/workflows/e2e.yml:1","Warn: no topLevel permission defined: .github/workflows/lint.yml:1","Warn: no topLevel permission defined: .github/workflows/manual_goreleaser.yml:1","Info: no jobLevel write permissions found"],"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":"License","score":10,"reason":"license file detected","details":["Info: project has a license file: LICENSE:0","Info: FSF or OSI recognized license: Apache License 2.0: LICENSE:0"],"documentation":{"short":"Determines if the project has defined a license.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#license"}},{"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":"Branch-Protection","score":-1,"reason":"internal error: error during branchesHandler.setup: internal error: githubv4.Query: Resource not accessible by integration","details":null,"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":"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":"Packaging","score":10,"reason":"packaging workflow detected","details":["Info: Project packages its releases by way of GitHub Actions.: .github/workflows/.goreleaser.yml:7"],"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":"Signed-Releases","score":0,"reason":"Project has not signed or included provenance with any releases.","details":["Warn: release artifact v3.2.3 not signed: https://api.github.com/repos/haproxytech/dataplaneapi/releases/238331449","Warn: release artifact v3.1.8 not signed: https://api.github.com/repos/haproxytech/dataplaneapi/releases/238334257","Warn: release artifact v3.0.12 not signed: https://api.github.com/repos/haproxytech/dataplaneapi/releases/238334239","Warn: release artifact v2.9.16 not signed: https://api.github.com/repos/haproxytech/dataplaneapi/releases/238334253","Warn: release artifact v3.2.1 not signed: https://api.github.com/repos/haproxytech/dataplaneapi/releases/225557804","Warn: release artifact v3.2.3 does not have provenance: https://api.github.com/repos/haproxytech/dataplaneapi/releases/238331449","Warn: release artifact v3.1.8 does not have provenance: https://api.github.com/repos/haproxytech/dataplaneapi/releases/238334257","Warn: release artifact v3.0.12 does not have provenance: https://api.github.com/repos/haproxytech/dataplaneapi/releases/238334239","Warn: release artifact v2.9.16 does not have provenance: https://api.github.com/repos/haproxytech/dataplaneapi/releases/238334253","Warn: release artifact v3.2.1 does not have provenance: https://api.github.com/repos/haproxytech/dataplaneapi/releases/225557804"],"documentation":{"short":"Determines if the project cryptographically signs release artifacts.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#signed-releases"}},{"name":"Pinned-Dependencies","score":1,"reason":"dependency not pinned by hash detected -- score normalized to 1","details":["Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/.goreleaser.yml:11: update your workflow using https://app.stepsecurity.io/secureworkflow/haproxytech/dataplaneapi/.goreleaser.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/.goreleaser.yml:16: update your workflow using https://app.stepsecurity.io/secureworkflow/haproxytech/dataplaneapi/.goreleaser.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/.goreleaser.yml:21: update your workflow using https://app.stepsecurity.io/secureworkflow/haproxytech/dataplaneapi/.goreleaser.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/build.yml:12: update your workflow using https://app.stepsecurity.io/secureworkflow/haproxytech/dataplaneapi/build.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/build.yml:14: update your workflow using https://app.stepsecurity.io/secureworkflow/haproxytech/dataplaneapi/build.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/check.yml:11: update your workflow using https://app.stepsecurity.io/secureworkflow/haproxytech/dataplaneapi/check.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/e2e.yml:15: update your workflow using https://app.stepsecurity.io/secureworkflow/haproxytech/dataplaneapi/e2e.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/e2e.yml:19: update your workflow using https://app.stepsecurity.io/secureworkflow/haproxytech/dataplaneapi/e2e.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/lint.yml:12: update your workflow using https://app.stepsecurity.io/secureworkflow/haproxytech/dataplaneapi/lint.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/lint.yml:14: update your workflow using https://app.stepsecurity.io/secureworkflow/haproxytech/dataplaneapi/lint.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/lint.yml:17: update your workflow using https://app.stepsecurity.io/secureworkflow/haproxytech/dataplaneapi/lint.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/lint.yml:34: update your workflow using https://app.stepsecurity.io/secureworkflow/haproxytech/dataplaneapi/lint.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/lint.yml:36: update your workflow using https://app.stepsecurity.io/secureworkflow/haproxytech/dataplaneapi/lint.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/lint.yml:39: update your workflow using https://app.stepsecurity.io/secureworkflow/haproxytech/dataplaneapi/lint.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/manual_goreleaser.yml:9: update your workflow using https://app.stepsecurity.io/secureworkflow/haproxytech/dataplaneapi/manual_goreleaser.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/manual_goreleaser.yml:14: update your workflow using https://app.stepsecurity.io/secureworkflow/haproxytech/dataplaneapi/manual_goreleaser.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/manual_goreleaser.yml:22: update your workflow using https://app.stepsecurity.io/secureworkflow/haproxytech/dataplaneapi/manual_goreleaser.yml/master?enable=pin","Warn: containerImage not pinned by hash: generate/swagger/Dockerfile:2","Warn: downloadThenRun not pinned by hash: bin/lint-check.sh:6","Info:   0 out of  14 GitHub-owned GitHubAction dependencies pinned","Info:   0 out of   3 third-party GitHubAction dependencies pinned","Info:   0 out of   1 containerImage dependencies pinned","Info:   0 out of   1 downloadThenRun dependencies pinned","Info:   1 out of   1 goCommand 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/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#pinned-dependencies"}},{"name":"SAST","score":0,"reason":"SAST tool is not run on all commits -- score normalized to 0","details":["Warn: 0 commits out of 2 are checked with a SAST tool"],"documentation":{"short":"Determines if the project uses static code analysis.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#sast"}},{"name":"Vulnerabilities","score":10,"reason":"0 existing vulnerabilities detected","details":null,"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-19T09:28:13.590Z","repository_id":37821061,"created_at":"2025-08-19T09:28:13.591Z","updated_at":"2025-08-19T09:28:13.591Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":30298258,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-03-09T13:46:43.843Z","status":"ssl_error","status_checked_at":"2026-03-09T13:46:42.821Z","response_time":61,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.5:443 state=error: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"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":["dataplane","haproxy","haproxy-configuration","sidecar"],"created_at":"2024-08-01T15:02:20.311Z","updated_at":"2026-03-09T14:14:52.402Z","avatar_url":"https://github.com/haproxytech.png","language":"Go","readme":"# ![HAProxy](assets/images/haproxy-weblogo-210x49.png \"HAProxy\")\n\n## HAProxy Data Plane API\n\n[![Contributors](https://img.shields.io/github/contributors/haproxytech/dataplaneapi?color=purple)](CONTRIBUTING.md)\n[![License](https://img.shields.io/badge/License-Apache%202.0-blue.svg)](LICENSE)\n\n**Data Plane API** is a sidecar process that runs next to HAProxy and provides API endpoints for managing HAProxy. It requires HAProxy version 1.9.0 or higher.\n\n## Building the Data Plane API\n\nIn order to build the Data Plane API you need Go installed on your system with go modules support enabled, and execute the following steps:\n\n1\\. Clone dataplaneapi repository\n\n```\ngit clone https://github.com/haproxytech/dataplaneapi.git\n```\n\n2\\. Run make build:\n\n```\nmake build\n```\n\n3\\. You can find the built binary in /build directory. TEST\n\n## Running the Data Plane API\nBasic usage:\n\n```\nUsage:\n  dataplaneapi [OPTIONS]\n\nAPI for editing and managing haproxy instances\n\nApplication Options:\n      --scheme=                                       the listeners to enable, this can be repeated and defaults to the schemes in the swagger spec\n      --cleanup-timeout=                              grace period for which to wait before killing idle connections (default: 10s)\n      --graceful-timeout=                             grace period for which to wait before shutting down the server (default: 15s)\n      --max-header-size=                              controls the maximum number of bytes the server will read parsing the request header's keys and values, including the request line. It does not limit the size of the request\n                                                      body. (default: 1MiB)\n      --socket-path=                                  the unix socket to listen on (default: /var/run/data-plane.sock)\n      --host=                                         the IP to listen on (default: localhost) [$HOST]\n      --port=                                         the port to listen on for insecure connections, defaults to a random value [$PORT]\n      --listen-limit=                                 limit the number of outstanding requests\n      --keep-alive=                                   sets the TCP keep-alive timeouts on accepted connections. It prunes dead TCP connections ( e.g. closing laptop mid-download) (default: 3m)\n      --read-timeout=                                 maximum duration before timing out read of the request (default: 30s)\n      --write-timeout=                                maximum duration before timing out write of the response (default: 60s)\n      --tls-host=                                     the IP to listen on for tls, when not specified it's the same as --host [$TLS_HOST]\n      --tls-port=                                     the port to listen on for secure connections, defaults to a random value [$TLS_PORT]\n      --tls-certificate=                              the certificate to use for secure connections [$TLS_CERTIFICATE]\n      --tls-key=                                      the private key to use for secure connections [$TLS_PRIVATE_KEY]\n      --tls-ca=                                       the certificate authority file to be used with mutual tls auth [$TLS_CA_CERTIFICATE]\n      --tls-listen-limit=                             limit the number of outstanding requests\n      --tls-keep-alive=                               sets the TCP keep-alive timeouts on accepted connections. It prunes dead TCP connections ( e.g. closing laptop mid-download)\n      --tls-read-timeout=                             maximum duration before timing out read of the request\n      --tls-write-timeout=                            maximum duration before timing out write of the response\n      --uid                                           user id value to set on start\n      --gid                                           group id value to set on start\n\nHAProxy options:\n  -c, --config-file=                                  Path to the haproxy configuration file (default: /etc/haproxy/haproxy.cfg)\n  -u, --userlist=                                     Userlist in HAProxy configuration to use for API Basic Authentication (default: controller)\n  -b, --haproxy-bin=                                  Path to the haproxy binary file (default: haproxy)\n  -d, --reload-delay=                                 Minimum delay between two reloads (in s) (default: 5)\n  -r, --reload-cmd=                                   Reload command\n  -s, --restart-cmd=                                  Restart command\n      --reload-retention=                             Reload retention in days, every older reload id will be deleted (default: 1)\n  -t, --transaction-dir=                              Path to the transaction directory (default: /tmp/haproxy)\n  -n, --backups-number=                               Number of backup configuration files you want to keep, stored in the config dir with version number suffix (default: 0)\n      --backups-dir=                                  Path to directory in which to place backup files\n  -m, --master-runtime=                               Path to the master Runtime API socket\n  -i, --show-system-info                              Show system info on info endpoint\n  -f=                                                 Path to the dataplane configuration file (default: /etc/haproxy/dataplaneapi.yaml)\n      --userlist-file=                                Path to the dataplaneapi userlist file. By default userlist is read from HAProxy conf. When specified userlist would be read from this file\n      --fid=                                          Path to file that will dataplaneapi use to write its id (not a pid) that was given to him after joining a cluster\n  -p, --maps-dir=                                     Path to directory of map files managed by dataplane (default: /etc/haproxy/maps)\n      --ssl-certs-dir=                                Path to SSL certificates directory (default: /etc/haproxy/ssl)\n      --update-map-files                              Flag used for syncing map files with runtime maps values\n      --update-map-files-period=                      Elapsed time in seconds between two maps syncing operations (default: 10)\n      --cluster-tls-dir=                              Path where cluster tls certificates will be stored. Defaults to same directory as dataplane configuration file\n      --spoe-dir=                                     Path to SPOE directory. (default: /etc/haproxy/spoe)\n      --spoe-transaction-dir=                         Path to the SPOE transaction directory (default: /tmp/spoe-haproxy)\n      --master-worker-mode                            Flag to enable helpers when running within HAProxy\n      --max-open-transactions=                        Limit for active transaction in pending state (default: 20)\n      --validate-cmd=                                 Executes a custom command to perform the HAProxy configuration check\n      --disable-inotify                               Disables inotify watcher watcher for the configuration file\n      --pid-file=                                     Path to file that will dataplaneapi use to write its pid\n      --debug-socket-path=                            Unix socket path for the debugging command socket\nLogging options:\n      --log-to=[stdout|file|syslog]                   Log target, can be stdout, file, or syslog (default: stdout)\n      --log-file=                                     Location of the log file (default: /var/log/dataplaneapi/dataplaneapi.log)\n      --log-level=[trace|debug|info|warning|error]    Logging level (default: warning)\n      --log-format=[text|JSON]                        Logging format (default: text)\n      --apache-common-log-format=                     Apache Common Log Format to format the access log entries (default: %h %l %u %t \"%r\" %\u003es %b \"%{Referer}i\" \"%{User-agent}i\" %{us}T)\n\nSyslog options:\n      --syslog-address=                               Syslog address (with port declaration in case of TCP type) where logs should be forwarded: accepting socket path in case of unix or unixgram\n      --syslog-protocol=[tcp|tcp4|tcp6|unix|unixgram] Syslog server protocol (default: tcp)\n      --syslog-tag=                                   String to tag the syslog messages (default: dataplaneapi)\n      --syslog-level=                                 Define the required syslog messages level, allowed values: debug|info|notice|warning|error|critical|alert|emergency  (default: debug)\n      --syslog-facility=                              Define the Syslog facility number, allowed values: kern|user|mail|daemon|auth|syslog|lpr|news|uucp|cron|authpriv|ftp|local0|local1|local2|local3|local4|local5|local6|local7\n                                                      (default: local0)\n\nShow version:\n  -v, --version                                       Version and build information\n\nHelp Options:\n  -h, --help                                          Show this help message\n```\n\nBeside those options, everything can be defined in side of configuration file. See [configuration file](configuration/README.md)\n\n## Example\n\nYou can test it by simply running:\n\n```\n./dataplaneapi --port 5555 -b /usr/sbin/haproxy -c /etc/haproxy/haproxy.cfg  -d 5 -r \"service haproxy reload\" -s \"service haproxy restart\" -u dataplaneapi -t /tmp/haproxy\n```\n\nDataplaneapi will require write permissions to the haproxy configuration file and the directories containing additional managed files (maps, ssl, spoe). The default locations can be overriden with command-line options.\nTest it out with curl, note that you need user/pass combination setup in HAProxy userlist in haproxy configuration (in above example: /etc/haproxy/haproxy.cfg, userlist controller):\n\n```\ncurl -u \u003cuser\u003e:\u003cpass\u003e -H \"Content-Type: application/json\" \"http://127.0.0.1:5555/v2/\"\n```\n\nIf you are using secure passwords, supported algorithms are: md5, sha-256 and sha-512.\n\n## Using the Data Plane API\n\nFor more docs how to use the Data Plane API check our [documentation](https://www.haproxy.com/documentation/hapee/latest/api/data-plane-api/)\n\nAlternatively, dataplaneapi serves its own interactive documentation relevant for the current build on the `/v2/docs` uri. Just point your browser to the host/port dataplane was started with (i.e. `http://localhost:5555/v2/docs`)\n\n## Service Discovery\n\nCheck the documentation in the [README](./discovery/README.md).\n\n## Command socket for debugging purpose\n\nCheck the documentation in the [README](./runtime/README.md).\n\n## Contributing\n\nIf you wish to contribute to this project please check [Contributing Guide](CONTRIBUTING.md)\n","funding_links":[],"categories":["Go"],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fhaproxytech%2Fdataplaneapi","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fhaproxytech%2Fdataplaneapi","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fhaproxytech%2Fdataplaneapi/lists"}