{"id":19754984,"url":"https://github.com/feup-infolab/node-b2drop","last_synced_at":"2026-05-14T00:36:13.728Z","repository":{"id":72478311,"uuid":"106020213","full_name":"feup-infolab/node-b2drop","owner":"feup-infolab","description":"NodeJS client for the EUDAT B2Drop service, based on OwnCloud API","archived":false,"fork":false,"pushed_at":"2018-03-13T14:16:51.000Z","size":753,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":3,"default_branch":"master","last_synced_at":"2025-11-27T10:14:33.757Z","etag":null,"topics":["b2drop","client","eudat","nodejs","owncloud"],"latest_commit_sha":null,"homepage":"http://dendro.fe.up.pt","language":"JavaScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"bsd-3-clause","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/feup-infolab.png","metadata":{"files":{"readme":"README.md","changelog":null,"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}},"created_at":"2017-10-06T15:25:53.000Z","updated_at":"2017-11-01T13:54:55.000Z","dependencies_parsed_at":null,"dependency_job_id":"3f7faef8-24e4-4aef-9415-9035504535ef","html_url":"https://github.com/feup-infolab/node-b2drop","commit_stats":{"total_commits":58,"total_committers":4,"mean_commits":14.5,"dds":0.3793103448275862,"last_synced_commit":"0e32a58d8dc9a45d2557c3184eed25ac17e6509f"},"previous_names":[],"tags_count":3,"template":false,"template_full_name":null,"purl":"pkg:github/feup-infolab/node-b2drop","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/feup-infolab%2Fnode-b2drop","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/feup-infolab%2Fnode-b2drop/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/feup-infolab%2Fnode-b2drop/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/feup-infolab%2Fnode-b2drop/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/feup-infolab","download_url":"https://codeload.github.com/feup-infolab/node-b2drop/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/feup-infolab%2Fnode-b2drop/sbom","scorecard":{"id":397885,"data":{"date":"2025-08-11","repo":{"name":"github.com/feup-infolab/node-b2drop","commit":"0e32a58d8dc9a45d2557c3184eed25ac17e6509f"},"scorecard":{"version":"v5.2.1-40-gf6ed084d","commit":"f6ed084d17c9236477efd66e5b258b9d4cc7b389"},"score":1.7,"checks":[{"name":"Code-Review","score":0,"reason":"Found 0/21 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":"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":"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":"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":"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":"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":"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":"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: BSD 3-Clause \"New\" or \"Revised\" 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":"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":"SAST","score":0,"reason":"SAST tool is not run on all commits -- score normalized to 0","details":["Warn: 0 commits out of 11 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":"84 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-fwr7-v2mv-hh25","Warn: Project is vulnerable to: GHSA-v6h2-p8h4-qcjw","Warn: Project is vulnerable to: GHSA-h452-7996-h45h","Warn: Project is vulnerable to: GHSA-3xgq-45jj-v275","Warn: Project is vulnerable to: GHSA-rq8g-5pc5-wrhr","Warn: Project is vulnerable to: GHSA-p28h-cc7q-c4fg","Warn: Project is vulnerable to: GHSA-9vvw-cc9w-f27h","Warn: Project is vulnerable to: GHSA-gxpj-cx7g-858c","Warn: Project is vulnerable to: GHSA-hr2v-3952-633q","Warn: Project is vulnerable to: GHSA-h6ch-v84p-w6p9","Warn: Project is vulnerable to: GHSA-4gmj-3p3h-gm8h","Warn: Project is vulnerable to: GHSA-qrmc-fj45-qfc2","Warn: Project is vulnerable to: GHSA-fjxv-7rqg-78g4","Warn: Project is vulnerable to: GHSA-4q6p-r6v2-jvc5","Warn: Project is vulnerable to: GHSA-qh2h-chj9-jffq","Warn: Project is vulnerable to: GHSA-q42p-pg8m-cqh6","Warn: Project is vulnerable to: GHSA-w457-6q6x-cgp9","Warn: Project is vulnerable to: GHSA-62gr-4qp9-h98f","Warn: Project is vulnerable to: GHSA-f52g-6jhx-586p","Warn: Project is vulnerable to: GHSA-2cf5-4w76-r9qv","Warn: Project is vulnerable to: GHSA-3cqr-58rm-57f8","Warn: Project is vulnerable to: GHSA-g9r4-xpmj-mj65","Warn: Project is vulnerable to: GHSA-q2c6-c6pm-g3gh","Warn: Project is vulnerable to: GHSA-765h-qjxv-5f44","Warn: Project is vulnerable to: GHSA-f2jv-r9rf-7988","Warn: Project is vulnerable to: GHSA-44pw-h2cw-w3vq","Warn: Project is vulnerable to: GHSA-jp4x-w63m-7wgm","Warn: Project is vulnerable to: GHSA-c429-5p7v-vgjp","Warn: Project is vulnerable to: GHSA-43f8-2h32-f4cj","Warn: Project is vulnerable to: GHSA-8g7p-74h8-hg48","Warn: Project is vulnerable to: GHSA-pc5p-h8pf-mvwp","Warn: Project is vulnerable to: GHSA-qqgx-2p2h-9c37","Warn: Project is vulnerable to: GHSA-4hpf-3wq7-5rpr","Warn: Project is vulnerable to: GHSA-f522-ffg8-j8r6","Warn: Project is vulnerable to: GHSA-2pr6-76vf-7546","Warn: Project is vulnerable to: GHSA-8j8c-7jfh-h6hx","Warn: Project is vulnerable to: GHSA-896r-f27r-55mw","Warn: Project is vulnerable to: GHSA-282f-qqgm-c34q","Warn: Project is vulnerable to: GHSA-jf85-cpcp-j695","Warn: Project is vulnerable to: GHSA-fvqr-27wr-82fm","Warn: Project is vulnerable to: GHSA-4xc9-xhrj-v574","Warn: Project is vulnerable to: GHSA-x5rq-j2xg-h7qm","Warn: Project is vulnerable to: GHSA-29mw-wpgm-hmr9","Warn: Project is vulnerable to: GHSA-35jh-r3h4-6jhm","Warn: Project is vulnerable to: GHSA-p6mc-m468-83gw","Warn: Project is vulnerable to: GHSA-2m96-9w4j-wgv7","Warn: Project is vulnerable to: GHSA-h726-x36v-rx45","Warn: Project is vulnerable to: GHSA-hxm2-r34f-qmc5","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-446m-mv8f-q348","Warn: Project is vulnerable to: GHSA-8hfj-j24r-96c4","Warn: Project is vulnerable to: GHSA-wc69-rhjr-hc9g","Warn: Project is vulnerable to: GHSA-w9mr-4mfr-499f","Warn: Project is vulnerable to: GHSA-r683-j2x4-v87g","Warn: Project is vulnerable to: GHSA-rp65-9cf3-cjxr","Warn: Project is vulnerable to: GHSA-hj48-42vr-x3v9","Warn: Project is vulnerable to: GHSA-g6ww-v8xp-vmwg","Warn: Project is vulnerable to: GHSA-hrpp-h998-j3pp","Warn: Project is vulnerable to: GHSA-hxcm-v35h-mg2x","Warn: Project is vulnerable to: GHSA-p8p7-x288-28g6","Warn: Project is vulnerable to: GHSA-c2qf-rxjj-qqgw","Warn: Project is vulnerable to: GHSA-4rq4-32rv-6wp6","Warn: Project is vulnerable to: GHSA-64g7-mvw6-v9qj","Warn: Project is vulnerable to: GHSA-2m39-62fm-q8r3","Warn: Project is vulnerable to: GHSA-mf6x-7mm4-x2g7","Warn: Project is vulnerable to: GHSA-8225-6cvr-8pqp","Warn: Project is vulnerable to: GHSA-52f5-9888-hmc6","Warn: Project is vulnerable to: GHSA-g7q5-pjjr-gqvp","Warn: Project is vulnerable to: GHSA-72xf-g2v4-qvf3","Warn: Project is vulnerable to: GHSA-xc7v-wxcw-j472","Warn: Project is vulnerable to: GHSA-cf4h-3jhx-xvhq","Warn: Project is vulnerable to: GHSA-pv4c-p2j5-38j4","Warn: Project is vulnerable to: GHSA-46c4-8wrp-j99v","Warn: Project is vulnerable to: GHSA-9m6j-fcg5-2442","Warn: Project is vulnerable to: GHSA-hh27-ffr2-f2jc","Warn: Project is vulnerable to: GHSA-rqff-837h-mm52","Warn: Project is vulnerable to: GHSA-8v38-pw62-9cw2","Warn: Project is vulnerable to: GHSA-hgjh-723h-mx2j","Warn: Project is vulnerable to: GHSA-jf5r-8hm2-f872","Warn: Project is vulnerable to: GHSA-776f-qx25-q3cc"],"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-18T19:26:46.507Z","repository_id":72478311,"created_at":"2025-08-18T19:26:46.508Z","updated_at":"2025-08-18T19:26:46.508Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":33004973,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-05-13T13:14:54.681Z","status":"ssl_error","status_checked_at":"2026-05-13T13:14:51.610Z","response_time":115,"last_error":"SSL_read: 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":["b2drop","client","eudat","nodejs","owncloud"],"created_at":"2024-11-12T03:07:27.934Z","updated_at":"2026-05-14T00:36:13.710Z","avatar_url":"https://github.com/feup-infolab.png","language":"JavaScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"[![Build Status](https://travis-ci.org/feup-infolab/node-b2drop.svg?branch=master)](https://travis-ci.org/feup-infolab/node-b2drop)\n[![Codacy Badge](https://api.codacy.com/project/badge/Grade/5193de70952343a8a66e9c26e004713f)](https://www.codacy.com/app/silvae86/node-b2drop?utm_source=github.com\u0026utm_medium=referral\u0026utm_content=feup-infolab/node-b2drop\u0026utm_campaign=badger)\n[![Codacy Badge](https://api.codacy.com/project/badge/Coverage/5193de70952343a8a66e9c26e004713f)](https://www.codacy.com/app/silvae86/node-b2drop?utm_source=github.com\u0026utm_medium=referral\u0026utm_content=feup-infolab/node-b2drop\u0026utm_campaign=Badge_Coverage)\n[![npm version](https://badge.fury.io/js/%40feup-infolab%2Fnode-b2drop.svg)](https://badge.fury.io/js/%40feup-infolab%2Fnode-b2drop)\n[![Chat on gitter](https://img.shields.io/gitter/room/badges/shields.svg)](https://gitter.im/feup-infolab/dendro)\n\n\nnode-b2drop\n====\nNodeJS client for B2Drop, based on OwnCloud\n\n# Table of Contents\n  * [Installation](#installation)\n  * [Module Details](#module-details)\n    * [B2Drop](#b2drop)\n    * [B2DropShare](#b2dropshare)\n  * [Examples](#examples)\n\n            \n## Installation \n\n    $ npm i @feup-infolab/node-b2drop\n    \n## Module Details \n ### Introduction\n    \n   The module is divides in two main classes  B2drop and B2ropShare, the main reason for that\n    is to give the maximum flexibility using this cloud storage service.\n \n #### B2Drop\n   \n   B2Drop is responsible for all operations related to user private \n   area. This operations can be divided in two groups: WebDav  and \n   the functions to extend the previous group capabilities using requests.\n   \n   The WebDav functions group send the user and password on every request via https.\n   \n   The extended features uses request and requesttoken to validate the request.\n   \n   ##### WebDav\n   ![workflow B2drop webdav](resources/flow1.png \"B2drop WebDav\")\n   \n   ##### Extended Features\n   ![workflow B2drop extra funcs](resources/flow3.png \"B2drop extra funcs\")\n   \n   ##### Methods\n - **`B2Drop(username, password)`** - Constructor\n - **`changeFolderSetting (folderUri, folderID, setting, callback)`** - Change folder setting (only change 1 setting for each call)\n - **`checkIfFolderExits (folderPath, callbakc) `** - Check if a folder exits in provided path\n - **`createFolder (folderUri, callback)`** - Create folder in folderUri (if the path does not exists it will try to create the folders to recreate the path)\n - **`delete(fileUri, callback)`** - Delete file at fileUri\n - **`deleteFolder (folderUri, callback)`** - Delete folder in folderUri\n - **`get(fileUri, outputStream, callback)`** - Get file from fileUri\n - **`getAuthToken (callback)`** - get Authentication Token form B2drop website \n - **`getDirectoryContents (folderPath, callback)`** - List folder content \n - **`getQuota (callback) `** - Get available and used space in the cloud\n - **`getShareLink (folderUri, password, callback)`** - Create and get share link and set folder to editable and folder password  \n - **`put(fileUri, inputStream, callback)`** - Upload file to fileUri\n - **`testConnection (callback) `**- Simple test to check if username and password are valid\n \n ### B2DropShare\n   \n   B2DropShare is responsible for all operations related to users shared area, only uses WebDav.\n   \n   \n   \n\n   #### WebDav\n \n  ![workflow B2dropShare WebDav](resources/flow4.jpg \"B2drop WebDav\")\n  \n     \n   ##### Extended Features\n   ![workflow B2dropShare extra funcs](resources/flow5.png \"B2drop request\")\n   \n   #### Methods\n - **`B2DropShare ( sharelink, password)`** - Constructor\n - **`createFolder(folderUri, callback)`** - Create folder in folderUri\n - **`checkIfFolderExits ( folderPath, callback)`**- Check if folder exists in provided path\n - **`delete(fileUri, callback)`** - Delete file at fileUri\n - **`deleteFolder(folderUri, callback)`** - Delete folder in folderUri\n - **`put(fileUri, inputStream, callback)`** - Upload file to fileUri\n - **`get(fileUri, outputStream, callback)`** - Get file from fileUri\n - **`getDirectoryContents(folderPath, callback)`** - List folder content\n    \n## Examples\n #### Create Share Link\n   ```js\n        const b2drop = require('node-b2drop').B2Drop;\n        \n        var account = new b2drop(b2dropAccount.username, b2dropAccount.password);\n            account.getShareLink(testPathFolder1, passwordFolder, function (err, response, shareLink)\n            {\n                console.log(shareLink);\n            };\n});\n   ```\n  #### Upload File \n   ```js\n         const b2drop = require('node-b2drop').B2Drop;\n        \n         var fileUri;\n         var inputStream = fs.createReadStream(testFile.location);\n\n         inputStream.on(\"open\", function ()\n            {\n                var account = new b2drop(b2dropAccount.username, b2dropAccount.password);\n                account.put(fileUri, inputStream, function (err)\n                {\n                  console.log(err);\n                });\n           }\n});\n  ```\n   \n## Test\n    \n    $ npm test\n\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Ffeup-infolab%2Fnode-b2drop","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Ffeup-infolab%2Fnode-b2drop","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Ffeup-infolab%2Fnode-b2drop/lists"}