{"id":42423755,"url":"https://github.com/jordanblakey/ffjs","last_synced_at":"2026-01-28T03:05:44.789Z","repository":{"id":57234931,"uuid":"114961084","full_name":"jordanblakey/ffjs","owner":"jordanblakey","description":"Lightweight, modular utility functions for arrays, browser, dates, strings, math, and more.","archived":false,"fork":false,"pushed_at":"2017-12-21T11:46:38.000Z","size":104,"stargazers_count":1,"open_issues_count":0,"forks_count":0,"subscribers_count":2,"default_branch":"master","last_synced_at":"2025-09-07T16:56:05.627Z","etag":null,"topics":["functional-programming","javascript","library","lodash","utility-library"],"latest_commit_sha":null,"homepage":"https://www.npmjs.com/package/ffjs","language":"JavaScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"cc0-1.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/jordanblakey.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}},"created_at":"2017-12-21T04:04:58.000Z","updated_at":"2023-12-05T07:30:06.000Z","dependencies_parsed_at":"2022-08-23T15:50:13.399Z","dependency_job_id":null,"html_url":"https://github.com/jordanblakey/ffjs","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/jordanblakey/ffjs","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/jordanblakey%2Fffjs","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/jordanblakey%2Fffjs/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/jordanblakey%2Fffjs/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/jordanblakey%2Fffjs/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/jordanblakey","download_url":"https://codeload.github.com/jordanblakey/ffjs/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/jordanblakey%2Fffjs/sbom","scorecard":{"id":532625,"data":{"date":"2025-08-11","repo":{"name":"github.com/jordanblakey/ffjs","commit":"03d73b55e63f423825c8714c28376272ba03cff2"},"scorecard":{"version":"v5.2.1-40-gf6ed084d","commit":"f6ed084d17c9236477efd66e5b258b9d4cc7b389"},"score":1.7,"checks":[{"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":"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":"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":"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":"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":"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":"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":"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":"License","score":10,"reason":"license file detected","details":["Info: project has a license file: LICENSE:0","Info: FSF or OSI recognized license: Creative Commons Zero v1.0 Universal: 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":"Vulnerabilities","score":0,"reason":"40 existing vulnerabilities detected","details":["Warn: Project is vulnerable to: GHSA-v88g-cgmw-v5xw","Warn: Project is vulnerable to: GHSA-67hx-6x53-jw92","Warn: Project is vulnerable to: GHSA-v6h2-p8h4-qcjw","Warn: Project is vulnerable to: GHSA-cwfw-4gq5-mrqx","Warn: Project is vulnerable to: GHSA-g95f-p29q-9xw4","Warn: Project is vulnerable to: GHSA-grv7-fg5c-xmjg","Warn: Project is vulnerable to: GHSA-hr2v-3952-633q","Warn: Project is vulnerable to: GHSA-qrmc-fj45-qfc2","Warn: Project is vulnerable to: GHSA-fjxv-7rqg-78g4","Warn: Project is vulnerable to: GHSA-8r6j-v8pm-fqw3","Warn: Project is vulnerable to: MAL-2023-462","Warn: Project is vulnerable to: GHSA-xf7w-r453-m56c","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-qqgx-2p2h-9c37","Warn: Project is vulnerable to: GHSA-896r-f27r-55mw","Warn: Project is vulnerable to: GHSA-9c47-m6qq-7p4h","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-jf85-cpcp-j695","Warn: Project is vulnerable to: GHSA-p6mc-m468-83gw","Warn: Project is vulnerable to: GHSA-29mw-wpgm-hmr9","Warn: Project is vulnerable to: GHSA-35jh-r3h4-6jhm","Warn: Project is vulnerable to: GHSA-952p-6rrq-rcjv","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-hrpp-h998-j3pp","Warn: Project is vulnerable to: GHSA-6g33-f262-xjp4","Warn: Project is vulnerable to: GHSA-p8p7-x288-28g6","Warn: Project is vulnerable to: GHSA-c2qf-rxjj-qqgw","Warn: Project is vulnerable to: GHSA-2m39-62fm-q8r3","Warn: Project is vulnerable to: GHSA-mf6x-7mm4-x2g7","Warn: Project is vulnerable to: GHSA-j44m-qm6p-hp7m","Warn: Project is vulnerable to: GHSA-3jfq-g458-7qm9","Warn: Project is vulnerable to: GHSA-5955-9wpr-37jh","Warn: Project is vulnerable to: GHSA-f5x3-32g6-xq36","Warn: Project is vulnerable to: GHSA-72xf-g2v4-qvf3"],"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-20T06:05:39.957Z","repository_id":57234931,"created_at":"2025-08-20T06:05:39.957Z","updated_at":"2025-08-20T06:05:39.957Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":28835927,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-01-28T02:10:51.810Z","status":"ssl_error","status_checked_at":"2026-01-28T02:10:50.806Z","response_time":57,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.6: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":["functional-programming","javascript","library","lodash","utility-library"],"created_at":"2026-01-28T03:05:44.728Z","updated_at":"2026-01-28T03:05:44.776Z","avatar_url":"https://github.com/jordanblakey.png","language":"JavaScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"# ffjs\n\nLightweight, modular utility functions for arrays, browser, dates, strings, math, and more.\n\nAdapted from [30 Seconds of Code](https://chalarangelo.github.io/30-seconds-of-code/), the most excellent JS exercises from Chalarangelo and co.\n\n[![npm version](https://badge.fury.io/js/ffjs.svg)](https://badge.fury.io/js/ffjs)\n\n## Installation\n\n```sh\nnpm install ffjs\n# OR\nyarn add ffjs\n```\n\n## Usage\n\nEverything:\n\n``` js\nimport ff from 'ffjs'\n// OR\nconst ff = require('ffjs').default\n```\n\nSingle Module:\n\n``` js\nimport { array } from 'ffjs'\n// OR\nconst array = require('ffjs').array\n```\n\n## Examples by Function Category\n\nUse these to test any function.\n\n```js\n// TEST ARRAY FUNCTIONS ////////////////////////////////////////////////////////\nlog('arrayGcd:', array.arrayGcd([4, 8, 12]))\nlog('arrayMax:', array.arrayMax([10, 1, 5]))\nlog('arrayMin:', array.arrayMin([10, 1, 5]))\nlog('chunk:', array.chunk([1, 2, 3, 4, 5], 2))\nlog('compact:', array.compact([0, 1, false, 2, '', 3, 'a', 'e' * 23, NaN, 's', 34]))\nlog('countOccurences:', array.countOccurences([1, 1, 2, 1, 2, 3], 1))\nlog('flatten:', array.flatten([1, [2], [3, [4]]]))\nlog('flattenDepth:', array.flattenDepth([1, [2], [[[3], 4], 5]], 2))\nlog('deepFlatten', array.deepFlatten([1, [2], [[3], 4], 5]))\nlog('difference:', array.difference([1, 2, 3], [1, 2, 4]))\nlog('differenceWith:', array.differenceWith([1, 1.2, 1.5, 3], [1.9, 3], (a, b) =\u003e Math.round(a) === Math.round(b)))\nlog('distictValuesOfArray:', array.distinceValuesOfArray([1, 2, 2, 3, 4, 4, 5]))\nlog('dropElements:', array.dropElements([1, 2, 3, 4], n =\u003e n \u003e= 3))\nlog('dropRight:', array.dropRight([1, 2, 3, 4, 5, 6, 7, 8, 9, 10], 4))\nlog('everyNth:', array.everyNth([1, 2, 3, 4, 5, 6], 2))\nlog('filterNonUnique', array.filterNonUnique([1, 2, 2, 3, 4, 4, 5]))\nlog('groupBy:', array.groupBy([6.1, 4.2, 6.3], Math.floor))\nlog('head:', array.head([1, 2, 3]))\nlog('initial:', array.initial([1, 2, 3]))\nlog('initArrayRange:', array.initArrayRange(7, 3))\nlog('initArrayFill:', array.initArrayFill(5, 2))\nlog('init2DArray:', array.init2dArray(3, 3, 0))\nlog('intersection:', array.intersection([1, 2, 3], [4, 3, 2]))\nlog('last:', array.last([1, 2, 3]))\nlog('mapObject:', array.mapObject([1, 2, 3, 4], a =\u003e a * a))\nlog('pick:', array.pick({'a':1, 'b':'2', 'c': 3}, ['a', 'c']))\nlog('pull:', array.pull(['a', 'b', 'c'], 'a'))\nlog('sample:', array.sample([3, 7, 9, 11]))\nlog('shuffle:', array.shuffle([1, 2, 3]))\nlog('similarity:', array.similarity([1, 2, 3], [1, 2, 4]))\nlog('symmetricDifference:', array.symmetricDifference([1, 2, 3], [1, 2, 4]))\nlog('tail:', array.tail([1, 2, 3]))\nlog('take:', array.take([1, 2, 3, 4, 5], 3))\nlog('takeRight:', array.takeRight([1, 2, 3, 4, 5], 3))\nlog('union:', array.union([1, 2, 3], [4, 3, 2]))\nlog('without:', array.without([2, 1, 2, 3], 1, 2))\nlog('zip:', array.zip(['a'], [1, 2], [true, false]))\n\n\n// TEST BROWSER FUNCTIONS //////////////////////////////////////////////////////\n// THESE WON'T RUN UNLESS IN BROWSER\n// log('arrayToHtmlList:', browser.arrayToHtmlList(['item 1', 'item 2'],'myListID'))\n// log('bottomVisible:', browser.bottomVisible())\n// log('currentUrl:', browser.currentUrl())\n// log('elementIsVisibleInViewport:', browser.elementIsVisibleInViewport(el))\n// log('elementIsVisibleInViewport:', browser.elementIsVisibleInViewport(el, true))\n// log('getScrollPosition:', browser.getScrollPosition())\n// log('getURLParameters:', browser.getURLParameters('http://url.com/page?name=Adam\u0026surname=Smith'))\n// log('redirect:', browser.redirect('https://google.com'))\n// log('scrollToTop:', browser.scrollToTop())\n\n\n// TEST DATE FUNCTIONS /////////////////////////////////////////////////////////\nlog('getDaysDiffBetweenDates:', date.getDaysDiffBetweenDates(new Date(\"2017-12-13\"), new Date(\"2017-12-22\")))\nlog('JSONToDate:', date.JSONToDate(/Date(1489525200000)/))\nlog('toEnglishDate:', date.toEnglishDate('09/21/2010'))\n\n\n// TEST FUNCTION FUNCTIONS /////////////////////////////////////////////////////\nfunc.chainAsync([\n  next =\u003e { console.log('0 seconds'); setTimeout(next, 1000); },\n  next =\u003e { console.log('1 second'); setTimeout(next, 1000); },\n  next =\u003e { console.log('2 seconds'); }\n])\n\nconst add5 = x =\u003e x + 5\nconst multiply = (x, y) =\u003e x * y\nconst multiplyAndAdd5 = func.compose(add5, multiply)\nlog(multiplyAndAdd5(5, 2))\n\nfunc.curry(Math.pow)(2)(10)\nfunc.curry(Math.min, 3)(10)(50)(2)\n\nconst add6 = x =\u003e x + 6\nconst multiply2 = (x, y) =\u003e x * y\nconst multiplyAndAdd6 = func.pipeFunctions(multiply2, add6)\nlog(multiplyAndAdd6(5, 2))\n\nconst delay = func.promisify((d, cb) =\u003e setTimeout(cb, d))\ndelay(2000).then(() =\u003e console.log('Hi!'))\n\nconst delay2 = (d) =\u003e new Promise(r =\u003e setTimeout(r, d))\nfunc.runPromisesInSeries([() =\u003e delay2(1000), () =\u003e delay2(2000)])\n\n\n// TEST MATH FUNCTIONS /////////////////////////////////////////////////////////\nlog('arrayAverage:', math.arrayAverage([1, 2, 3]))\nlog('arraySum:', math.arraySum([1, 2, 3, 4]))\nlog('collatz:', math.collatz(8))\nlog('digitize:', math.digitize(2334))\nlog('distance:', math.distance(1, 1, 2, 3))\nlog('factorial:', math.factorial(6))\nlog('fibonacci:', math.fibonacci(5))\nlog('gcd:', math.gcd(8, 36))\nlog('hammingDisance:', math.hammingDistance(2, 3))\nlog('isArmstrongNumber:', math.isArmstrongNumber(1634))\nlog('isArmstrongNumber:', math.isArmstrongNumber(371))\nlog('isArmstrongNumber:', math.isArmstrongNumber(56))\nlog('isDivisible:', math.isDivisible(6, 3))\nlog('isEven:', math.isEven(3))\nlog('isPrime:', math.isPrime(11))\nlog('isPrime:', math.isPrime(12))\nlog('isPrime:', math.isPrime(11))\nlog('lcm:', math.lcm(12, 7))\nlog('median:', math.median(5, 6, 50, 1, -5))\nlog('palindrome:', math.palindrome('taco cat'))\nlog('percentile:', math.percentile([1, 2, 3, 4, 5, 6, 7, 8, 9, 10], 6))\nlog('powerset:', math.powerset([1, 2]))\nlog('randomIntegerInRange:', math.randomIntegerInRange(0, 5))\nlog('randomNumberInRange:', math.randomNumberInRange(2, 10))\nlog('round:', math.round(1.005, 2))\nlog('standardDeviation:', math.standardDeviation([10, 2, 38, 23, 38, 23, 21]))\nlog('standardDeviation:', math.standardDeviation([10, 2, 38, 23, 38, 23, 21], true))\n\n\n// TEST STRING FUNCTIONS ///////////////////////////////////////////////////////\nlog('anangrams:', string.anagrams('abc'))\nlog('capitalize:', string.capitalize('john'))\nlog('capitalizeEveryWord:', string.capitalizeEveryWord('hello world'))\nlog('countVowels:', string.countVowels('foobar'))\nlog('countVowels:', string.countVowels('gym'))\nlog('escapeRegExp:', string.escapeRegExp('(test)'))\nlog('fromCamelCase:', string.fromCamelCase('someDatabaseFieldName', ' '))\nlog('fromCamelCase (snake):', string.fromCamelCase('someDatabaseFieldName', '_'))\nlog('fromCamelCase (kebab):', string.fromCamelCase('someDatabaseFieldName', '-'))\nlog('reverseString:', string.reverseString('foobar'))\nlog('sortCharactersInString:', string.sortCharactersInString('cabbage'))\nlog('stringToArrayOfWords:', string.stringToArrayOfWords('I love javaScript!!'))\nlog('stringToArrayOfWords:', string.stringToArrayOfWords('python, javaScript \u0026 coffee'))\nlog('toCamelCase:', string.toCamelCase('some_database_field_name'))\nlog('toCamelCase:', string.toCamelCase('Some label that needs to be camelized'))\nlog('toCamelCase:', string.toCamelCase('some-javascript-property'))\nlog('toCamelCase:', string.toCamelCase('some-mixed_string with spaces_underscores-and-hyphens'))\nlog('truncateString:', string.truncateString('boomerang', 7))\n\n\n// TEST UTILITY FUNCTIONS //////////////////////////////////////////////////////\nlog('coalesce:', util.coalesce(null, undefined, NaN, 'Waldo'))\nconst customCoalesce = util.coalesceFactory(x =\u003e ![null, undefined, '', NaN].includes(x))\nlog('coalesceFactory:', customCoalesce(null, undefined, '', NaN, 'Waldo'))\nlog('extendHex:', util.extendHex('#03f'))\nlog('getType:', util.getType(3))\nlog('getType:', util.getType(new Set([1, 2, 3])))\nlog('hexToRGB:', util.hexToRGB('#27ae60ff'))\nlog('hexToRGB:', util.hexToRGB('27ae60'))\nlog('hexToRGB:', util.hexToRGB('#fff'))\nlog('isArray:', util.isArray([1]))\nlog('isArray:', util.isArray(1))\nlog('isBoolean:', util.isBoolean(null))\nlog('isBoolean:', util.isBoolean(true))\nlog('isFunction:', util.isFunction('x'))\nlog('isFunction:', util.isFunction(x =\u003e x))\nlog('isNumber:', util.isNumber('1'))\nlog('isNumber:', util.isNumber(1))\nlog('isString:', util.isString(10))\nlog('isString:', util.isString('10'))\nlog('isSymbol:', util.isSymbol('x'))\nlog('isSymbol:', util.isSymbol(Symbol('x')))\nlog('toOrdinalSuffix:', util.toOrdinalSuffix(123))\nlog('validateEmail:', util.validateEmail('example@example.com'))\nlog('validateEmail:', util.validateEmail('example'))\nlog('validateNumber:', util.validateNumber('129387.987987'))\nlog('validateNumber:', util.validateNumber(129387.987987))\n```\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fjordanblakey%2Fffjs","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fjordanblakey%2Fffjs","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fjordanblakey%2Fffjs/lists"}