{"id":31936455,"url":"https://github.com/stitchng/kwikng","last_synced_at":"2025-10-14T07:42:51.641Z","repository":{"id":40921572,"uuid":"214988903","full_name":"stitchng/kwikng","owner":"stitchng","description":"A NodeJS Wrapper for KwikDelivery APIs - https://app.kwik.delivery","archived":false,"fork":false,"pushed_at":"2023-03-03T16:03:47.000Z","size":261,"stargazers_count":4,"open_issues_count":5,"forks_count":3,"subscribers_count":1,"default_branch":"master","last_synced_at":"2025-10-06T15:49:52.056Z","etag":null,"topics":["api-endpoints","automated-deliveries","kwik","lastmile-delivery","logistics","nodejs","pickups","price-estimation","rest-api"],"latest_commit_sha":null,"homepage":null,"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/stitchng.png","metadata":{"files":{"readme":"README.md","changelog":"CHANGELOG.md","contributing":"CONTRIBUTING.md","funding":".github/FUNDING.yml","license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null},"funding":{"github":null,"patreon":"coolcodes","open_collective":null,"ko_fi":null,"tidelift":null,"community_bridge":null,"liberapay":null,"issuehunt":null,"otechie":null,"custom":null}},"created_at":"2019-10-14T08:28:28.000Z","updated_at":"2023-09-08T17:59:03.000Z","dependencies_parsed_at":"2023-01-23T05:35:25.875Z","dependency_job_id":null,"html_url":"https://github.com/stitchng/kwikng","commit_stats":null,"previous_names":[],"tags_count":1,"template":false,"template_full_name":null,"purl":"pkg:github/stitchng/kwikng","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/stitchng%2Fkwikng","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/stitchng%2Fkwikng/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/stitchng%2Fkwikng/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/stitchng%2Fkwikng/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/stitchng","download_url":"https://codeload.github.com/stitchng/kwikng/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/stitchng%2Fkwikng/sbom","scorecard":{"id":853485,"data":{"date":"2025-08-11","repo":{"name":"github.com/stitchng/kwikng","commit":"4a37e3d6f684bf1bf20bfb5a1632de7e7945bbbf"},"scorecard":{"version":"v5.2.1-40-gf6ed084d","commit":"f6ed084d17c9236477efd66e5b258b9d4cc7b389"},"score":1.7,"checks":[{"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":"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":"Code-Review","score":0,"reason":"Found 1/19 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":"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":"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":"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":"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":"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":"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":"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":"SAST","score":0,"reason":"SAST tool is not run on all commits -- score normalized to 0","details":["Warn: 0 commits out of 12 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":0,"reason":"14 existing vulnerabilities detected","details":["Warn: Project is vulnerable to: GHSA-v88g-cgmw-v5xw","Warn: Project is vulnerable to: GHSA-93q8-gq69-wqmw","Warn: Project is vulnerable to: GHSA-v6h2-p8h4-qcjw","Warn: Project is vulnerable to: GHSA-3xgq-45jj-v275","Warn: Project is vulnerable to: GHSA-w573-4hg7-7wgq","Warn: Project is vulnerable to: GHSA-4q6p-r6v2-jvc5","Warn: Project is vulnerable to: GHSA-pfrx-2q88-qq97","Warn: Project is vulnerable to: GHSA-rc47-6667-2j5j","Warn: Project is vulnerable to: GHSA-f8q6-p94x-37v3","Warn: Project is vulnerable to: GHSA-vh95-rmgr-6w4m","Warn: Project is vulnerable to: GHSA-xvch-5gv4-984h","Warn: Project is vulnerable to: GHSA-c2qf-rxjj-qqgw","Warn: Project is vulnerable to: GHSA-52f5-9888-hmc6","Warn: Project is vulnerable to: GHSA-j8xg-fqg3-53r7"],"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-23T23:10:42.280Z","repository_id":40921572,"created_at":"2025-08-23T23:10:42.280Z","updated_at":"2025-08-23T23:10:42.280Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":279018217,"owners_count":26086308,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","status":"online","status_checked_at":"2025-10-14T02:00:06.444Z","response_time":60,"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":["api-endpoints","automated-deliveries","kwik","lastmile-delivery","logistics","nodejs","pickups","price-estimation","rest-api"],"created_at":"2025-10-14T07:42:48.821Z","updated_at":"2025-10-14T07:42:51.635Z","avatar_url":"https://github.com/stitchng.png","language":"JavaScript","funding_links":["https://patreon.com/coolcodes","https://www.patreon.com/coolcodes/"],"categories":[],"sub_categories":[],"readme":"# kwikng \n\n[![NPM Version][npm-image]][npm-url]\n[![Build Status][travis-image]][travis-url]\n\nA NodeJS Wrapper for [Kwik Delivery](https://kwik.delivery)\n\n## Overview\nThis project provides an easy-to-use object-oriented API to access endpoints delineated at https://apikwik.docs.apiary.io/#reference OR https://liveapikwik.docs.apiary.io/#reference\n\n## Getting Started\n\n\u003eInstall from the NPM Registry\n\n```bash\n\n    $ npm i --save kwik-node\n\n```\n\n## API Values Format Codes ( Chart )\n\nAPI REQUEST STATUSES:\n====================\n\n| Title               | Code | Description                |\n|---------------------|------|----------------------------|\n|PARAMETER_MISSING    | 100  |  A parameter is missing    |\n|INVALID_KEY          | 101  |  Invalid access token      |\n|ACTION_COMPLETE      | 200  |  Successful request        |\n|ERROR_IN_EXECUTION   | 404  |  An Error Occured          |\n\n\n\nTASK/JOB STATUSES:\n=================\n\n| Title     | Code | Description\n|-----------|------|--------------------------------------------------------------------|\n|UPCOMING   |  0   |  The task has been assigned to a agent                             |\n|STARTED    |  1   |  The task has been started and the agent is on the way             |\n|ENDED\t    |  2   |  The task has been completed successfully                          |\n|FAILED\t    |  3   |  The task has not been completed successfully                      |\n|ARRIVED    |  4   |  The task is being performed;agent has reached the destination     |\n|UNASSIGNED |  6   |  The task has not been assigned to any agent                       |\n|ACCEPTED   |  7   |  The task has been accepted by the agent which is assigned to him  |\n|DECLINE    |  8   |  The task has been declined by the agent which is assigned to him  |\n|CANCEL\t    |  9   |  The task has been cancelled by the agent which is accepted by him |\n|DELETED    |  10  |  The task is deleted by the agent                                  |\n\n\n\nPAYMENT METHODS:\n===============\n\n| Title        | Code   | Description                                                |\n|--------------|--------|------------------------------------------------------------|\n|CARD          | 32     |  The task will be paid for using paystack card option       |\n|CASH          | 8      |  The task will be paid for using cash in currency of local |\n|STRIPE        | 2      |  The task will be paid for using stripe card option        |\n|WALLET (PAGA) | 131072 |  The task will be paid for using a paga wallet option      |\n\n\n\nVEHICLE SIZES:\n=============\n\n| Code | Description          |\n|------|----------------------|\n|  0   |  A motorcycle (bike) |\n|  1   |  A small car         |\n|  2   |  A medium car        |\n|  3   |  A large truck       |\n\n\n\nDELIVERY CHARGES:\n================\n\n| Code | Description                                                |\n|------|------------------------------------------------------------|\n|  1   |  Paid by the buyer (your own customer whom you deliver to) |\n|  2   |  Paid by the kwik customer (you whom are using this API)   |\n\n\n\nTIMEZONES:\n=========\n\n| Title                     | Code | Description                  |\n|---------------------------|------|------------------------------|\n|INDIAN STANDARD TIME (IST) | -330 |  offset from UTC in minutes  |\n|CENTRAL AFRICAN TIME (CAT) | +180 |  offset from UTC in minutes  |\n|WEST AFRICAN TIME (WAT)    | +60  |  offset from UTC in minutes  |\n\n\n# Usage\n\n```js\n\nconst Kwik = require('kwik-node')\nconst express = require('express')\n\n\nconst domainName = process.env.KWIK_DOMAIN_NAME; // 'app-test.kwik.delivery'\nconst environment = process.env.NODE_ENV; // 'production'\n\nconst kwikClient = new Kwik(\n    domainName, \n    environment === 'production'\n);\n\nconst app = express()\nconst port = 3000\n\n/* setup a middleware to load up the API access_token via auth */\napp.use('/create/delivery', async (req, res, next) =\u003e {\n  if(req.method.toLowercase() === 'post'){\n    let response = {\n        body: {\n            status:0,\n            data: {\n                access_token: '',\n                vendor_details: {\n                    vendor_id: '',\n                    card_id: '',\n                    user_id: ''\n                }\n            }\n        }\n    }\n\n    try {\n        response = await kwikClient.adminLogin({ \n            email: process.env.KWIK_ACCOUNT_EMAIL,\n            password: process.env.KWIK_ACCOUNT_PASSWORD\n        });\n    } catch(error) {\n        throw error;\n    }\n\n\n    kwikClient.setAccessToken(\n        response.body.data.access_token\n    );\n\n    kwikClient.setVendorId(\n        response.body.data.vendor_details.vendor_id\n    );\n\n    kwikClient.setUserId(\n        response.body.data.vendor_details.user_id\n    );\n\n    kwikClient.setCardId(\n        response.body.data.vendor_details.card_id\n    );\n  }\n\n  next();\n});\n\n\n\n/* global error handler */\napp.use(function (err, req, res, next) {\n  res.status(500).send(err.message)\n});\n\n\n/* standard app endpoint to create a delivery task for dispatch by kwik dispatch riders */\napp.post('/create/delivery', async (req, res) =\u003e {\n    const today = new Date()\n    const deliveries = [\n            {\n              address: req.body.delivery_address,\n              name: req.body.business_name,\n              latitude: req.body.choords.delivery_lat,\n              longitude: req.body.choords.delivery_long,\n              time: \"2022-06-03 12:48:24\",\n              phone: req.body.mobile_number,\n              email: req.body.email,\n              has_return_task: false,\n            }\n    ];\n    const pickups = [\n            {\n              address: req.body.pickup_address,\n              name: \"My Business name\",\n              latitude: req.body.choords.pickup_lat,\n              longitude\": req.body.choords.pickup_long,\n              time: \"2022-06-03 11:02:30\",\n              phone: \"+2347045804049\",\n              email: \"my.business@gmail.com\"\n            }\n    ];\n\n    /* NOTE: \n        no need to include 'domain_name', 'access_token' and 'vendor_id'\n        as they are included automatically as long as the express middleware\n        above obtains the details correctly in the middleware above using\n        kwikClient.adminLogin() and sets all the details accordingly\n    */\n\n    /* HINT:\n       It's vital to get Loaders and Vehicles info for your delivery task before\n       that delivery task can be scheduled/created\n    */\n\n    /* Loaders info */\n    const loaderDetails = await kwikClient.fetchAllLoadersOnAmount()\n\n    /* Vehicles info */\n    const vehicleDetails = await kwikClient.fetchAllAvailableDeliveryVehicles({\n        size: 1 /* a small car (see API values format codes above 👆🏾) */\n    });\n\n    const deliveryTaskDetails = await kwikClient.getExactPricingForDeliveryTask({\n        custom_field_template: 'pricing-template',\n        auto_assignment: 1,\n        layout_type: 1,\n        pickup_custom_field_template: 'pricing-template',\n        has_pickup: 1,\n        has_delivery: 1,\n        vehicle_id: vehicleDetails.body.data[0].vehicle_id,\n        parcel_amount: 0,\n        is_cod_job: 0, /* No collect on delivery */\n        delivery_images: 'https://res.cloudinary.com/kwiky/image/upload/v1648282178/mova/item.png', /* The URL of the image of the item being delivered */\n        delivery_instruction: 'Please, hand it over to the nanny', /* The instruction for the person who's to recieve the item being delivered */\n        is_loader_required: loaderDetails.body.data.is_loader_enabled, /* equals 0; no loaders enabled */\n        is_multiple_tasks: 1,\n        payment_method: 32, /* payment via card */\n        is_schedule_task: 0, /* task will not be scheduled in future */\n        deliveries,\n        pickups\n    });\n\n    console.log(\n        'CURRENCY: ', \n        JSON.stringify(deliveryTaskDetails.body.data.currency, null, '\\t')\n    );\n\n    console.log(\n        'COST PER TASK (AMOUNT): ', \n        deliveryTaskDetails.body.data.per_task_cost\n    );\n\n    const cost_per_task = deliveryTaskDetails.body.data.per_task_cost\n\n    const deliveryPaymentBreakDownDetails = await kwikClient.getEstimatedPriceForDeliveryTask({\n        promo_value: 0,\n        amount: String(cost_per_task),\n        pickup_time: today.toISOString().replace('T', ' ').replace(/(?:\\.[\\d]{2,3}Z)/, ''),\n        total_service_charge: deliveryTaskDetails.body.data.total_service_charge,\n        vehicle_id: deliveryTaskDetails.body.data.vehicle_id,\n        delivery_images: deliveryTaskDetails.body.data.delivery_images,\n        delivery_instruction: deliveryTaskDetails.body.data.delivery_instruction,\n        delivery_charge_by_buyer: 1, /* buyer pays for delivery charge (see API values format codes above 👆🏾) */\n        is_cod_job: deliveryTaskDetails.body.data.is_cod_job,\n        parcel_amount: deliveryTaskDetails.body.data.parcel_amount,\n        is_loader_required: deliveryTaskDetails.body.data.is_loader_required,\n    });\n\n    const response = await kwikClient.scheduleDeliveryTask({\n        team_id: 2, /* get your `team_id` from your admin dashboard */\n        timezone: '+60', /* west african timezone (see API values format codes above 👆🏾) */\n        auto_assignment: 1,\n        layout_type: 1,\n        is_multiple_tasks: 1,\n        is_cod_job: deliveryTaskDetails.body.data.is_cod_job,\n        delivery_charge_by_buyer: deliveryPaymentBreakDownDetails.body.data.delivery_charge_by_buyer,\n        delivery_charge: deliveryPaymentBreakDownDetails.body.data.DELIVERY_CHARGE,\n        collect_on_delivery: deliveryPaymentBreakDownDetails.body.data.COLLECT_ON_DELIVERY,\n        surge_cost: deliveryPaymentBreakDownDetails.body.data.SURGE_PRICING,\n        surge_type: deliveryPaymentBreakDownDetails.body.data.SURGE_TYPE,\n        cash_handling_charges: deliveryPaymentBreakDownDetails.body.data.CASH_HANDLING_CHARGE,\n        cash_handling_percentage: deliveryPaymentBreakDownDetails.body.data.CASH_HANDLING_PERCENTAGE,\n        net_processed_amount: deliveryPaymentBreakDownDetails.body.data.NET_CASH_PROCEEDS,\n        kwister_cash_handling_charge: deliveryPaymentBreakDownDetails.body.data.KWISTER_CASH_HANDLING_CHARGE,\n        is_loader_required: deliveryTaskDetails.body.data.is_loader_required,\n        delivery_images: deliveryTaskDetails.body.data.delivery_images,\n        delivery_instruction: deliveryTaskDetails.body.data.delivery_instruction,\n        insurance_amount: deliveryTaskDetails.body.data.insurance_amount,\n        total_no_of_tasks: deliveryTaskDetails.body.data.total_no_of_tasks,\n        total_service_charge: deliveryTaskDetails.body.data.total_service_charge,\n        parcel_amount: deliveryTaskDetails.body.data.parcel_amount,\n        payment_method: 32, /* payment via card (see API values format codes above 👆🏾) */\n        amount: String(cost_per_task),\n        deliveries: deliveryTaskDetails.body.data.deliveries,\n        pickups: deliveryTaskDetails.body.data.pickups\n    });\n\n    res.status(response.body.status).send(response.body.message)\n});\n\napp.listen(port, () =\u003e {\n    console.log(`Example app listening at http://localhost:${port}`)\n});\n\n\n```\n\n## API Resources\n\n\u003eEach method expects an object literal with both **route parameters** and **request parameters (query / body)**. Please, go through the _src/Kwik/index.js_ `apiEndpoints` object to see the specific items that should make up the object literal for each method and their types\n\n- **Tasks**\n  - kwikClient.cancelDeliveryTask()\n  - kwikClient.scheduleDeliveryTask()\n- **Vehicles**\n  - kwikClient.fetchAllAvailableDeliveryVehicles()\n- **Loaders**\n  - kwikClient.fetchAllLoadersOnAmount()\n- **Pricing**\n  - kwikClient.getExactPricingForDeliveryTask()\n  - kwikClient.getEstimatedPriceForDeliveryTask()\n- **Payments**\n  - kwikClient.fetchAllMerchantCards()\n  - kwikClient.addMerchantCard()\n  - kwikClient.deleteMerchantCard()\n- **Corporates**\n  - kwikClient.createCorporate()\n  - kwikClient.listAllCorporates()\n  - kwikClient.listAllCorporatesInvoices()\n  - kwikClient.listAllCustomersPerCorporates()\n  - kwikClient.listAllCorporatesInvoicesSub()\n- **Task Details ( Jobs )**\n  - kwikClient.getSingleDeliveryTaskDetails()\n  - kwikClient.getAllDeliveryTaskDetails()\n  - kwikClient.getDeliveryTaskStatus()\n\n# License\n\nMIT\n\n# Credits\n\n- [Ifeora Okechukwu](https://twitter.com/isocroft)\n\n# Contributing\n\nSee the [CONTRIBUTING.md](https://github.com/stitchng/kwikng/blob/master/CONTRIBUTING.md) file for info\n\n[npm-image]: https://img.shields.io/npm/v/kwik-node.svg?style=flat-square\n[npm-url]: https://npmjs.org/package/kwik-node\n\n[travis-image]: https://img.shields.io/travis/stitchng/kwikng/master.svg?style=flat-square\n[travis-url]: https://travis-ci.org/stitchng/kwikng\n\n## Support \n\n**Coolcodes** is a non-profit software foundation (collective) created by **Oparand** - parent company of StitchNG, Synergixe based in Abuja, Nigeria. You'll find an overview of all our work and supported open source projects on our [Facebook Page](https://www.facebook.com/coolcodes/).\n\n\u003eFollow us on facebook if you can to get the latest open source software/freeware news and infomation.\n\nDoes your business depend on our open projects? Reach out and support us on [Patreon](https://www.patreon.com/coolcodes/). All pledges will be dedicated to allocating workforce on maintenance and new awesome stuff.\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fstitchng%2Fkwikng","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fstitchng%2Fkwikng","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fstitchng%2Fkwikng/lists"}