Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/megasanjay/electron-flask
Using Flask as the backend of an Electron.js application
https://github.com/megasanjay/electron-flask
electron electron-builder flask pyinstaller
Last synced: 2 months ago
JSON representation
Using Flask as the backend of an Electron.js application
- Host: GitHub
- URL: https://github.com/megasanjay/electron-flask
- Owner: megasanjay
- License: mit
- Created: 2021-06-22T18:53:49.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2023-12-15T20:29:09.000Z (about 1 year ago)
- Last Synced: 2024-05-01T18:25:12.574Z (9 months ago)
- Topics: electron, electron-builder, flask, pyinstaller
- Language: Python
- Homepage:
- Size: 22.5 KB
- Stars: 11
- Watchers: 2
- Forks: 3
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
## Requirements:
If we are using the conda environment add flask to the environment file.
```bash
pip install flask
pip install pyinstaller# for windows only
pip install pypiwin32 # for pyinstaller
```## renderer.js
```js
const axios = require("axios");const SERVER_URL = "http://127.0.0.1:5000";
// Check server connection
(() => {
axios
.get(`${SERVER_URL}/`)
.then((response) => {
console.log(response.data);
})
.catch((error) => {
console.error(error);
});
})();const requestObject = {
key: "Hello world from Electron!",
};const echo = (requestObject) => {
axios
.post(`${SERVER_URL}/echo`, requestObject)
.then((response) => {
console.log("Server response: ", response.data);
})
.catch((error) => {
console.error(error);
});
};
```
Using the axios library, the backend will behave just like a regular web server. Use `axios.get()`, `axios.post()`, etc... to send the requests to the api. The `SERVER_URL` will remain constant and the port will be whatever is defined in `main.js`. If you need timeouts set the appropriate timeouts directly in the axios request.## api.py
```python
from __future__ import print_function
from flask import Flask, request, jsonify
from calc import calc as real_calc
import timeapp = Flask(__name__)
@app.route('/', methods=["GET"])
def hello():
return "Server active!"@app.route('/echo', methods=["POST"])
def echo():
try:
data = request.json
print("Server: ", data["key"])
return "Hello World from Server!"
except Exception as e:
raise e# :5000 is the flask default port.
# You can change it to something else if you would like.
if __name__ == '__main__':
app.run(host='127.0.0.1', port=5000)
```
You can use this template to start. All the routes are defined under the `@app.route(, methods=["method"])` syntax. Keep the function name inside the route descriptive. Use only one `def` inside the route and for any additional functions, declare/define them outside the `@app` block.The return type must be a string, dict, tuple, Response instance, or WSGI callable (NO INT RETURNS)
## For quick testing
If you don't want to have to create the python process everytime, use the following instructions to have a more realtime view of the program. Set the `createPyProc` function to not run.
```js
// main.jsconst createPyProc = () => {
return;
}
```
Open the flask backend on the terminal window. You will be able to see all the requests that come through. If you set any print statements in your python output, they will be visible here as well. To run this:
```bash
python ./api.py
```## Packaging and distribution
Everything here works exactly the same as [SODA](https://github.com/bvhpatel/SODA/wiki/Packaging). On Windows, I didn't need to move any file or folders into the package. Should be a drop in replacement. You will need to add the `npm run` scripts for this repo.