Development Guides
SDK
Overview

Overview

SDK

ROQ BaaS SDKs are a collection of packages and tools that allow for creating SaaS applications supporting various web frameworks such as Express, Next.js, Nuxt.js, RedwoodJS, or SvelteKit.

With this SDK, you can streamline the fetching, manipulation, and storage of data in the BaaS database. The SDK also handles user authentication and authorization, ensuring secure app interactions and additional features such as file handling, user profiles, and user invites, enhancing the application's capability.

The SDK offers mainly two variations: client-side or front-end SDK and server-side or back-end SDK.

Front-end SDK

The front-end SDK is: @roq/client and generated SDK

This @roq/client package is installed automatically when using the @roq/cli tool to generate a front-end SDK. Typically, developers would not use it directly during development because @roq/cli generates code that is easier to use and ready for interaction with BaaS.

Our CLI tool @roq/cli will generate the front-end SDK. Furthermore, the benefits of the generated front-end SDK include:

  • Customization: Tailored to fit the specific requirements and configurations of your front-end project. For example, if you need to make changes to the project schema, you can do so using the ROQ Console and then regenerate the SDK.
  • Easy Integration: The API generated in the SDK is designed to be easily integrated with modern front-end frameworks and libraries.
  • Consistency: Ensures consistent interaction patterns with the back-end, reducing potential integration issues.

The front-end SDK serves primary purposes:

  • Access to the BaaS database (via Rest API)
  • Interaction with ROQ Platform (via GraphQL)
  • Redirects to hosted pages

Back-end SDK

The back-end SDKs are: @roq/nodejs and @roq/nextjs (we will support more SDKs coming soon)

The server-side SDK includes the following:

  • Auth-handlers (specific per framework)
  • ROQ Node.js SDK (for interaction with ROQ Platform)
  • BaaS SDK (with and without access management)

CLI

@roq/cli is a command-line interface (CLI) tool that facilitates the generation of a front-end SDK in your project. It provides a convenient way to streamline creating a software development kit (SDK) tailored for front-end development. The CLI will generate code based on the project Prisma schema and will handle any dependencies that are needed.

Installation

The installation and setup of the SDK depend on the client or server frameworks used. Refer to the installation documentation for specific details.

Access to your data

The front-end SDK simplifies BaaS database access on the client and leverages the ROQ platform. Also, the API uses Prisma-like syntax that is easy to understand. To learn about query syntax, visit the query syntax documentation.

For information on accessing data in applications like Next.js, check out the documentation on accessing data.

Authentication

SaaS applications always need authentication. The ROQ platform handles this authentication. Hence, the developers don't need to implement it from scratch. The front-end SDK has helper functions for easy authentication. You can visit authentication to learn more about authentication.

Additional features

File handling

This API handles everything to do with the file (upload, get files, delete files, and update files). Please look into the file handling section for more information.

User invites

The API handle user invitation to the project tenant or organization. You can read more in this user invites for more information.

Emails

The API handles sending emails. Visit the emails for more information.