Security News
Input Validation Vulnerabilities Dominate MITRE's 2024 CWE Top 25 List
MITRE's 2024 CWE Top 25 highlights critical software vulnerabilities like XSS, SQL Injection, and CSRF, reflecting shifts due to a refined ranking methodology.
@flargd/web
Advanced tools
This is the web client for [Flargd](https://github.com/pmbanugo/flargd). It can be used anywhere JavaScript runs (i.e browsers, Node.js, and any Edge runtime).
This is the web client for Flargd. It can be used anywhere JavaScript runs (i.e browsers, Node.js, and any Edge runtime).
Install the package
npm i @flargd/web
Then you initialise the client:
import { createClient } from "@flargd/web";
import { EDGE_FLAGS_HOST } from "./constants"; // EDGE_FLAGS_HOST is a constant value that could be resolved to an environment variable
const client = createClient({ host: EDGE_FLAGS_HOST });
The createClient()
function takes a context object which is used to configure the client. See the next section for more info.
After the client is created, you can retrieve a feature flag using the get()
method.
const flag = await client.get("feature-name");
The get()
function returns an object with a boolean property enable
. If it resolves to true, then you can enable the feature for the user.
If you want to retrieve more than one flag, you should use getMany()
or getAll()
function.
const flags = await client.getMany(["feature-1", "feature_2"]);
const allFlags = await client.getAll();
The getAll()
function allows you to evaluate all the flags associated to an app. getMany()
on the other hand allows you to retrieve a few flags.
See the examples repo for more code examples.
The configuration context has the following shape in TypeScript:
interface Context {
host?: string;
app?: string;
team?: string;
distinctId?: string;
}
If app
, host
, or team
are skipped, a default value will be used. For app
, it defaults to default, for host
it's https://api.flargd.dev, while team
defaults to public
.
The distinctId
is optional and has no default. It is used by flargd as part of the evaluation criteria for a flag. If it is present, you are guaranteed to make get the same result each time you call get()
, getMany()
, or getAll()
. If absent, the server generates a random identifier for each call to the get()
or getMany()
function. If you want a consistent result, it's advised to initialise with a value for distinctId
.
You can use a unique identifier for the user, for example, the user ID in your database or the session ID if you want to keep it consistent only for the session. You can also generate and cache a random identifier for the user using crypto.randomUUID()
FAQs
This is the web client for [Flargd](https://github.com/pmbanugo/flargd). It can be used anywhere JavaScript runs (i.e browsers, Node.js, and any Edge runtime).
The npm package @flargd/web receives a total of 1 weekly downloads. As such, @flargd/web popularity was classified as not popular.
We found that @flargd/web 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
MITRE's 2024 CWE Top 25 highlights critical software vulnerabilities like XSS, SQL Injection, and CSRF, reflecting shifts due to a refined ranking methodology.
Security News
In this segment of the Risky Business podcast, Feross Aboukhadijeh and Patrick Gray discuss the challenges of tracking malware discovered in open source softare.
Research
Security News
A threat actor's playbook for exploiting the npm ecosystem was exposed on the dark web, detailing how to build a blockchain-powered botnet.