diff --git a/.dockerignore b/.dockerignore new file mode 100644 index 0000000..cd8251c --- /dev/null +++ b/.dockerignore @@ -0,0 +1,6 @@ +.git/ +.vscode/ +.idea/ + +.DS_Store +__pycache__ \ No newline at end of file diff --git a/.github/workflows/docker.yaml b/.github/workflows/docker.yaml new file mode 100644 index 0000000..10c608f --- /dev/null +++ b/.github/workflows/docker.yaml @@ -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 \ No newline at end of file diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 0000000..4dbeeca --- /dev/null +++ b/Dockerfile @@ -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"] \ No newline at end of file diff --git a/docker-compose.yaml b/docker-compose.yaml new file mode 100644 index 0000000..a00bb48 --- /dev/null +++ b/docker-compose.yaml @@ -0,0 +1,5 @@ +services: + shirino: + build: . + image: ghcr.io/shirino/shirino:latest + restart: unless-stopped \ No newline at end of file diff --git a/main.py b/main.py index 2ee56f0..75f264a 100644 --- a/main.py +++ b/main.py @@ -26,12 +26,17 @@ async def currency(query: types.Message | types.InlineQuery) -> None: conv = Converter() if len(args) <= 1: - if query.chat.type not in ['supergroup', 'group']: - return await reply(result_id, - "2 or 3 arguments are required.", - "@shirino_bot USD RUB " - "\n@shirino_bot 12 USD RUB", - query) + 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 " + "\n@shirino_bot 12 USD RUB", + query) if len(args) == 4: conv.amount = float(args[0]) from_currency_alias = args[1].lower() @@ -44,8 +49,13 @@ 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']: - return await reply(result_id, 'The source and target currency could not be determined.', None, query) + 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: