/dbbs-solutions

Primary LanguageTypeScriptMIT LicenseMIT

DBBS Pre-Built Solutions

Table of Contents

  1. Introduction
  2. Prerequisites
  3. Installation
  4. Usage
  5. Repository Structure
  6. Configuration Details
  7. Contribution Guidelines
  8. FAQs/Troubleshooting
  9. Contact Information
  10. License

Introduction

Welcome to the DBBS Pre-Built Solutions, a comprehensive solution developed by DBB Software that is designed to revolutionize the management and development of complex software ecosystems. This platform is the foundation of a robust monorepo approach, enabling the creation of diverse applications, including APIs (both server-based and serverless), mobile apps with React Native, and web applications (React SPA and SSR).

At DBBS Pre-Built Solutions, our focus is on providing a strong and adaptable foundation for software development. We address the challenges of managing multiple applications within a single repository with our seamless, efficient approach to generating a base monorepo structure complete with all necessary applications and tools.

Our platform is defined by its opinionated design, offering a suite of predefined, rigorously tested configurations and modules. This framework minimizes the time developers spend on architectural decisions, allowing more focus on innovation. DBBS Pre-Built Solutions is more than a tool; it represents a shift in how development ecosystems are managed and scaled, merging industry best practices with cutting-edge technologies. Join us in advancing the future of software development.

Key Advantages of DBBS Pre-Built Solutions:

  • Streamlined Development Process: Through our CLI interface or configuration files, developers can easily assign necessary modules to each application, tailoring functionalities to meet specific needs within the monorepo.
  • Time Efficiency: The platform's predefined configurations and opinionated nature drastically cut down setup time, allowing developers to dive into coding immediately.
  • Consistency and Quality: Uniform structure and configurations across projects enhance overall development quality, ensuring a consistent and high-standard output.

Prerequisites

Before diving into the DBBS Pre-Built Solutions, ensure the following prerequisites are met for a smooth experience:

  • Git: Essential for source control management.
  • Node.js & NPM: Required for managing dependencies and running scripts. Check the .nvmrc file for the exact Node.js version.
  • Python & Poetry: Required for managing dependencies and running apps for Python projects.
  • AWS CLI: Necessary for handling AWS services, version 2.14.0 or higher.
  • Serverless Framework: Version 3.38.0 or higher for deploying serverless applications.
  • Knowledge Base: Familiarity with JavaScript/TypeScript, React, and serverless concepts will be beneficial.

These tools and knowledge are key to effectively using and contributing to the DBBS Pre-Built Solutions.

Essential Tools

  • Git: Required for version control and repository management. Ensure Git is installed on your machine.
  • Node.js & NPM: The platform is dependent on Node.js. The required version is specified in the .nvmrc file in the root of the repository. The corresponding npm version should be used as per the Node.js version.
  • Python & Poetry: The part of platform is depended on Python. The required version is specified in the pyproject.toml file in each python applications directory

AWS Integration

  • AWS CLI v2.14.0 or Higher: For managing AWS services, install AWS CLI version 2.14.0 or higher.
  • Serverless Framework v3.38.0 or Higher: To deploy serverless applications, you'll need the Serverless Framework. Install version 3.38.0 or higher for optimal compatibility.

AWS Account Setup

  • AWS Account: An AWS account is necessary for deploying applications. Set up your account if you haven't already.
  • AWS CLI Keys: Generate AWS CLI keys with the following permissions to ensure full functionality with AWS services:
    • AWSCloudFormationFullAccess
    • AWSLambda_FullAccess
    • AmazonAPIGatewayAdministrator
    • AmazonS3FullAccess
    • AmazonEC2ContainerRegistryFullAccess
    • SecretsManagerReadWrite

Recommended Knowledge

  • JavaScript/TypeScript: Familiarity with JavaScript or TypeScript is essential, as our pre-built solutions is heavily based on these languages.
  • React & React Native: Basic understanding of React for web apps and React Native for mobile app development.
  • Serverless Architecture: Knowledge of serverless concepts is beneficial for working with serverless APIs.

Installation DBBS Pre-Built Solutions

Setting up the DBBS Pre-Built Solutions is straightforward. Follow these steps to get started:

  1. Clone the Repository Begin by cloning the repository to your local machine.

    git clone https://github.com/DBB-Software/pre-built-solutions

    This command clones the DBBS Pre-Built Solutions repository from GitHub.

  2. Setup AWS Config File Before you start setting up DBBS Pre-Built Solutions, you need to configure the AWS config.

    cd pre-built-solutions/infra/aws_configs

    Open the config file and change the following values ​​to your own:

    • sso_start_url
    • profile
    • sso_session
    • sso_account_id
  3. Run Example Applications

    1. Linux/macOS Makefile is designed to automate the setup of dependencies, download environment variables for projects, build and run all example applications. To start all example applications, use the following command:
      make all
    2. Windows with WSL Install Windows Subsystem for Linux (WSL): Setup WSL on Windows
      Once WSL is installed, open the WSL terminal. You can do this by searching for "Ubuntu" (or the name of your Linux distribution) in the Start Menu and selecting it.
      Navigate to your project directory on the Windows file system using the WSL terminal (example):
      cd /mnt/c/Users/User/Documents/DBB/platform
      Install Homebrew on WSL:
      /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
      Follow the on-screen instructions to add Homebrew to your PATH:
      echo 'eval "$(/home/linuxbrew/.linuxbrew/bin/brew shellenv)"' >> ~/.bashrc
      eval "$(/home/linuxbrew/.linuxbrew/bin/brew shellenv)"
      Verify the installation:
      brew --version
      To start all example applications, use the following command:
      make all
  4. Testing Running tests is crucial for maintaining code quality. Use the test command to execute your test suites.

    make test

Installation A Specific Applications DBBS Pre-Built Solutions

If you want run a specific applications follow these steps:

  1. Follow steps 1-2 in Installation DBBS Pre-Built Solutions

  2. Setup Setting up dependencies and environment variables. Makefile is designed to automate the setup of dependencies and environment variables for project. It uses Homebrew, asdf, and Yarn to manage installations and versions of tools and packages and AWS CLI for download environment variables. Navigate to the root directory of the cloned repository.

    cd pre-built-solutions

    Install all dependencies and environments while in the root directory of the cloned repository.

    For all available languages

    make setup

    Only for TypeScript

    make setup-ts

    Only for Python

    make setup-py
  3. Build A Specific application Once the dependencies are installed, build specific application to ensure all components are properly compiled.

    make build-<app-name>
  4. Run A Specific Applications If you want start a specific application, use the following command:

    make dev-<app-name>
  5. Test A Specific Applications

    make test-<app-name>

Usage DBBS Pre-Built Solutions

The DBBS Pre-Built Solutions offers a set of commands to manage and operate your monorepo efficiently. These commands are designed to enhance flexibility and enable targeted development tasks for specific packages or applications. Below is a guide to the key commands and their functionalities:

  1. Linting To ensure code quality and consistency, use the lint command. This will check your code for any stylistic or programming errors.

    yarn lint
  2. Building To compile your code and prepare it for deployment, use the build command. This is essential for making sure your applications are ready for production.

    yarn build
  3. Testing Running tests is crucial for maintaining code quality. Use the test command to execute your test suites.

    yarn test
  4. Starting Applications To start a specific application in a production environment, use the start command.

    target=<app-name> yarn start

    Replace <app-name> with the name of the application you wish to start.

  5. Development Mode For a development environment with hot reloading, use the dev command. This is particularly useful during the development phase for immediate feedback.

    target=<app-name> yarn dev

    Replace <app-name> with the name of the application you're developing.

  6. Local start For local environment to emulate AWS resources LocalStack is used. To start the local environment and emulate AWS resources using LocalStack, run the start:localstack command from the root directory. This will start applications along with additional AWS services in docker container such as S3, etc.

Additional Tips

  • Targeted Commands: Most commands support a target env variable at the beginning of command to specify which package or app the command should run for. This allows for more granular control over your development workflow.
  • Custom Scripts: You can also define custom scripts in your package.json to streamline your workflow further.

With these commands and tips, you can fully leverage the capabilities of the DBBS Pre-Built Solutions to streamline your development process.

Commands:

  • yarn dev

Targeted Commands:

  • target=web-spa yarn start
  • target=web-spa yarn dev

In addition to the standard development commands, the DBBS Platform includes Cypress testing commands to facilitate end-to-end testing. These commands leverage the Cypress testing framework for interactive and headless test execution.

  • target=web-spa yarn cypress:open - Launches the Cypress Test Runner in an interactive mode, allowing developers to visually inspect and debug tests.
  • target=web-spa yarn cypress:run - Executes Cypress tests in a headless mode, suitable for automated test runs in continuous integration (CI) pipelines.

Makefile Targets:

  • setup - The main target for setting up all dependencies and environment variables. It runs the following targets in order: install-aws, install-asdf, install-docker, check-versions, setup-aws-credentials, download-env.
  • setup-ts - The main target for setting up all dependencies and environment variables for TypeScript. It first runs the Makefile in the TypeScript directory, and then executes the following targets in order: install-aws, install-asdf, install-docker, check-versions, setup-aws-credentials, download-env.
  • setup-py - The main target for setting up all dependencies and environment variables for Python. It runs the Makefile in the Python directory.
  • check-brew - Checks if Homebrew is installed on the system. If not, it prompts the user to install Homebrew by providing the installation instructions.
  • asdf-install - Installs asdf and its plugins for managing Node.js, Ruby, and Cocoapods versions. It also updates all asdf plugins and installs the specified versions of the tools.
  • install-deps - Installs the project's dependencies, which include Node.js modules and the AWS CLI. It runs the install-node-modules and install-awscli targets.
  • install-node-modules - Installs the required Node.js modules using Yarn.
  • check-asdf-path - Checks if asdf is correctly set in the system's PATH. If not, it opens instructions for adding asdf to the shell.
  • check-yarn - Checks if Yarn is installed and up to date. If not, it installs Yarn using Corepack. It also updates local Yarn to the stable version if the installed version is lower than 4.0.
  • install-awscli - Installs the AWS CLI using Homebrew.
  • check-versions - Checks and prints the versions of installed tools, including asdf, Node.js, Ruby, Cocoapods, Yarn and the AWS CLI.
  • all - The main target for running all essential operations. It runs the following targets in order: setup, run-build, and run-dev.
  • run-build - Builds the platform. It executes the yarn build command.
  • run-build-% - Pattern rule that runs the yarn build command in the specified subdirectory. The subdirectory is determined by replacing % with the name of the subdirectory.
  • setup-aws-credentials - Automatically configures AWS credentials.
  • aws-login - This target logs into AWS if the SSO session has expired.
  • download-env - Downloads environment variables from AWS Secrets Manager using the AWS profile and region specified in the $(AWS_PROFILE), $(STAGE) and $(REGION) variables.
  • run-dev - Runs the yarn dev command in the root directory of the project.
  • run-dev-% - Pattern rule that runs the yarn dev command in the specified subdirectory. The subdirectory is determined by replacing % with the name of the subdirectory.
  • run-test - Runs the yarn test command in the root directory of the project.
  • run-test-% - Pattern rule that runs the yarn test command in the specified subdirectory. The subdirectory is determined by replacing % with the name of the subdirectory.
  • install-awscli-local - Installs the LocalStack AWS CLI using Homebrew.
  • install-docker - Installs Docker and Docker Compose if they are not already installed, using Homebrew.
  • check-versions - Checks and prints the versions of installed tools, including asdf, Node.js, Ruby, Cocoapods, Yarn, AWS CLI, Docker and Docker Compose.
  • localstack-up and localstack-down - Commands to manage LocalStack services with Docker Compose.
  • set-docker-volume-permissions - Sets permissions for Docker volumes to ensure accessibility.
  • Target-specific rules like install-gems-%, install-pods-%, fastlane-build-%, firebase-distribution-%, and beta-distribution-% are designed to handle operations in specific subdirectories for various deployment and testing scenarios.

Scripts:

The .sh scripts are in /scripts folder. Below is an outline of the scripts, along with their purpose:

download.env.sh

Script for downloading environment variables from AWS Secret Manager. It requires the STAGE, AWS_PROFILE, and SECRET_PREFIX variables to be set. There are three ways to set the envs:

  1. Inline variable
    STAGE="your-stage" AWS_PROFILE="your-aws-profile" SECRET_PREFIX="your-secret-prefix" ./download.env.sh
    
  2. With export in terminal
    export STAGE="your-stage"
    export AWS_PROFILE="your-aws-profile"
    export SECRET_PREFIX="your-secret-prefix"
    ./script.sh
    
  3. Define the STAGE, AWS_PROFILE, SECRET_PREFIX in scripts/env-constants.sh.
    # Define the AWS profile (default value)
    AWS_PROFILE="${AWS_PROFILE:-default-aws-profile}"
    
    # Define the secret prefix (default value)
    SECRET_PREFIX="${SECRET_PREFIX:-dbbs-platform}"
    
    # Define the stage (default value)
    STAGE="${STAGE:-default-stage}"
upload-settings.sh

The main script for uploading application settings to an S3 bucket. It requires the SETTINGS_S3_BUCKET_NAME and AWS_PROFILE variables to be set. There are three ways to set the SETTINGS_S3_BUCKET_NAME and AWS_PROFILE:

  1. Inline variable
    SETTINGS_S3_BUCKET_NAME="your-s3-bucket-name" ./scripts/upload-settings.sh
  2. With export in terminal
    export SETTINGS_S3_BUCKET_NAME="your-s3-bucket-name"
    ./scripts/upload-settings.sh
  3. Define the SETTINGS_S3_BUCKET_NAME in scripts/env-constants.sh.
    #!/bin/bash
    
    # Define a list of environment names
    readonly ENVIRONMENTS=("local" "development" "production" "staging")
    
    # Define the S3 bucket name (default value)
    SETTINGS_S3_BUCKET_NAME="${SETTINGS_S3_BUCKET_NAME:-default-s3-bucket-name}"
    

upload-env.sh

Script for uploading environment variables from AWS Secret Manager. It requires the STAGE, AWS_PROFILE, and SECRET_PREFIX variables to be set. There are three ways to set the envs:

  1. Inline variable
    STAGE="your-stage" AWS_PROFILE="your-aws-profile" SECRET_PREFIX="your-secret-prefix" ./scripts/upload-env.sh
    
  2. With export in terminal
    export STAGE="your-stage"
    export AWS_PROFILE="your-aws-profile"
    export SECRET_PREFIX="your-secret-prefix"
    ./scripts/upload-env.sh
    
  3. Define the STAGE, AWS_PROFILE, SECRET_PREFIX in scripts/env-constants.sh.
    # Define the AWS profile (default value)
    AWS_PROFILE="${AWS_PROFILE:-default-aws-profile}"
    
    # Define the secret prefix (default value)
    SECRET_PREFIX="${SECRET_PREFIX:-dbbs-platform}"
    
    # Define the stage (default value)
    STAGE="${STAGE:-default-stage}"

Repository Structure

The DBBS Pre-Built Solutions monorepo is structured to facilitate ease of navigation and development across various components. Below is an outline of the key directories and files, along with their purpose:

  • /apps: This directory contains the individual applications developed within the monorepo. Each sub-directory represents a separate application, such as server, serverless APIs, React SPA, React SSR, and React Native mobile apps.
  • /packages: Contains shared packages or libraries that are used across multiple applications within the monorepo. This promotes code reusability and consistency.
  • /serverless-layer: Specific to serverless applications, this directory hosts the common layers used in serverless deployments, such as shared libraries and utilities.
  • /turbo: This directory contains configurations and scripts related to the Turbo repository management tool, which helps in managing and scaling the monorepo efficiently.
  • yarn.lock & package.json: These files manage dependencies for the entire monorepo.
  • tsconfig.json: Configuration file for TypeScript, setting compiler options for the projects.
  • turbo.json: Configuration file for the Turbo tool, defining the build dependencies and optimizations.

Apps

This directory encompasses a diverse array of applications, spanning web, server, mobile, and function-based applications. The DBBS Platform provides a comprehensive set of tools and configurations to facilitate efficient development across various application types.

Front End:

  • Server-Side Rendered Next.js App (SSR) - application provides the ability to generate static pages
  • React Single Page Apps (SPA)

Back End:

  • Server NestJS App
  • Serverless NestJS App
  • Serverless App
  • Strapi App
  • Server Django App

Mobile applications

  • React Native cross-platform mobile app, can be presented using react-native-cli and expo.

For each application, a predefined set of initial configurations is supplied. These include:

  • ESLint Configuration
  • Jest Configuration
  • Detox Configuration
  • TypeScript Configurations
  • Firebase configuration: Remote config and messaging
  • Fastlane implementation of cross-platform distribution
  • Sentry Configuration
  • Storybook Configuration: on device and web

Additionally, a sample component is provided for each application, serving as a practical illustration of the application's structure. These applications serve as diverse templates for building customer systems. Whether you are constructing a web interface, server logic, mobile application, or a serverless function, the DBBS Platform offers a solid foundation to expedite development.

Setup Instructions after generating app template via turbo generator
For react-native-cli Template
  1. Generate Required Firebase Files:

    • google-services.json for Android
    • GoogleService-Info.plist for iOS
  2. Add Firebase Files:

    • Place the google-services.json file into the android/app directory.
    • Place the GoogleService-Info.plist file into the ios directory.
  3. Complete the Setup:

    • Ensure that all other configurations and dependencies are correctly set up according to the provided templates.
For Expo Template
  1. Generate Required Firebase Files:

    • google-services.json
    • GoogleService-Info.plist
  2. Add Firebase File:

    • Place the google-services.json and GoogleService-Info.plist file into the firebase directory within the Expo template.
  3. Run Prebuild Command:

    • Execute the command yarn prebuild to generate the native parts of the application.

By following these instructions, you ensure that the necessary Firebase configurations are properly integrated into your mobile application setup, whether you are using react-native-cli or expo.

Packages

The packages folder serves as a repository for common elements shared across various applications within the DBBS Platform. It encapsulates fundamental configurations, reusable components, and essential features, providing a centralized resource for streamlined development. These are modules that are used in apps to cover the basic logic of end-customer applications, such as authorization, logging, multi-tenancy configuration, etc.

Common Configurations:

  • Settings Configuration
  • ESLint Base Configuration
  • TypeScript Base Configurations

React Components and Features:

A collection of React components and features designed to enhance the user interface and functionality across applications.

Mobile Components and Features:

Presented as two packages:

  • mobile-components: A collection of ReactNative components using the react-native-paper, react-native-gesture-handler, react-native-svg, react-native-reanimated, react-native-tab-view, react-native-vector-icons, etc. libraries. Designed to improve the user interface of ReactNative and Expo applications.
  • mobile-features: A collection of universal solutions for ReactNative applications including implementation of firebase service handling.
  • mobile-storages: This package provides a basic implementation for two storage options - RTK and Jotai, with a persistence implementation using react-native-mmkv.

NestJS Modules:

A set of NestJS modules, including middlewares, filters, interceptors, guards, and pipes. These modules contribute to the backend logic and functionality shared among applications. Detailed information about each NestJS module can be found in the packages/nest-modules directory, where each module includes its own README file.

AWS Package Wrapper:

To ensure smoother integration with AWS services, the packages folder includes a wrapper for key AWS packages. This simplifies the usage of AWS functionalities across different applications.

Strapi Plugins:

A collection of custom Strapi plugins that enhance and extend the functionality of Strapi applications. These plugins cover various use cases such as permissions management, Stripe integration, and more. Detailed information about each Strapi plugin can be found in the packages/strapi-plugins directory, where each plugin includes its own README file.

The packages folder consolidates common elements critical for maintaining consistency and efficiency in development. By centralizing configurations, components, and modules, developers can seamlessly integrate shared functionalities into their respective applications.

ESLint and TypeScript Configurations

Base Configurations

Found within the platform are base configurations for ESLint and TypeScript. These configurations establish consistent coding standards and type checking throughout the entire monorepository.

Importantly, the base configurations are inherited by the monorepo, promoting uniformity in coding practices and type safety across projects.

Framework-Specific Guidelines

In addition to the base configurations, the guidelines incorporate framework-specific settings for various application and package types.

Versatility Across Apps

These configurations cater to the unique needs of web, server, mobile, and function applications. They provide tailored guidelines for each, optimizing the development experience based on specific requirements.

Purpose

The primary goal of these configuration guidelines is to establish a consistent foundation for development. By integrating base configurations and framework-specific settings, developers benefit from standardized coding practices and streamlined development processes.

How to Use

Review and implement the configuration guidelines relevant to your project. Whether you're working on an application or a package, these guidelines are crucial for maintaining code quality and ensuring seamless integration within the diverse ecosystem of the DBBS Platform.

Generators

The generators folder is a key component of the DBBS Platform, offering a streamlined approach to generating necessary applications with custom names. Each application from the apps folder has a corresponding generator, enabling developers to create applications tailored to their specific needs efficiently through CLI commands.

Individual Generators

Within the generators folder, there exists a dedicated generator for each application located in the apps folder. These generators encapsulate the necessary configurations and structures for the corresponding applications. The generators empower developers to create needed applications with custom names effortlessly through Command Line Interface (CLI) commands. This functionality enhances flexibility and expedites the application setup process. The generator folder simplifies and accelerates the application creation process. Developers can easily generate needed applications with personalized names, ensuring a more efficient and adaptable development workflow.

Configuration Details

The DBBS Pre-Built Solutions is designed to be highly configurable to meet a variety of development needs. Below is an overview of key configuration files and settings within the monorepo:

  • package.json: This file at the root level defines project dependencies and scripts. It's essential for managing npm packages and can be customized to include additional scripts or dependencies as required.

  • tsconfig.json: TypeScript configurations are managed here. Adjust compiler options and include paths according to your project's TypeScript requirements.

  • turbo.json: This configuration file is vital for the Turbo repository management tool. It defines the build dependencies and strategies for optimizing the monorepo's performance.

  • /apps Directory Configurations: Each application within the /apps directory may have its own configuration files, such as .env for environment variables and specific setup files. These should be configured based on the needs of each individual app.

  • Serverless Configuration: For serverless applications, configurations are typically found in the serverless.yml files within the respective application directories. Adjust these files to configure your serverless deployments.

Tips for Effective Configuration:

  • Keep Configurations Organized: Maintain a clear structure in your configuration files for ease of maintenance and updates.
  • Document Customizations: If you add custom scripts or make significant changes to configuration files, document these changes either in the README or a separate documentation file.
  • Version Control: Regularly commit changes to your configuration files to version control, allowing you to track and revert changes if needed.

By properly configuring the DBBS Pre-Built Solutions, you can ensure that it aligns with your development objectives and works seamlessly across different environments.

Status Page Integration

Our status page is available at the following link: dbbs-status-apps.betteruptime.com.

Overview

This status page is used to display the current availability of our applications. We use the Better Uptime service to monitor the uptime and performance of our applications.

How to Add a New Application for Monitoring

  1. Creating a Monitor:

    • To add a new application for monitoring, you need to create a monitor in Better Uptime.
    • During the creation process, provide the health check URL of your application. This will allow Better Uptime to automatically check its availability.
  2. Setting Up Integrations:

    • You can configure various integrations to receive alerts if your application becomes unavailable. Notifications can be sent to your preferred channel, such as email, Slack, SMS, and more.
  3. Adding the Monitor to the Status Page:

    • To display the availability of your application on the status page, add the created monitor to the status page.
    • To do this, go to the "Status Pages" section, create a new status page or select an existing one.
    • In the status page structure, add a new section and select the monitor for your application.
    • This way, the current availability status of your application will be displayed on the status page.

Conclusion

This way, we can monitor the availability of our applications and receive alerts if any of them become unavailable.

Technology Stack

The DBBS Pre-Built Solutions utilizes a diverse and modern technology stack to offer a robust and efficient development experience. Below is an overview of the key technologies used and their specific roles within the platform:

  • NestJS: A progressive Node.js framework used for building efficient, reliable, and scalable server-side applications.
  • Django: Is a high-level Python web framework that encourages rapid development and clean, pragmatic design.
  • Next.js: A React framework that enables functionalities such as server-side rendering and generating static websites, enhancing the performance of web applications.
  • Material UI: A popular UI framework for React applications, known for its responsive and customizable components that speed up the design process.
  • Serverless: A framework for building and deploying serverless applications, streamlining the process of managing cloud resources and reducing operational overhead.
  • NextServerlessDeployment: This technology enhances Next.js applications, providing serverless self-hosted solution with a robust caching solution.
  • Turbo: A high-performance build system and repository management tool designed to optimize the development and scaling of monorepos like ours.
  • Vite: An innovative front-end build tool that significantly improves the development experience with features like instant server start and lightning-fast hot module replacement (HMR).
  • Jest: A delightful JavaScript testing framework with a focus on simplicity, providing a flexible and scalable testing solution for our applications.
  • **ReactNative: A framework for building native applications using React, enabling the development of cross-platform mobile applications with a single codebase.
  • **Expo: A framework and platform for universal React applications, providing a set of tools and services to build, deploy, and quickly iterate on iOS, Android, and web apps from the same JavaScript/TypeScript codebase.
  • **Firebase: A comprehensive app development platform that offers a variety of tools and services such as authentication, real-time databases, cloud storage, and analytics, facilitating the development of high-quality apps.
  • **Fastlane: An open-source platform aimed at simplifying Android and iOS deployment, automating every aspect of building and releasing mobile applications.
  • **Detox: A gray-box end-to-end testing and automation library for mobile apps, designed to test your mobile application from the perspective of a real user.

Our technology stack is carefully selected to ensure the platform remains at the forefront of development innovation, offering a powerful combination of speed, efficiency, and scalability.

Contribution Guidelines

We warmly welcome contributions to the DBBS Pre-Built Solutions! Whether you're fixing bugs, improving documentation, or suggesting new features, your input is invaluable. Here's how you can contribute:

Getting Started

  1. Fork the Repository: Start by forking the repository on GitHub. This creates your own copy of the project where you can make changes.
  2. Clone Your Fork: Clone your fork to your local machine to start working on the changes.
    git clone https://github.com/your-username/dbbs-platform-base
  3. Create a New Branch: Always create a new branch for your changes. This keeps the work organized and makes it easier to manage pull requests.
    git checkout -b your-branch-name

Making Contributions

  • Code Contributions: When contributing code, ensure it adheres to the project's coding standards and write tests where applicable.
  • Documentation: If you are contributing to documentation, ensure your changes are clear, concise, and helpful for other users.
  • Bug Reports and Feature Requests: Use the GitHub Issues section to report bugs or suggest new features. Please provide as much detail as possible to help us understand the issue or feature.

Submitting Your Changes

  1. Commit Your Changes: Make your changes and commit them with a clear commit message.
    git commit -m "A brief description of your changes"
  2. Push to Your Fork: Push the changes to your forked repository.
    git push origin your-branch-name
  3. Create a Pull Request: Go to the original repository on GitHub and create a pull request from your branch. Provide a clear description of your changes and the purpose of the pull request.

Code Review

  • Once you've submitted a pull request, it will be reviewed by the maintainers. Be open to feedback and make any requested changes if necessary.

Stay Updated

  • Regularly pull changes from the main repository to keep your fork up to date. This minimizes the chances of conflicts.

Code of Conduct

  • Please adhere to the Code of Conduct while interacting with the project. Respectful and constructive communication is expected from all participants.

By following these guidelines, you can contribute to making DBBS Pre-Built Solutions an even better tool for everyone. We look forward to your contributions!

Questions or Issues?

  • If you have any questions or run into issues, don't hesitate to reach out for help or clarification.

Thank you for contributing to the DBBS Pre-Built Solutions!

FAQs/Troubleshooting

This section aims to address common questions and provide solutions to frequent issues that users might encounter while working with the DBBS Pre-Built Solutions.

Frequently Asked Questions (FAQs)

  1. Q: How do I update my local repository with the latest changes from the main repo? A: Use the git pull command to fetch and merge the latest changes from the main repository.

  2. Q: What should I do if I encounter npm dependency conflicts? A: Ensure that you are using the same npm version as specified in the project. If the issue persists, try removing the node_modules directory and the yarn.lock file, then run yarn again.

  3. Q: Can I contribute to a feature or bugfix without being assigned? A: Absolutely! Feel free to pick up any unassigned issues. We recommend commenting on the issue to let others know you're working on it.

Troubleshooting Common Issues

  1. Issue: Build failing due to TypeScript errors. Solution: Ensure that your TypeScript version matches the one specified in the project. Check for any type mismatches or syntax errors in your code.

  2. Issue: Serverless deployment errors. Solution: Verify that your AWS credentials are correctly set up and that you have the necessary permissions. Also, check the serverless.yml configurations for any inconsistencies.

  3. Issue: The application not running after recent updates. Solution: Pull the latest changes from the main repository and rebuild the application. If the issue persists, it might be due to incompatible local environment settings.

Additional Help

If your question or issue isn't covered here, don't hesitate to reach out to us or raise an issue on GitHub. We are continually updating this section based on user feedback and common queries.

For detailed documentation and guides, refer to the /documentation directory in the repository.

Contact Information

We value your feedback and contributions to the DBBS Pre-Built Solutions. If you have any questions or suggestions or need support, here are several ways to get in touch with us:

  • General Inquiries and Support: For any general questions about the platform or if you need assistance, please visit our website DBB Software and use the contact form provided.

  • GitHub Issues: For specific issues, feature requests, or bugs related to the platform, please use the GitHub Issues page. This is the fastest way to directly communicate with our development team and track the resolution of your issue.

  • Community Discussion and Contributions: Join our community discussions on GitHub Discussions for broader topics, ideas exchange, and collaborative discussions.

  • Social Media: Follow us on our social media channels for the latest news, updates, and insights:

  • Email Contact: For more formal or detailed inquiries, feel free to reach out to us via email at in@dbbsoftware.com.

We're always here to help and are committed to ensuring you have the best experience with the DBBS Pre-Built Solutions. Your input and participation drive the continuous improvement of our platform.

License

The DBBS Pre-Built Solutions is open-source software licensed under the MIT License.

Key Points of the MIT License:

  • Freedom to Use: You are free to use this software in your own projects, commercial or otherwise.
  • Permission to Modify: You have the right to modify the code to suit your needs.
  • Redistribution: You can distribute the original or modified versions of the software.
  • No Warranty: The software is provided "as is", without warranty of any kind.

This license allows for maximum flexibility and broad use, encouraging innovation and collaboration. For the full terms and conditions, please refer to the LICENSE file in the repository.

We believe in open-source software and the power of community collaboration, and we hope this licensing choice helps foster a vibrant and supportive ecosystem around the DBBS Pre-Built Solutions.