Metadata-Version: 2.1
Name: bom-mysql
Version: 0.1.0
Summary: Awesome bom_mysql created by bommaru-com
Home-page: https://github.com/bommaru-com/bom_mysql
Author: bommaru-com
License: UNKNOWN
Platform: UNKNOWN
Description-Content-Type: text/markdown
Provides-Extra: test
License-File: LICENSE

# Usage

.env 파일의 설정으로 필요시 ssh 터널링을 하여 mysql 접속 및 종료 처
```
# requirements.txt
git+https://github.com/bommaru-com/bom_mysql.git

# .env
DB_HOST={database host}
DB_PORT={database port}
DB_USERNAME={database username}
DB_PASSWORD={database password}
DB_DEFAULT={default database name}
SSH_HOST={jump server host}
SSH_PORT={jump server port}
SSH_USERNAME={jump server username}
SSH_PRIVATE_KEY={pem key path}
TUNNEL={use tunnel flag 0 or 1}

# usage
>>> from bom_mysql import MysqlConnect
>>> from bom_mysql import loadenv

>>> conf = loadenv()
>>> db = MysqlConnect(conf)

>>> db.cursor.execute("select now()")
>>> now = db.cursor.fetchone()
>>> MysqlConnect.cleanup(db)  # 프로그램에서 사용시 종료되면 atexit 모듈에 의해 호출되어 처리됩니다.
```


# Python Project Template

A low dependency and really simple to start project template for Python Projects.

See also 
- [Flask-Project-Template](https://github.com/rochacbruno/flask-project-template/) for a full feature Flask project including database, API, admin interface, etc.
- [FastAPI-Project-Template](https://github.com/rochacbruno/fastapi-project-template/) The base to start an openapi project featuring: SQLModel, Typer, FastAPI, JWT Token Auth, Interactive Shell, Management Commands.

### HOW TO USE THIS TEMPLATE

> **DO NOT FORK** this is meant to be used from **[Use this template](https://github.com/rochacbruno/python-project-template/generate)** feature.

1. Click on **[Use this template](https://github.com/rochacbruno/python-project-template/generate)**
3. Give a name to your project  
   (e.g. `my_awesome_project` recommendation is to use all lowercase and underscores separation for repo names.)
3. Wait until the first run of CI finishes  
   (Github Actions will process the template and commit to your new repo)
4. If you want [codecov](https://about.codecov.io/sign-up/) Reports and Automatic Release to [PyPI](https://pypi.org)  
  On the new repository `settings->secrets` add your `PIPY_API_TOKEN` and `CODECOV_TOKEN` (get the tokens on respective websites)
4. Read the file [CONTRIBUTING.md](CONTRIBUTING.md)
5. Then clone your new project and happy coding!

> **NOTE**: **WAIT** until first CI run on github actions before cloning your new project.

### What is included on this template?

- 🖼️ Templates for starting multiple application types:
  * **Basic low dependency** Python program (default) [use this template](https://github.com/rochacbruno/python-project-template/generate)
  * **Flask** with database, admin interface, restapi and authentication [use this template](https://github.com/rochacbruno/flask-project-template/generate).
  **or Run `make init` after cloning to generate a new project based on a template.**
- 📦 A basic [setup.py](setup.py) file to provide installation, packaging and distribution for your project.  
  Template uses setuptools because it's the de-facto standard for Python packages, you can run `make switch-to-poetry` later if you want.
- 🤖 A [Makefile](Makefile) with the most useful commands to install, test, lint, format and release your project.
- 📃 Documentation structure using [mkdocs](http://www.mkdocs.org)
- 💬 Auto generation of change log using **gitchangelog** to keep a HISTORY.md file automatically based on your commit history on every release.
- 🐋 A simple [Containerfile](Containerfile) to build a container image for your project.  
  `Containerfile` is a more open standard for building container images than Dockerfile, you can use buildah or docker with this file.
- 🧪 Testing structure using [pytest](https://docs.pytest.org/en/latest/)
- ✅ Code linting using [flake8](https://flake8.pycqa.org/en/latest/)
- 📊 Code coverage reports using [codecov](https://about.codecov.io/sign-up/)
- 🛳️ Automatic release to [PyPI](https://pypi.org) using [twine](https://twine.readthedocs.io/en/latest/) and github actions.
- 🎯 Entry points to execute your program using `python -m <bom_mysql>` or `$ bom_mysql` with basic CLI argument parsing.
- 🔄 Continuous integration using [Github Actions](.github/workflows/) with jobs to lint, test and release your project on Linux, Mac and Windows environments.

> Curious about architectural decisions on this template? read [ABOUT_THIS_TEMPLATE.md](ABOUT_THIS_TEMPLATE.md)  
> If you want to contribute to this template please open an [issue](https://github.com/rochacbruno/python-project-template/issues) or fork and send a PULL REQUEST.

[❤️ Sponsor this project](https://github.com/sponsors/rochacbruno/)

<!--  DELETE THE LINES ABOVE THIS AND WRITE YOUR PROJECT README BELOW -->

---
# bom_mysql

[![codecov](https://codecov.io/gh/bommaru-com/bom_mysql/branch/main/graph/badge.svg?token=bom_mysql_token_here)](https://codecov.io/gh/bommaru-com/bom_mysql)
[![CI](https://github.com/bommaru-com/bom_mysql/actions/workflows/main.yml/badge.svg)](https://github.com/bommaru-com/bom_mysql/actions/workflows/main.yml)

Awesome bom_mysql created by bommaru-com

## Install it from PyPI

```bash
pip install bom_mysql
```

## Usage

```py
from bom_mysql import BaseClass
from bom_mysql import base_function

BaseClass().base_method()
base_function()
```

```bash
$ python -m bom_mysql
#or
$ bom_mysql
```

## Development

Read the [CONTRIBUTING.md](CONTRIBUTING.md) file.

