Skip to content

Commit da66bc7

Browse files
authored
Merge pull request #1 from callstack/chore/repo-setup
chore: repo setup
2 parents 32b5cb2 + e039c69 commit da66bc7

File tree

114 files changed

+13906
-2
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

114 files changed

+13906
-2
lines changed

.editorconfig

+17
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,17 @@
1+
# EditorConfig helps developers define and maintain consistent
2+
# coding styles between different editors and IDEs
3+
# editorconfig.org
4+
5+
root = true
6+
7+
[*]
8+
9+
indent_style = space
10+
indent_size = 2
11+
12+
end_of_line = lf
13+
charset = utf-8
14+
trim_trailing_whitespace = true
15+
insert_final_newline = true
16+
17+
max_line_length = 100

.eslintignore

+9
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,9 @@
1+
node_modules/
2+
3+
dist/
4+
5+
tsup.config.ts
6+
rslib.config.ts
7+
rsbuild.config.ts
8+
vitest.config.ts
9+

.eslintrc

+25
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,25 @@
1+
{
2+
"extends": "@callstack/eslint-config/node",
3+
"rules": {
4+
"prettier/prettier": [
5+
"error",
6+
{
7+
"quoteProps": "consistent",
8+
"singleQuote": true,
9+
"tabWidth": 2,
10+
"trailingComma": "all",
11+
"useTabs": false
12+
}
13+
]
14+
},
15+
"parserOptions": {
16+
"project": ["./tsconfig.lint.json"]
17+
},
18+
"settings": {
19+
"import/resolver": {
20+
"typescript": {
21+
"project": ["./tsconfig.lint.json"]
22+
}
23+
}
24+
}
25+
}

.gitattributes

+3
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
*.pbxproj -text
2+
# specific for windows script files
3+
*.bat text eol=crlf

.github/actions/setup/action.yaml

+30
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,30 @@
1+
name: Setup
2+
description: Setup Node.js and install dependencies
3+
4+
# see: https://pnpm.io/continuous-integration#github-actions
5+
runs:
6+
using: composite
7+
steps:
8+
- name: Cache turbo build setup
9+
uses: actions/cache@v4
10+
with:
11+
path: .turbo
12+
key: ${{ runner.os }}-turbo-${{ github.sha }}
13+
restore-keys: |
14+
${{ runner.os }}-turbo-
15+
16+
- name: Install pnpm
17+
uses: pnpm/action-setup@v4
18+
with:
19+
version: 9.12.2+sha256.2ef6e547b0b07d841d605240dce4d635677831148cd30f6d564b8f4f928f73d2
20+
21+
- name: Setup Node.js
22+
uses: actions/setup-node@v4
23+
with:
24+
node-version-file: .nvmrc
25+
cache: 'pnpm'
26+
27+
- name: Install dependencies
28+
if: steps.pnpm-cache.outputs.cache-hit != 'true'
29+
run: pnpm install --frozen-lockfile
30+
shell: bash

.github/workflows/ci.yaml

+32
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,32 @@
1+
name: CI
2+
3+
on:
4+
push:
5+
branches:
6+
- main
7+
pull_request:
8+
branches:
9+
- main
10+
11+
jobs:
12+
validate:
13+
name: Validate
14+
runs-on: ubuntu-latest
15+
steps:
16+
- name: Checkout repository
17+
uses: actions/checkout@v4
18+
19+
- name: Setup
20+
uses: ./.github/actions/setup
21+
22+
- name: Build packages
23+
run: pnpm run build
24+
25+
- name: Run tests
26+
run: pnpm test
27+
28+
- name: Typecheck
29+
run: pnpm run typecheck
30+
31+
- name: Lint
32+
run: pnpm run lint

.gitignore

+43
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,43 @@
1+
# OSX
2+
.DS_Store
3+
4+
# VSCode
5+
.vscode/
6+
jsconfig.json
7+
8+
# WebStorm
9+
.idea
10+
11+
# Node.js
12+
node_modules/
13+
npm-debug.log
14+
yarn-debug.log
15+
yarn-error.log
16+
.pnpm-debug.log*
17+
18+
# TypeScript cache
19+
*.tsbuildinfo
20+
21+
# BUCK
22+
buck-out/
23+
\.buckd/
24+
25+
# Build artifacts
26+
build/
27+
dist/
28+
docs/doc_build
29+
30+
# Envs
31+
.env
32+
.env.*
33+
service-account.json
34+
google-*.json
35+
36+
# Other
37+
coverage/
38+
39+
# Rslib
40+
**/.rslib
41+
42+
# Turborepo
43+
.turbo

.nvmrc

+1
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
v20

.prettierrc

+7
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,7 @@
1+
{
2+
"quoteProps": "consistent",
3+
"singleQuote": true,
4+
"tabWidth": 2,
5+
"trailingComma": "all",
6+
"useTabs": false
7+
}

.watchmanconfig

+1
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
{}

CODE_OF_CONDUCT.md

+133
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,133 @@
1+
2+
# Contributor Covenant Code of Conduct
3+
4+
## Our Pledge
5+
6+
We as members, contributors, and leaders pledge to make participation in our
7+
community a harassment-free experience for everyone, regardless of age, body
8+
size, visible or invisible disability, ethnicity, sex characteristics, gender
9+
identity and expression, level of experience, education, socio-economic status,
10+
nationality, personal appearance, race, caste, color, religion, or sexual
11+
identity and orientation.
12+
13+
We pledge to act and interact in ways that contribute to an open, welcoming,
14+
diverse, inclusive, and healthy community.
15+
16+
## Our Standards
17+
18+
Examples of behavior that contributes to a positive environment for our
19+
community include:
20+
21+
* Demonstrating empathy and kindness toward other people
22+
* Being respectful of differing opinions, viewpoints, and experiences
23+
* Giving and gracefully accepting constructive feedback
24+
* Accepting responsibility and apologizing to those affected by our mistakes,
25+
and learning from the experience
26+
* Focusing on what is best not just for us as individuals, but for the overall
27+
community
28+
29+
Examples of unacceptable behavior include:
30+
31+
* The use of sexualized language or imagery, and sexual attention or advances of
32+
any kind
33+
* Trolling, insulting or derogatory comments, and personal or political attacks
34+
* Public or private harassment
35+
* Publishing others' private information, such as a physical or email address,
36+
without their explicit permission
37+
* Other conduct which could reasonably be considered inappropriate in a
38+
professional setting
39+
40+
## Enforcement Responsibilities
41+
42+
Community leaders are responsible for clarifying and enforcing our standards of
43+
acceptable behavior and will take appropriate and fair corrective action in
44+
response to any behavior that they deem inappropriate, threatening, offensive,
45+
or harmful.
46+
47+
Community leaders have the right and responsibility to remove, edit, or reject
48+
comments, commits, code, wiki edits, issues, and other contributions that are
49+
not aligned to this Code of Conduct, and will communicate reasons for moderation
50+
decisions when appropriate.
51+
52+
## Scope
53+
54+
This Code of Conduct applies within all community spaces, and also applies when
55+
an individual is officially representing the community in public spaces.
56+
Examples of representing our community include using an official e-mail address,
57+
posting via an official social media account, or acting as an appointed
58+
representative at an online or offline event.
59+
60+
## Enforcement
61+
62+
Instances of abusive, harassing, or otherwise unacceptable behavior may be
63+
reported to the community leaders responsible for enforcement at
64+
[INSERT CONTACT METHOD].
65+
All complaints will be reviewed and investigated promptly and fairly.
66+
67+
All community leaders are obligated to respect the privacy and security of the
68+
reporter of any incident.
69+
70+
## Enforcement Guidelines
71+
72+
Community leaders will follow these Community Impact Guidelines in determining
73+
the consequences for any action they deem in violation of this Code of Conduct:
74+
75+
### 1. Correction
76+
77+
**Community Impact**: Use of inappropriate language or other behavior deemed
78+
unprofessional or unwelcome in the community.
79+
80+
**Consequence**: A private, written warning from community leaders, providing
81+
clarity around the nature of the violation and an explanation of why the
82+
behavior was inappropriate. A public apology may be requested.
83+
84+
### 2. Warning
85+
86+
**Community Impact**: A violation through a single incident or series of
87+
actions.
88+
89+
**Consequence**: A warning with consequences for continued behavior. No
90+
interaction with the people involved, including unsolicited interaction with
91+
those enforcing the Code of Conduct, for a specified period of time. This
92+
includes avoiding interactions in community spaces as well as external channels
93+
like social media. Violating these terms may lead to a temporary or permanent
94+
ban.
95+
96+
### 3. Temporary Ban
97+
98+
**Community Impact**: A serious violation of community standards, including
99+
sustained inappropriate behavior.
100+
101+
**Consequence**: A temporary ban from any sort of interaction or public
102+
communication with the community for a specified period of time. No public or
103+
private interaction with the people involved, including unsolicited interaction
104+
with those enforcing the Code of Conduct, is allowed during this period.
105+
Violating these terms may lead to a permanent ban.
106+
107+
### 4. Permanent Ban
108+
109+
**Community Impact**: Demonstrating a pattern of violation of community
110+
standards, including sustained inappropriate behavior, harassment of an
111+
individual, or aggression toward or disparagement of classes of individuals.
112+
113+
**Consequence**: A permanent ban from any sort of public interaction within the
114+
community.
115+
116+
## Attribution
117+
118+
This Code of Conduct is adapted from the [Contributor Covenant][homepage],
119+
version 2.1, available at
120+
[https://www.contributor-covenant.org/version/2/1/code_of_conduct.html][v2.1].
121+
122+
Community Impact Guidelines were inspired by
123+
[Mozilla's code of conduct enforcement ladder][Mozilla CoC].
124+
125+
For answers to common questions about this code of conduct, see the FAQ at
126+
[https://www.contributor-covenant.org/faq][FAQ]. Translations are available at
127+
[https://www.contributor-covenant.org/translations][translations].
128+
129+
[homepage]: https://www.contributor-covenant.org
130+
[v2.1]: https://www.contributor-covenant.org/version/2/1/code_of_conduct.html
131+
[Mozilla CoC]: https://github.com/mozilla/diversity
132+
[FAQ]: https://www.contributor-covenant.org/faq
133+
[translations]: https://www.contributor-covenant.org/translations

README.md

+23-2
Original file line numberDiff line numberDiff line change
@@ -1,2 +1,23 @@
1-
# byorg-ai
2-
TypeScript framework for writing chatbot applications
1+
# BYOrg AI - chatbot application framework
2+
3+
## Structure
4+
5+
### BYOrg AI Framework
6+
7+
Packages:
8+
9+
- `packages/core` - contains the core logic for the chatbot framework
10+
- `packages/slack` - contains the logic for the slack integration
11+
- `packages/discord` - contains the logic for the discord integration
12+
- `packages/utils` - contains the utility functions (e.g. logger)
13+
- `packages/document-loaders` - contains the document loaders (e.g. for Google Drive, Notion, etc.)
14+
- `packages/slack-rich-text` - custom Markdown renderer for Slack Blocks/Rich Text format
15+
16+
## BYOrg AI Framework key concepts (`core` package)
17+
18+
- `Application` (message processor) - pipeline for processing messages from the user. In starts with conversation history (e.g. for Slack), then in passes the message through a series of middleware and finally to AI provider (e.g. OpenAI) which produces the response.
19+
- `Middleware` - a middleware is a function that processes the message before it is passed to the AI provider. It is used to add custom logic to the message processing pipeline.
20+
- `Effect` - an effect is a function that is executed after the message is processed. It is used to add custom logic to the message processing pipeline (e.g. logging and analytics).
21+
- `Tool` - a tool is a function that is used by AI provider to call an external API.
22+
- `Plugin` - plugin is a simple interface that groups middlewares, tools and effects into a single entity that can be used to extend the chatbot functionality.
23+
- `ChatModel` - interface representing LLM chat model or more advanced AI flow which adheres to the same simple interface. We use [ai-sdk](https://github.com/ai-sdk/ai-sdk) under the hood to allow for easy integration with many AI providers.

package.json

+26
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,26 @@
1+
{
2+
"name": "@callstack/byorg",
3+
"type": "module",
4+
"packageManager": "[email protected]+sha256.2ef6e547b0b07d841d605240dce4d635677831148cd30f6d564b8f4f928f73d2",
5+
"scripts": {
6+
"build": "turbo build",
7+
"lint": "eslint \"**/*.{js,ts,tsx}\"",
8+
"test": "turbo test",
9+
"typecheck": "turbo run typecheck",
10+
"validate": "turbo build --force && turbo run typecheck test --force && pnpm lint"
11+
},
12+
"devDependencies": {
13+
"@callstack/eslint-config": "^15.0.0",
14+
"@types/node": "^22.5.1",
15+
"dotenv-cli": "^7.4.2",
16+
"eslint": "^8.4.1",
17+
"eslint-config-prettier": "^9.1.0",
18+
"eslint-import-resolver-typescript": "^3.6.3",
19+
"eslint-plugin-prettier": "^5.2.1",
20+
"jest": "^29.7.0",
21+
"prettier": "^3.3.3",
22+
"ts-node": "^10.9.2",
23+
"turbo": "^2.1.3",
24+
"typescript": "^5.6.0"
25+
}
26+
}

packages/core/README.md

+3
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
# BYOrg AI Core package
2+
3+
This package contains main framework for handling user requests

0 commit comments

Comments
 (0)