1
0
mirror of https://github.com/LibreTranslate/LibreTranslate.git synced 2024-11-05 07:20:13 +01:00
LibreTranslate/README.md

117 lines
3.4 KiB
Markdown
Raw Normal View History

2020-12-19 20:19:35 +01:00
# LibreTranslate
2020-12-20 21:52:02 +01:00
2020-12-21 00:56:05 +01:00
[Try it online!](https://libretranslate.com) | [API Docs](https://libretranslate.com/docs)
[![Publish to DockerHub](https://github.com/uav4geo/LibreTranslate/workflows/Publish%20to%20DockerHub/badge.svg)](https://hub.docker.com/r/libretranslate/libretranslate) ![Publish to GitHub Container Registry](https://github.com/uav4geo/LibreTranslate/workflows/Publish%20to%20GitHub%20Container%20Registry/badge.svg)
2021-01-02 18:17:11 +01:00
Free and Open Source Machine Translation API, entirely self-hosted. Unlike other APIs, it doesn't rely on proprietary providers such as Google or Azure to perform translations.
2020-12-20 21:52:02 +01:00
![image](https://user-images.githubusercontent.com/1951843/102724116-32a6df00-42db-11eb-8cc0-129ab39cdfb5.png)
2020-12-20 22:04:48 +01:00
[Try it online!](https://libretranslate.com) | [API Docs](https://libretranslate.com/docs)
2020-12-20 21:52:02 +01:00
2020-12-20 22:13:38 +01:00
## API Examples
Request:
```javascript
const res = await fetch("https://libretranslate.com/translate", {
method: "POST",
body: JSON.stringify({
q: "Hello!",
source: "en",
target: "es"
}),
headers: {
"Content-Type": "application/json"
});
console.log(await res.json());
```
Response:
```javascript
{
"translatedText": "¡Hola!"
}
```
2020-12-20 21:52:02 +01:00
## Build and Run
2020-12-20 22:13:38 +01:00
You can run your own API server in just a few lines of setup!
2020-12-20 21:52:02 +01:00
Make sure you have installed Python (3.8 or higher), then simply issue:
```bash
git clone https://github.com/uav4geo/LibreTranslate --recurse-submodules
cd LibreTranslate
pip install -r requirements.txt
python main.py [args]
```
2020-12-20 22:13:38 +01:00
Then open a web browser to http://localhost:5000
### Run with Docker
2020-12-29 16:55:53 +01:00
Simply run:
```bash
docker run -ti --rm -p 5000:5000 libretranslate/libretranslate
```
Then open a web browser to http://localhost:5000
### Build with Docker
Make sure you cloned the `models` submodule before building the Docker image:
```bash
docker build -t libretranslate .
```
Run the built image:
```bash
docker run -it -p 5000:5000 libretranslate [args]
```
Or build and run using `docker-compose`:
```bash
docker-compose up -d --build
```
> Feel free to change the [`docker-compose.yml`](https://github.com/uav4geo/LibreTranslate/blob/main/docker-compose.yml) file to adapt it to your deployment needs, or use an extra `docker-compose.prod.yml` file for your deployment configuration.
2020-12-20 21:52:02 +01:00
## Arguments
| Argument | Description | Default |
| ------------- | ------------------------------ | -------------------- |
| --host | Set host to bind the server to | `127.0.0.1` |
| --port | Set port to bind the server to | `5000` |
| --char-limit | Set character limit | `No limit` |
| --req-limit | Set maximum number of requests per minute per client | `No limit` |
| --ga-id | Enable Google Analytics on the API client page by providing an ID | `No tracking` |
| --debug | Enable debug environment | `False` |
2020-12-21 00:56:46 +01:00
| --ssl | Whether to enable SSL | `False` |
2020-12-20 21:52:02 +01:00
## Roadmap
Help us by opening a pull request!
2020-12-21 20:31:50 +01:00
- [x] A docker image (thanks [@vemonet](https://github.com/vemonet) !)
2020-12-20 21:52:02 +01:00
- [ ] Auto-detect input language
- [ ] User authentication / tokens
2020-12-21 19:55:14 +01:00
- [ ] Language bindings for every computer language
2020-12-20 21:52:02 +01:00
## Credits
This work is largely possible thanks to [Argos Translate](https://github.com/argosopentech/argos-translate), which powers the translation engine.
## License
2020-12-21 00:56:05 +01:00
[GNU Affero General Public License v3](https://www.gnu.org/licenses/agpl-3.0.en.html)