{"id":19475452,"url":"https://github.com/artdecocode/logarithm","last_synced_at":"2026-06-09T01:33:56.512Z","repository":{"id":135405161,"uuid":"158052344","full_name":"artdecocode/logarithm","owner":"artdecocode","description":"A Koa Middleware For Web-Server To Record Hits In ElasticSearch.","archived":false,"fork":false,"pushed_at":"2020-03-10T01:04:14.000Z","size":214,"stargazers_count":2,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"master","last_synced_at":"2025-11-19T01:02:55.546Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":"https://www.artd.eco","language":"JavaScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/artdecocode.png","metadata":{"files":{"readme":"README.md","changelog":"CHANGELOG.md","contributing":null,"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}},"created_at":"2018-11-18T05:16:08.000Z","updated_at":"2020-03-10T01:04:17.000Z","dependencies_parsed_at":"2023-07-17T11:32:22.607Z","dependency_job_id":null,"html_url":"https://github.com/artdecocode/logarithm","commit_stats":null,"previous_names":[],"tags_count":11,"template":false,"template_full_name":null,"purl":"pkg:github/artdecocode/logarithm","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/artdecocode%2Flogarithm","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/artdecocode%2Flogarithm/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/artdecocode%2Flogarithm/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/artdecocode%2Flogarithm/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/artdecocode","download_url":"https://codeload.github.com/artdecocode/logarithm/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/artdecocode%2Flogarithm/sbom","scorecard":{"id":208896,"data":{"date":"2025-08-11","repo":{"name":"github.com/artdecocode/logarithm","commit":"67a3a6e484a93c518e81b9255f3858a9def1245c"},"scorecard":{"version":"v5.2.1-40-gf6ed084d","commit":"f6ed084d17c9236477efd66e5b258b9d4cc7b389"},"score":3,"checks":[{"name":"Code-Review","score":0,"reason":"Found 0/30 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":"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":"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":"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":"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":"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":"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":"License","score":10,"reason":"license file detected","details":["Info: project has a license file: LICENSE:0","Info: FSF or OSI recognized license: MIT License: 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":"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":"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-17T00:21:14.347Z","repository_id":135405161,"created_at":"2025-08-17T00:21:14.347Z","updated_at":"2025-08-17T00:21:14.347Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":34088013,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-05-26T15:22:16.424Z","status":"online","status_checked_at":"2026-06-08T02:00:07.615Z","response_time":111,"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":[],"created_at":"2024-11-10T19:32:54.735Z","updated_at":"2026-06-09T01:33:56.491Z","avatar_url":"https://github.com/artdecocode.png","language":"JavaScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"# logarithm\n\n[![npm version](https://badge.fury.io/js/logarithm.svg)](https://www.npmjs.com/package/logarithm)\n\n`logarithm` Is A Koa Middleware That Records Logs In _ElasticSearch_. The CLI binary also allows to execute commands on the _ElasticSearch_ instance via the API, such as:\n\n- creating snapshots,\n- installing templates,\n- _etc_\n\n```sh\nyarn add logarithm\n```\n\n## Table Of Contents\n\n- [Table Of Contents](#table-of-contents)\n- [API](#api)\n- [`logarithm(options: !Config): !_goa.Middleware`](#logarithmoptions-config-_goamiddleware)\n  * [`Config`](#type-config)\n  * [`Hit`](#type-hit)\n- [`async ping(url: string, timeout: number): void`](#async-pingurl-stringtimeout-number-void)\n- [CLI](#cli)\n  * [List Templates, `-T`](#list-templates--t)\n  * [Statistics, `-s`](#statistics--s)\n- [Copyright \u0026 License](#copyright--license)\n\n\u003cp align=\"center\"\u003e\u003ca href=\"#table-of-contents\"\u003e\n  \u003cimg src=\"/.documentary/section-breaks/0.svg?sanitize=true\"\u003e\n\u003c/a\u003e\u003c/p\u003e\n\n## API\n\nThe package is available by importing its default function and a named function:\n\n```js\nimport logarithm, { ping } from 'logarithm'\n```\n\n\u003cp align=\"center\"\u003e\u003ca href=\"#table-of-contents\"\u003e\n  \u003cimg src=\"/.documentary/section-breaks/1.svg?sanitize=true\"\u003e\n\u003c/a\u003e\u003c/p\u003e\n\n## \u003ccode\u003e\u003cins\u003elogarithm\u003c/ins\u003e(\u003c/code\u003e\u003csub\u003e\u003cbr/\u003e\u0026nbsp;\u0026nbsp;`options: !Config,`\u003cbr/\u003e\u003c/sub\u003e\u003ccode\u003e): \u003ci\u003e!_goa.Middleware\u003c/i\u003e\u003c/code\u003e\nCreates a middleware for logging requests in _Koa_/_Goa_ web-server and returns it.\n\n - \u003ckbd\u003e\u003cstrong\u003eoptions*\u003c/strong\u003e\u003c/kbd\u003e \u003cem\u003e\u003ccode\u003e\u003ca href=\"#type-config\" title=\"Options for the program.\"\u003e!Config\u003c/a\u003e\u003c/code\u003e\u003c/em\u003e: Options for the middleware.\n\n__\u003ca name=\"type-config\"\u003e`Config`\u003c/a\u003e__: Options for the program.\n\u003ctable\u003e\n \u003cthead\u003e\u003ctr\u003e\n  \u003cth\u003eName\u003c/th\u003e\n  \u003cth\u003eType \u0026amp; Description\u003c/th\u003e\n  \u003cth\u003eDefault\u003c/th\u003e\n \u003c/tr\u003e\u003c/thead\u003e\n \u003ctr\u003e\n  \u003ctd rowSpan=\"3\" align=\"center\"\u003e\u003cstrong\u003eapp*\u003c/strong\u003e\u003c/td\u003e\n  \u003ctd\u003e\u003cem\u003estring\u003c/em\u003e\u003c/td\u003e\n  \u003ctd rowSpan=\"3\"\u003e-\u003c/td\u003e\n \u003c/tr\u003e\n \u003ctr\u003e\u003c/tr\u003e\n \u003ctr\u003e\n  \u003ctd\u003e\n   The name of the website application.\n  \u003c/td\u003e\n \u003c/tr\u003e\n \u003ctr\u003e\n  \u003ctd rowSpan=\"3\" align=\"center\"\u003e\u003cstrong\u003eurl*\u003c/strong\u003e\u003c/td\u003e\n  \u003ctd\u003e\u003cem\u003estring\u003c/em\u003e\u003c/td\u003e\n  \u003ctd rowSpan=\"3\"\u003e-\u003c/td\u003e\n \u003c/tr\u003e\n \u003ctr\u003e\u003c/tr\u003e\n \u003ctr\u003e\n  \u003ctd\u003e\n   ElasticSearch endpoint URL, e.g., \u003ccode\u003ehttp://192.168.0.1:9200\u003c/code\u003e.\n  \u003c/td\u003e\n \u003c/tr\u003e\n \u003ctr\u003e\n  \u003ctd rowSpan=\"3\" align=\"center\"\u003etimeout\u003c/td\u003e\n  \u003ctd\u003e\u003cem\u003enumber\u003c/em\u003e\u003c/td\u003e\n  \u003ctd rowSpan=\"3\"\u003e\u003ccode\u003e5000\u003c/code\u003e\u003c/td\u003e\n \u003c/tr\u003e\n \u003ctr\u003e\u003c/tr\u003e\n \u003ctr\u003e\n  \u003ctd\u003e\n   Timeout for the connection after which an error is shown.\n  \u003c/td\u003e\n \u003c/tr\u003e\n \u003ctr\u003e\n  \u003ctd rowSpan=\"3\" align=\"center\"\u003epipeline\u003c/td\u003e\n  \u003ctd\u003e\u003cem\u003estring\u003c/em\u003e\u003c/td\u003e\n  \u003ctd rowSpan=\"3\"\u003e\u003ccode\u003einfo\u003c/code\u003e\u003c/td\u003e\n \u003c/tr\u003e\n \u003ctr\u003e\u003c/tr\u003e\n \u003ctr\u003e\n  \u003ctd\u003e\n   The pipeline in ElasticSearch, for example to parse GeoIP info and User-Agent.\n  \u003c/td\u003e\n \u003c/tr\u003e\n \u003ctr\u003e\n  \u003ctd rowSpan=\"3\" align=\"center\"\u003eindex\u003c/td\u003e\n  \u003ctd\u003e\u003cem\u003estring\u003c/em\u003e\u003c/td\u003e\n  \u003ctd rowSpan=\"3\"\u003e-\u003c/td\u003e\n \u003c/tr\u003e\n \u003ctr\u003e\u003c/tr\u003e\n \u003ctr\u003e\n  \u003ctd\u003e\n   The name of the index. Defaults to the app name if not specified.\n  \u003c/td\u003e\n \u003c/tr\u003e\n \u003ctr\u003e\n  \u003ctd rowSpan=\"3\" align=\"center\"\u003estrategy\u003c/td\u003e\n  \u003ctd colSpan=\"2\"\u003e\u003cem\u003e(index: string, date: !Date) =\u003e string\u003c/em\u003e\u003c/td\u003e\n \u003c/tr\u003e\n \u003ctr\u003e\u003c/tr\u003e\n \u003ctr\u003e\n  \u003ctd colSpan=\"2\"\u003e\n   How to construct the index name. By default, monthly strategy is used: \u003ccode\u003e${index}-${yyyy}.${mm}\u003c/code\u003e.\u003cbr/\u003e\n   \u003ckbd\u003e\u003cstrong\u003eindex*\u003c/strong\u003e\u003c/kbd\u003e \u003cem\u003e\u003ccode\u003estring\u003c/code\u003e\u003c/em\u003e: The general name of the index.\u003cbr/\u003e\n   \u003ckbd\u003e\u003cstrong\u003edate*\u003c/strong\u003e\u003c/kbd\u003e \u003cem\u003e\u003ccode\u003e!Date\u003c/code\u003e\u003c/em\u003e: The date of the request.\n  \u003c/td\u003e\n \u003c/tr\u003e\n\u003c/table\u003e\n\n```js\n/* yarn example/ */\nimport core from '@idio/idio'\nimport logarithm, { ping } from 'logarithm'\n\n(async () =\u003e {\n  await ping(process.env.ELASTIC)\n\n  // setup for idio web-server\n  const { url, app } = await core()\n\n  app.use(logarithm({\n    app: 'idio.cc',\n    url: process.env.ELASTIC,\n    index: 'clients',\n  }))\n  app.use(async (ctx) =\u003e {\n    ctx.body = 'hello world'\n  })\n  console.log(url)\n})()\n```\n\nThe following data structure is sent to the server:\n\n__\u003ca name=\"type-hit\"\u003e`Hit`\u003c/a\u003e__: A record sent to ElasticSearch.\n\n\n|     Name     |       Type       |                    Description                    |\n| ------------ | ---------------- | ------------------------------------------------- |\n| __app*__     | \u003cem\u003estring\u003c/em\u003e  | The application name from the config.             |\n| __ip*__      | \u003cem\u003estring\u003c/em\u003e  | Client IP address.                                |\n| __path*__    | \u003cem\u003estring\u003c/em\u003e  | The decoded request path.                         |\n| __headers*__ | \u003cem\u003e!Object\u003c/em\u003e | The request headers.                              |\n| __status*__  | \u003cem\u003enumber\u003c/em\u003e  | The status code.                                  |\n| __date*__    | \u003cem\u003e!Date\u003c/em\u003e   | The date of the request.                          |\n| __method*__  | \u003cem\u003estring\u003c/em\u003e  | The method of the request, e.g., `GET` or `POST`. |\n| query        | \u003cem\u003e!Object\u003c/em\u003e | Possible query from the request.                  |\n\n\u003cp align=\"center\"\u003e\u003ca href=\"#table-of-contents\"\u003e\n  \u003cimg src=\"/.documentary/section-breaks/2.svg?sanitize=true\" width=\"15\"\u003e\n\u003c/a\u003e\u003c/p\u003e\n\n## \u003ccode\u003easync \u003cins\u003eping\u003c/ins\u003e(\u003c/code\u003e\u003csub\u003e\u003cbr/\u003e\u0026nbsp;\u0026nbsp;`url: string,`\u003cbr/\u003e\u0026nbsp;\u0026nbsp;`timeout: number,`\u003cbr/\u003e\u003c/sub\u003e\u003ccode\u003e): \u003ci\u003evoid\u003c/i\u003e\u003c/code\u003e\nCheck that a connection to the _ElasticSearch_ server can be established. Will throw an error after timeout.\n\n - \u003ckbd\u003e\u003cstrong\u003eurl*\u003c/strong\u003e\u003c/kbd\u003e \u003cem\u003e`string`\u003c/em\u003e: The ElasticSearch URL.\n - \u003ckbd\u003e\u003cstrong\u003etimeout*\u003c/strong\u003e\u003c/kbd\u003e \u003cem\u003e`number`\u003c/em\u003e: The timeout for the request in ms.\n\n\u003cp align=\"center\"\u003e\u003ca href=\"#table-of-contents\"\u003e\n  \u003cimg src=\"/.documentary/section-breaks/3.svg?sanitize=true\"\u003e\n\u003c/a\u003e\u003c/p\u003e\n\n## CLI\n\n_Logarithm_ also provides a CLI tool to be able to install index patterns and a pipeline for the use by the middleware API.\n\n```js\nlogarithm -h\n```\n\n```Dockerfile\nElasticSearch utility for creating a pipeline and index templates\nfor logging request using logarithm middleware.\n\n  logarithm \u003curl\u003e [-TPS] [-p pipeline] [-d]\n\n\turl            \tThe ElasticSearch URL.\n\t               \tIf protocol is not given, `http` is assumed.\n\t--stats, -s    \tDisplay statistics by indices.\n\t--templates, -T\tList all index templates.\n\t--delete, -d   \tDelete an index, snapshot or pipeline.\n\t               \tUsed with the relevant flag.\n\t--index, -i    \tSelect an index for operations.\n\t--pipeline, -p \tCreate a pipeline with `User-Agent`\n\t               \tand `GeoIp` plugins.\n\t--pipelines, -P\tDisplay installed pipelines.\n\t--snapshots, -S\tList registered snapshot repositories.\n\t--help, -h     \tPrint the help information and exit.\n\t--version, -v  \tShow the version's number and exit.\n\nSnapshots: used to print info, create and restore snapshots.\n\n  logarithm \u003curl\u003e [-r repo] [-s snapshot] [-s3 snapshot --bucket bucket] [--status|-d]\n\n\t--repository-s3, -s3\tCreate a new `s3` snapshot repo with this name.\n\t--bucket            \tThe bucket name for the `s3` snapshot repository.\n\t--repo, -r          \tThe name of the repo.\n\t--snapshot, -s      \tThe name of the snapshot.\n\t--restore           \tRestore this snapshot.\n\t--status            \tFetch the status.\n\nTemplates: creates a template for an app.\n\n  logarithm \u003curl\u003e -t {app-name} [-s shards] [-r replicas] [-d]\n\n\t--template, -t\tCreate an index template for storing\n\t              \tlog data in the `{template}-*` index.\n\t--shards, -s  \tThe number of shards for index template.\n\t              \tDefault: 1.\n\t--replicas, -r\tThe number of replicas for index template.\n\nMethods: send data from JSON files.\n\n  logarithm \u003curl\u003e [--post data.json] -p path\n\n\t--post    \tSend POST request with data from the file.\n\t--path, -p\tThe path to send a request to.\n```\n\n\u003ckbd\u003e📙 [Read Wiki](../../wiki) For More Documentation\u003c/kbd\u003e\n\n\u003cp align=\"center\"\u003e\u003ca href=\"#table-of-contents\"\u003e\n  \u003cimg src=\"/.documentary/section-breaks/4.svg?sanitize=true\" width=\"15\"\u003e\n\u003c/a\u003e\u003c/p\u003e\n\n### List Templates, `-T`\n\nTo see what templates are installed.\n\n```sh\nlogarithm 192.168.0.1:9200 -T\n```\n\n```fs\nName                           Patterns          Shards  Replicas\nkibana_index_template:.kibana  .kibana           1\nhits-logarithm.page            logarithm.page-*  1       0\nhits-clients                   clients-*         1       0\nhits-client2                   client2-*         1       0\n```\n\n\u003cp align=\"center\"\u003e\u003ca href=\"#table-of-contents\"\u003e\n  \u003cimg src=\"/.documentary/section-breaks/5.svg?sanitize=true\" width=\"15\"\u003e\n\u003c/a\u003e\u003c/p\u003e\n\n### Statistics, `-s`\n\nThe stats can be used to monitor created indices.\n\n```sh\nlogarithm 192.168.0.1:9200 -s\n```\n\n```sh\nName                      Memory    Docs  Size\nlogarithm.page          11.6 KB   1     21.6 KB\nlogarithm.page-2018.12  60.4 KB   8859  3.3 MB\nlogarithm.page-2018.11  64.4 KB   116   179.5 KB\nlogarithm.page-2019.2   151.4 KB  63    279.1 KB\nlogarithm.page-2019.1   120.7 KB  5747  2.2 MB\n```\n\n\n\n## Copyright \u0026 License\n\nGNU Affero General Public License v3.0\n\n\u003ctable\u003e\n  \u003ctr\u003e\n    \u003cth\u003e\n      \u003ca href=\"https://www.artd.eco\"\u003e\n        \u003cimg width=\"100\" src=\"https://raw.githubusercontent.com/wrote/wrote/master/images/artdeco.png\"\n          alt=\"Art Deco\"\u003e\n      \u003c/a\u003e\n    \u003c/th\u003e\n    \u003cth\u003e© \u003ca href=\"https://www.artd.eco\"\u003eArt Deco™\u003c/a\u003e   2020\u003c/th\u003e\n  \u003c/tr\u003e\n\u003c/table\u003e\n\n\u003cp align=\"center\"\u003e\u003ca href=\"#table-of-contents\"\u003e\n  \u003cimg src=\"/.documentary/section-breaks/-1.svg?sanitize=true\"\u003e\n\u003c/a\u003e\u003c/p\u003e","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fartdecocode%2Flogarithm","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fartdecocode%2Flogarithm","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fartdecocode%2Flogarithm/lists"}