data:image/s3,"s3://crabby-images/2523c/2523ce4b8b64bade795ffc89574cfc29f35428d3" alt="Deno 2.2 Improves Dependency Management and Expands Node.js Compatibility"
Security News
Deno 2.2 Improves Dependency Management and Expands Node.js Compatibility
Deno 2.2 enhances Node.js compatibility, improves dependency management, adds OpenTelemetry support, and expands linting and task automation for developers.
@rockset/client
Advanced tools
Official Rockset Javascript/Typescript Client
Node 10+
Optionally use Typescript for type checking.
npm i @rockset/client
Note: you can also install using yarn
.
A complete reference of this library (powered by TypeDoc) can be found here.
Note: you can also import using CommonJS syntax.
import rockset from "@rockset/client";
const rocksetClient = rockset(process.env.ROCKSET_APIKEY);
// Run a Query Lambda by tag with default parameters (or no parameters)
rocksetClient.queryLambdas
.executeQueryLambdaByTag(
/* workspace */ "commons",
/* queryName */ "myQuery",
/* tag */ "dev"
)
.then(console.log)
.catch(console.error);
// Run a Query Lambda with default parameters (or no parameters)
rocksetClient.queryLambdas
.executeQueryLambda(
/* workspace */ "commons",
/* queryName */ "myQuery",
/* version */ "1ab853df3eab33b"
)
.then(console.log)
.catch(console.error);
// Run a Query Lambda with custom parameters
rocksetClient.queryLambdas
.executeQueryLambda("commons", "myQuery", "1ab853df3eab33b", {
parameters: [
{
name: "param",
type: "string",
value: "All work and no play makes Jack a dull boy",
},
],
})
.then(console.log)
.catch(console.error);
rocksetClient.queries
.query({
sql: {
query: "SELECT 'Hello, world!'",
},
})
.then(console.log);
rocksetClient.integrations
.createIntegration({
name: "my-first-integration",
description: "my-first-integration",
s3: {
aws_role: {
aws_role_arn: "...",
},
},
})
.then(console.log);
rocksetClient.collections
.createCollection("commons", {
name: "my-first-s3-collection",
description: "my first s3 collection",
sources: [
{
integration_name: "my-first-integration",
s3: {
bucket: "bucket-name",
},
},
],
})
.then(console.log);
rocksetClient.documents
.addDocuments("commons", "my-first-collection", {
data: [
{
name: "foo",
address: "bar",
},
],
})
.then(console.log);
rocksetClient.queryLambdas
.createQueryLambda("commons", {
name: "myQueryLambda",
sql: {
query: "SELECT :param as echo",
default_parameters: [
{
name: "param",
type: "string",
value: "Hello world!",
},
],
},
})
.then(console.log);
Unit tests are available in the tests folder.
Set ROCKSET_APIKEY and ROCKSET_HOST endpoint in the environment variables. To run tests:
yarn test
This runs unit tests and integration tests.
By default, the client is a thin wrapper that sends REST calls to Rockset using node-fetch
. Some applications may require more complex behavior. If additional functionality is required, the client can be configured to generate the parameters for a REST call, and pass them to a custom fetch function to be handled accordingly.
Here is an example that shows how to support cancelling API calls using a custom fetch function with Axios. To supply a custom fetch function, we pass it in as the last parameter to rockset
.
import axios from "axios";
import rockset from "@rockset/client";
// Simple fetch with Axios instead of node-fetch
const customFetchAxios = async (
url: string,
{ headers, method, body: data, queryParams: params, cancelToken }: any
) => {
const res = await axios.request({
url,
headers,
method,
data,
params,
cancelToken,
});
return res.data;
};
// Configure
const basePath = "https://api.rs2.usw2.rockset.com";
const rocksetClient = rockset(process.env.ROCKSET_APIKEY, basePath, customFetchAxios);
const cancelSource = axios.CancelToken.source();
// Execute a query
rockset.queries
.query(
{ sql: { query: "SELECT count(*) FROM _events" } },
{ cancelToken: cancelSource.token }
)
.then(console.log)
.catch(console.error);
// Cancel the request through axios
// Note: this merely cancels the HTTP call - it does not cancel the query on Rockset's servers
cancelSource.cancel();
Please feel free to submit a pull request for modifications that can benefit other users in the community. It is best to have a unit test associated with each pull request.
File any issues with this client through GitHub.
This client is licensed under the Apache 2.0 License.
FAQs
Client for querying Rockset and interacting with the Rockset API.
The npm package @rockset/client receives a total of 5,727 weekly downloads. As such, @rockset/client popularity was classified as popular.
We found that @rockset/client demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 2 open source maintainers 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
Deno 2.2 enhances Node.js compatibility, improves dependency management, adds OpenTelemetry support, and expands linting and task automation for developers.
Security News
React's CRA deprecation announcement sparked community criticism over framework recommendations, leading to quick updates acknowledging build tools like Vite as valid alternatives.
Security News
Ransomware payment rates hit an all-time low in 2024 as law enforcement crackdowns, stronger defenses, and shifting policies make attacks riskier and less profitable.