Skip to content

Commit

Permalink
Merge pull request #497 from Telegram-Mini-Apps/feature/mate
Browse files Browse the repository at this point in the history
Welcome Mate
  • Loading branch information
heyqbnk authored Oct 11, 2024
2 parents d2f588c + d28c2d0 commit bf29b38
Show file tree
Hide file tree
Showing 44 changed files with 3,114 additions and 115 deletions.
13 changes: 11 additions & 2 deletions apps/docs/.vitepress/packages.ts
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,9 @@ export const packagesSidebar: Sidebar = {
[BASE]: [
section('CLI', {
'@telegram-apps/create-mini-app': 'telegram-apps-create-mini-app',
'@telegram-apps/mate': ['telegram-apps-mate', {
'Hosting': 'hosting'
}],
}),
section('TypeScript', {
'@telegram-apps/signals': 'telegram-apps-signals',
Expand Down Expand Up @@ -110,11 +113,17 @@ export const packagesSidebar: Sidebar = {
])],
}],
}],
'@telegram-apps/sdk-react': [{ url: 'telegram-apps-sdk-react', page: false }, {
'@telegram-apps/sdk-react': [{
url: 'telegram-apps-sdk-react',
page: false
}, {
'@1.x': '1-x',
'@2.x': '2-x',
}],
'@telegram-apps/sdk-solid': [{ url: 'telegram-apps-sdk-solid', page: false }, {
'@telegram-apps/sdk-solid': [{
url: 'telegram-apps-sdk-solid',
page: false
}, {
'@1.x': '1-x',
'@2.x': '2-x',
}],
Expand Down
61 changes: 61 additions & 0 deletions apps/docs/packages/telegram-apps-mate.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,61 @@
# @telegram-apps/mate

Mate is a multifunctional tool for developers at the Telegram Mini Apps
platform, that solves a wide range of problems.

## Installing

To start using Mate, it is required to install the `@telegram-apps/mate`
package. The developer can do it both locally and globally:

:::code-group

```bash [pnpm]
# Locally.
pnpm i -D @telegram-apps/mate
# Globally.
pnpm i -g @telegram-apps/mate
```

```bash [npm]
# Locally.
npm i -D @telegram-apps/mate
# Globally.
npm i -g @telegram-apps/mate
```

```bash [yarn]
# Locally.
yarn add -D @telegram-apps/mate
# Globally.
yarn global add @telegram-apps/mate
```

:::

Once installed, the package will be accessible via the `mate` CLI tool:

```bash
mate --help
```

> [!TIP]
> It is highly recommended to install the package locally to avoid confusion
> over package versions and to ensure a consistent usage experience within the
> development team.
## Install-free Usage

Not to install the package, you can also use the package using `pnpm` or `npx`:

:::code-group

```bash [pnpm]
pnpm dlx @telegram-apps/mate@latest --help
```

```bash [npx]
npx @telegram-apps/mate@latest --help
```

:::
213 changes: 213 additions & 0 deletions apps/docs/packages/telegram-apps-mate/hosting.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,213 @@
# Hosting

With Mate's fast and reliable hosting, developers can effectively manage static
assets for their mini applications. Delivering static files efficiently and
securely is vital for optimal performance.

By utilizing a Content Delivery Network (CDN), Mate's hosting boosts reliability
and accelerates file loading for users across various regions, surpassing the
performance of single-server solutions.

The hosting service is free, though there are some limitations on data transfer.

> [!WARNING]
> If you’re currently using a single server for both static file hosting and
> server-side operations, transitioning to Mate's hosting may require code
> adjustments. If your app already distinguishes between static and dynamic
> requests, integration will be much simpler.
## Features

### Lightning Speed

The crucial feature of Mate's hosting is its well-configured Content Delivery
Network spread across the world, in countries where mini applications are
commonly used. This feature allows developers to focus on building their
applications rather than worrying about how to deliver static assets as quickly
as possible.

### Version Management System

Another notable hosting feature is the version management system.

Mate allows the creation of up to five deployment tags, enabling developers to
deploy the project with a specific tag without affecting previously deployed
assets.

#### Usage Example

A common use case here is when the project has two versions: `latest` and
`staging`. The developer can use the `latest` version for production and
`staging` for the Quality Assurance team.

After deploying the `staging` assets, the QA team checks if this staging state
is acceptable. Then, the same assets can be deployed with the `latest` tag for
production.

#### About Base URL

When deploying static assets, Mate uses the following base URL pattern:

```
https://{storage_key}.tapps.global/{tag}
```

Here’s some information on these parameters for clarification:

- `storage_key`: a unique key for the deployed project. This value is
non-configurable and is assigned to the project upon creation.
- `tag`: a deployment tag. This value is set during the deployment process by
the developer. Examples include `staging`, `latest`, `dev`, etc.

## Getting Started

### Step 1: Register a Project

To start using the hosting functionality, you must register the project and
obtain its deployment token. To get the token, go
to [@tma_mate_bot](https://t.me/tma_mate_bot) and press the `Start` button to
begin the conversation with the bot.

<p align="center">
<img src="/mate/start.png" width="320"/>
</p>

Next, press the `Create a Project` button and enter the title of the project to
be created, following the specified rules.

<p align="center">
<img src="/mate/create.png" width="320"/>
</p>

After this step, the bot will return the created project information, including
the **deployment token**.

### Step 2: Update the Static Assets Base URL

Before deploying the project, ensure that all static assets have a valid base
URL. You can learn more about how Mate generates the static assets base
URL [here](#about-base-url).

To retrieve the project deployment information using a specific tag, use the
following command:

```bash
mate deploy info \
--token {DEPLOYMENT_TOKEN} \
--project {PROJECT_ID} \
--tag {TAG}
```

Here, the `DEPLOYMENT_TOKEN` and `PROJECT_ID` values refer to the deployment
token and project identifier received from the previous step. `TAG` is a
deployment version tag name.

Output example:

```
✔ Fetched deploy information for paper-planes (id 48) project
Project Title: paper-planes
Short title of the project
--------
Base Path (using tag "staging"): https://35f105bd6b.tapps.global/staging
This path will be used as a base path for the uploaded assets associated with this project.
Consider using this value as a base path in your bundler. You can also use different tags using the --tag option.
--------
Allowed file extensions: html, css, js, cjs, mjs, png, jpg, jpeg, webp, ttf, woff, woff2, eot, json, ico
Files extensions that are allowed to be uploaded.
--------
Maximum size: 10485760 bytes
Maximum upload size.
--------
Maximum files count: 100
Maximum number of files a single upload can contain.
```

The value `https://35f105bd6b.tapps.global/staging` is the base URL that should
be used in the project bundler.

Here’s how it can be applied using [Vite](https://vitejs.dev).

```ts
import { defineConfig } from 'vite';

export default defineConfig({
base: 'https://35f105bd6b.tapps.global/staging'
});
```

### Step 3: Deploy the Project

To deploy the project, Mate requires specifying a folder to be uploaded to the
hosting service. The folder must only contain files that can be opened by the
user's browser, so no source files or files for different purposes should be
present in the directory.

Let’s assume the following conditions:

- A project with ID `48` and token `aabbccdd` was created.
- A folder named `dist` contains all the mini application built static assets.
- It is required to deploy the static assets with the tag `latest`.

To deploy the project under these conditions, run the following command:

```bash
mate deploy upload \
--dir dist \
--token aabbccdd \
--project 48 \
--tag latest
```

Here’s the possible output:

```
✔ Fetched deploy information for paper-planes (id 48) project
i Assets base path (using tag "latest"):
https://35f105bd6b.tapps.global/latest
i Allowed file extensions: html, css, js, cjs, mjs, png, jpg, jpeg, webp, ttf, woff, woff2, eot, json, ico
i Maximum upload size: 10485760 bytes
i Maximum files count: 100
✔ Directory compressed successfully from 24185 to 7168 bytes
✔ Archive uploaded successfully
📁 dist
╰ 📄 index.js (https://35f105bd6b.tapps.global/latest/index.js)
```

> [!WARNING]
> The deployed directory must include only standard files and directories,
> excluding private ones (starting with the `.` symbol). All other types of
> files (such as symlinks) are forbidden. If found during the deployment process,
> the CLI tool will throw a corresponding error.
## Using Config

To avoid repeatedly specifying parameters, Mate allows creating a special
configuration with all the parameters included.

Here’s a complete config example with the parameters
mentioned [previously](#step-3-deploy-the-project).

```yml
deploy:
projectId: 48
directory: dist
token: aabbccdd
tag: latest
```
Then, the `info` and `upload` commands will retrieve the values from the
configuration.

```bash
mate deploy info
mate deploy upload
```

If any parameter override is required, it should be specified in the command.
For example, to override the `tag` option with the `staging` value, use the
following command:

```bash
mate deploy info --tag staging
```
Binary file added apps/docs/public/mate/create.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added apps/docs/public/mate/start.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
2 changes: 1 addition & 1 deletion packages/init-data-node/tsconfig.json
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
{
"extends": "tsconfig/base.json",
"extends": "tsconfig/esnext.json",
"include": [
"src"
],
Expand Down
2 changes: 1 addition & 1 deletion packages/init-data-node/tsconfig.node.json
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
{
"extends": "tsconfig/base.json",
"extends": "tsconfig/esnext.json",
"compilerOptions": {
"composite": true
},
Expand Down
41 changes: 41 additions & 0 deletions packages/mate/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
# See https://help.github.com/articles/ignoring-files/ for more about ignoring files.

# dependencies
node_modules
.pnp
.pnp.js

# testing
coverage

# next.js
.next/
out/
dist

# misc
.DS_Store
*.pem

# debug
npm-debug.log*
yarn-debug.log*
yarn-error.log*

# local env files
.env
.env.local
.env.development.local
.env.test.local
.env.production.local

# turbo
.turbo

# vercel
.vercel

.idea
.docusaurus

mate.yml
21 changes: 21 additions & 0 deletions packages/mate/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
# @telegram-apps/mate

[code-badge]: https://img.shields.io/badge/source-black?logo=github

[docs-badge]: https://img.shields.io/badge/documentation-blue?logo=gitbook&logoColor=white

[code-link]: https://github.com/Telegram-Mini-Apps/telegram-apps/tree/master/packages/mate

[docs-link]: https://docs.telegram-mini-apps.com/packages/telegram-apps-mate

[npm-link]: https://npmjs.com/package/@telegram-apps/mate

[npm-badge]: https://img.shields.io/npm/v/@telegram-apps/mate?logo=npm

[![NPM][npm-badge]][npm-link]
[![docs-badge]][docs-link]
[![code-badge]][code-link]

Your personal mate in Telegram Mini Apps development.

The package documentation has been moved [here](https://telegram-mini-apps.gitbook.io/mate).
Loading

0 comments on commit bf29b38

Please sign in to comment.