
Security News
CISA Rebuffs Funding Concerns as CVE Foundation Draws Criticism
CISA denies CVE funding issues amid backlash over a new CVE foundation formed by board members, raising concerns about transparency and program governance.
A factory for making URL/FileSystem paths with templates and URL query strings.
A factory for making URL/FileSystem paths with templates and URL query strings.
var basePath = PathMaker('/my/path/or/url/');
var subPath = basePath.sub('sub/path');
basePath(); // returns: '/my/path/or/url/'
subPath(); // returns: '/my/path/or/url/sub/path'
See Examples below for extended usage including templates and URL query strings.
Name | Default Value | Description |
---|---|---|
delimiter | '/' | The path delimiter. |
tokenPrefix | ':' | The path token prefix. |
path | '' | The path represented by the PathMaker . |
encodeURIComponent
. No other
part of the path is automatically encoded.import PathMaker from 'pathmaker';
const site = PathMaker('http://www.site.test/');
const api = PathMaker('http://api.site.test/');
const base = PathMaker('http://www.site.test/app-name/');
/** URL makers for any URLs used by this application. */
const AppURL = {
/** Base application URL maker. */
base,
/** Site URL maker, to make URLs outside of base. */
site,
login: base.sub('/login/'),
product: base.sub('/products/:id/'),
products: base.sub('/products/'),
/** API URL makers. */
api: {
/** Base API URL maker. */
base: api,
account: api.sub('account'),
oauth: api.sub('oauth'),
user: api.sub('users/:id'),
users: api.sub('users'),
}
};
export default AppURL;
import AppURL from './AppURL';
console.log(
AppURL.site()
); // http://www.site.test/
console.log(
AppURL.base()
); // http://www.site.test/app-name/
console.log(
AppURL.product({ id: 999 });
); // http://www.site.test/app-name/products/999/
console.log(
AppURL.login({ query: {redirect: '/dashboard'} })
); // http://www.site.test/app-name/login/?redirect=%2Fdashboard
console.log( // Equivalent to above:
AppURL.base('login/', { query: {redirect: '/dashboard'} })
); // http://www.site.test/app-name/login/?redirect=%2Fdashboard
console.log(
AppURL.api.user({ id: 10 })
); // http://api.site.test/users/10
console.log( // Alternatively, pass an array as a path.
AppURL.api.users([10, 'organizations/search'], { query: {q: 'the query'} })
); // http://api.site.test/users/10/organizations/search?q=the%20query
This code is trivial, it works and it's been in use for a while before it was published as an NPM. However, we need tests to protect against regressions! I think jest is already setup here for us.
FAQs
A factory for making URL/FileSystem paths with templates and URL query strings.
The npm package pathmaker receives a total of 0 weekly downloads. As such, pathmaker popularity was classified as not popular.
We found that pathmaker demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
CISA denies CVE funding issues amid backlash over a new CVE foundation formed by board members, raising concerns about transparency and program governance.
Product
We’re excited to announce a powerful new capability in Socket: historical data and enhanced analytics.
Product
Module Reachability filters out unreachable CVEs so you can focus on vulnerabilities that actually matter to your application.