Compare commits

..

4 commits

5 changed files with 90 additions and 9 deletions

6
.dockerignore Normal file
View file

@ -0,0 +1,6 @@
.git/
.vscode/
.idea/
.DS_Store
__pycache__

49
.github/workflows/docker.yaml vendored Normal file
View file

@ -0,0 +1,49 @@
name: Create and publish a Docker image
on:
push:
branches:
- main
release:
types:
- published
env:
REGISTRY: ghcr.io
IMAGE_NAME: ${{ github.repository }}
jobs:
build-and-push-image:
runs-on: ubuntu-latest
permissions:
contents: read
packages: write
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Log in to the Container registry
uses: docker/login-action@v3
with:
registry: ${{ env.REGISTRY }}
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Extract metadata (tags, labels) for Docker
id: meta
uses: docker/metadata-action@v5
with:
images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}
- name: Build and push Docker image
uses: docker/build-push-action@v5
with:
context: .
push: true
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
platforms: linux/amd64,linux/arm64

11
Dockerfile Normal file
View file

@ -0,0 +1,11 @@
FROM python:3.12
WORKDIR /shirino
COPY ./requirements.txt .
RUN pip3 install --no-cache-dir --upgrade -r ./requirements.txt
COPY ./ /shirino/
CMD ["python", "main.py"]

5
docker-compose.yaml Normal file
View file

@ -0,0 +1,5 @@
services:
shirino:
build: .
image: ghcr.io/shirino/shirino:latest
restart: unless-stopped

16
main.py
View file

@ -26,7 +26,12 @@ async def currency(query: types.Message | types.InlineQuery) -> None:
conv = Converter()
if len(args) <= 1:
if query.chat.type not in ['supergroup', 'group']:
try:
if query.chat.type in ['supergroup', 'group']:
return
except:
pass
return await reply(result_id,
"2 or 3 arguments are required.",
"@shirino_bot USD RUB "
@ -44,7 +49,12 @@ async def currency(query: types.Message | types.InlineQuery) -> None:
from_currency_alias = args[0].lower()
conv_currency_alias = args[1].lower()
else:
if query.chat.type not in ['supergroup', 'group']:
try:
if query.chat.type in ['supergroup', 'group']:
return
except:
pass
return await reply(result_id, 'The source and target currency could not be determined.', None, query)
from_currency, conv_currency = None, None
@ -93,7 +103,7 @@ async def reply(result_id: str | None, title: str | None, desc, query: types.Inl
is_personal=True,
)
else:
await query.answer(title)
await query.answer(f'{title} \n{desc}')
async def main() -> None: