This Document is for Skeet v1.

Setup - Firestore

💃 What's Skeet? 🕺

⚡️ Do more, manage less ⚡️

Reduce app development and operation costs and realize more plans.

Skeet is an open-source full-stack app development solution.

You can start writing app logic immediately without worrying about infrastructure.

📱 Demo App made by Skeet: https://skeeter.dev/

https://storage.googleapis.com/skeet-assets/animation/skeet-cli-create-latest.gif

🧪 Dependency 🧪

※ We don't write Java but we need it for mobile apps working

📗 Usage 📗

① Install Skeet/Firebase CLI

Skeet CLI is a command line tool for efficiently using the Skeet framework. You can install it with the following command. If npm is already installed, you can install it with the following command.

bash
$ npm i -g @skeet-framework/cli $ npm install -g firebase-tools

If npm is not installed, you can install it with the following command. (This command installs nodenv, node, npm, @skeet-framework/cli and edits .profile/.zshrc.)

bash
$ sh -c "$(curl -sSfL https://storage.googleapis.com/skeet-assets/resources/v1.0.2-install)" $ npm install -g firebase-tools

② Create Skeet App

bash
$ skeet create <appName>

Skeet Create Select Template

You can choose a template for the frontend.

※ This tutorial uses the Expo version, but you can use the same procedure even using the Next.js version.

③ Run Skeet App

bash
$ cd <appName> $ skeet s

Now you have both frontend and backend running locally ⭐️

📲 Frontend(Next.js) - http://localhost:4200/

📲 Frontend(Expo) - http://localhost:19006/

💻 Firebase Emulator - http://localhost:4000/

⚠️ You need to finish Activate Skeet ChatApp step to fully use default Skeet App ⚠️

🤖 Activate Skeet ChatApp 🤖

① Create Google Cloud Project

Create Google Cloud Project

② Add Firebase Project

Add Firebase Project

③ Activate Firebase Build

- Activate Firebase Authentication

  • Activate Firebase Authentication Firebase Authentication

  • Activate Email/Password Sign-in Email/Password in

- Activate Firebase Firestore

  • Activate Firestore Firestore

  • Select Native Mode Firestore

  • Select Region Firestore

- Firebase Storage

  • Activate Firebase Storage Firebase Storage

  • Select Native Mode Firebase Storage

  • Select Region Firebase Storage

④ Skeet init to setup project

Run skeet init command and select your GCP Project ID and Regions to setup.

Then, please visit the URL to authenticate your Firebase account.

bash
// Please login to Google Cloud if you have not $ gcloud auth login $ skeet init --login ? What's your GCP Project ID skeet-demo ? Select Regions to deploy europe-west1 europe-west2 europe-west3 ❯ europe-west6 northamerica-northeast1 southamerica-east1 us-central1 Visit this URL on this device to log in: https://accounts.google.com/o/oauth2/auth?project... Waiting for authentication...

⑤ How to setup Secret Key

- Upgrade to Firebase Blaze Plan

Skeet Framework uses Cloud Secret Manager environment variables to manage sensitive information such as API keys.

This command requires a Firebase Blaze or higher plan.

画像

From the Firebase console's bottom left menu, select Upgrade.

- Cloud Usage of Skeet Framework

Skeet Framework requires a Firebase Blaze plan or higher.

Google Cloud Free Program should cover the usage fee for the development environment.

The Google Cloud Free Tier has two parts:

  • A 90-day free trial with a $300 credit to use with any Google Cloud services.
  • Always Free, which provides limited access to many common Google Cloud resources, free of charge.

Free cloud features and trial offer

Firabse Blaze Pricing Plans

⚠️ We also recommend setting things like budget alerts to avoid unexpected charges. ⚠️

- Create OpenAI API Key

画像

📕 OpenAI API Document

- Set Secret Key in Cloud Secret Manager

using the skeet add secret <secretKey> command

Set the OpenAI Organization ID as an environment variable.

bash
$ skeet add secret CHAT_GPT_ORG ? Enter value for CHAT_GPT_ORG: <yourOpenAIOrganizationID>

Set CHAT_GPT_KEY as well.

bash
$ skeet add secret CHAT_GPT_KEY ? Enter value for CHAT_GPT_KEY: <yourOpenAIKey>

You can also write it in functions/skeet/.secret.local or functions/skeet/.env to try it easily, This method does not translate to production environments.

Now you are ready to use Skeet ChatApp 🎉

📱 User Login Auth 📱

bash
$ skeet s

Run Skeet App locally and access to

http://localhost:19006/register (with Next.js: http://localhost:4200/auth/register)

Let's create a new user account with your email address and password.

User Register

After registration, you will see the console log like below.

Email Validation

Click the link in the console log to verify your email address.

bash
To verify the email address [email protected], follow this link: <Link>

Successfully verified your email address.

画像

✉️ Create AI Chat Room ✉️

After login, access this page to create a chat room.

http://localhost:19006/user/open-ai-chat (with Next.js: http://localhost:4200/user/chat)

Let's create a chat room with the following settings.

OpenAI Chat Room Settings

itemdescriptiontype
ModelSelect OpenAI API's Modelgpt-3.5-turbo / gpt-4
Max TokensSet OpenAI API's Max Tokensnumber
TemperatureSet OpenAI API's Temperaturenumber
System CharactorSet OpenAI API's System Charactorstring

OpenAI ChatGPT AI Chat

Now you are all set 🎉

OpenAI ChatGPT AI Chat