.. image:: https://gitlab.com/aulla/pineboo/badges/master/pipeline.svg
:target: https://gitlab.com/aulla/pineboo/commits/master
:alt: pipeline status
.. image:: https://gitlab.com/aulla/pineboo/badges/master/coverage.svg
:target: https://gitlab.com/aulla/pineboo/commits/master
:alt: coverage report
Pineboo - Manual de supervivencia
===================================
Se ha redactado este manual para las dudas más comunes sobre este proyecto de
investigación, y ayudar a que cualquiera pueda poner en marcha y realizar las
pruebas que desee con el mismo.
¿Qué demonios es Pineboo?
----------------------------
Pineboo es un proyecto de investigación, donde no se pretende obtener un producto
final, sino sentar una base y crear las tecnologías necesarias para el día de mañana
crear realmente el/los producto(s) que se deseen.
Lo que se desea es contestar a la frase: "Qué necesitamos para poder ejecutar un proyecto
de módulos de Eneboo sin Eneboo?"
Para ello, se crea un micro-proyecto (o mejor dicho, pico-proyecto) que solo cubre
lo mínimo necesario para cumplir esa frase, y estrictamente esa frase.
Es posible que exista más de una versión de Pineboo, cada una con distintas aproximaciones
y tecnologías. Actualmente, en el momento de escribir esta documentación, solo existe una.
El nombre de Pineboo viene de Pico-eneboo, y hace referencia que es un proyecto de
investigación
Aproximaciones existentes
---------------------------
Solo existe una única aproximación a la ejecución de proyectos de Eneboo:
- Python3.x + PyQt6
- Permite ejecutarlo en PostgreSQL, SQLite ,MySQL y MSSQL.
- Motor realizado integramente en Python
- Conversión al vuelo de QSA a PY con parseador FLScriptParser2
- Conversión al vuelo de formularios Qt3 a Qt4 creando un UiLoader manualmente
- Conversión al vuelo de fichero .mtd a modelos sqlAlchemy
- Conversión al vuelo de fichros .kut a pdf
Dependencias
----------------
- Python >= 3.8
- PyQt6 >= 6.0.3
- PsycoPG2
Alcance actual de Pineboo
---------------------------
Pineboo es capaz de conectarse a cualquier base de datos de Eneboo y realizar
las siguientes tareas:
- Funcionamientos habituales de las acciones
- Trabajos normales de cursor (afterCommit, beforeCommit, ...)
- Transacciones plenamente operativas sobre postgres
- Impresión con jasperPluging configurado
Al iniciar una acción, el formulario es convertido al vuelo a Qt4 (con errores) y
el script QS es convertido a Python y ejecutado (con muchos más errores). Se
lanza el init() automáticamente.
Las referencias entre módulos (flfacturac.iface.XYZ) funcionan con carga de módulo
retrasada.
La API de QSA y Eneboo está practicamente terminada. En la API aún existente son
funciones y clases "fake", que desde el script, parece que funcionen pero no
realizan ningún trabajo. Esto permite ejecutar los scripts, pero no opera correctamente.
¿Si cargo Pineboo en mi base de datos de producción, puedo perder datos?
-------------------------------------------------------------------------
Sí, pueden perderse datos. Los experimentos con gaseosa.
Dado que es un motor experimental, puede que no realice el trabajo que se le
mande, sino otro inesperado. Un script podría de forma inadvertida borrar registros
por fallos en la API implementada. Y aquí nadie se hace responsable de esto.
Lo mejor es usarlo en bases de datos de desarrollo para evitar problemas.
Cómo poner en marcha Pineboo
------------------------------
1) Instalar desde apt-get.
sudo apt-get install python3-pip git libmysqlclient-dev
2) Actualizar pip.
sudo -H pip3 install --upgrade pip
3) Descargamos pineboo
sudo -H pip3 install pineboo
Al llamar al programa Pineboo éste crea el subdirectorio "/profiles".
Desde ese formulario se configura el acceso a la empresa elegida
Con esto, pineboo debería iniciarse así::
pineboo
Cosas que se pueden probar en Pineboo
----------------------------------------
La opción --help ofrece un listado de opciones, algunas pueden ser interesantes.
Los formularios con convertidos al vuelo, y aún requiere este proceso de muchos
retoques. Las características más usadas funcionan, pero muchas de las cosas
que se pueden hacer en un formulario de Eneboo aún no son intepretadas correctamente.
Para ejecutar los scripts se usan tres capas de compatibilidad: flcontrols, qsaglobals
y qsatypes.
Los ficheros son convertidos a python y guardados junto al fichero QS de cache.
Por ejemplo, las conversiones de masterarticulos.qs se pueden ver en la ruta
`tempdata/cache/nombre_bd/flfactalma/file.qs/masterarticulos/`.
Raw data
{
"_id": null,
"home_page": "https://github.com/deavid/pineboo",
"name": "pineboo",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.8",
"maintainer_email": null,
"keywords": "erp pineboo eneboo accounting sales warehouse",
"author": "David Mart\u00ednez Mart\u00ed, Jos\u00e9 A. Fern\u00e1ndez Fern\u00e1ndez",
"author_email": "deavidsedice@gmail.com, aullasistemas@gmail.com",
"download_url": "https://files.pythonhosted.org/packages/46/9a/7a4a556129048b25e5d3a52c353158385cfa898386ca0bcd8c71e2ab450e/pineboo-0.99.90.tar.gz",
"platform": null,
"description": ".. image:: https://gitlab.com/aulla/pineboo/badges/master/pipeline.svg\n :target: https://gitlab.com/aulla/pineboo/commits/master\n :alt: pipeline status\n\n.. image:: https://gitlab.com/aulla/pineboo/badges/master/coverage.svg\n :target: https://gitlab.com/aulla/pineboo/commits/master\n :alt: coverage report\n\nPineboo - Manual de supervivencia\n===================================\nSe ha redactado este manual para las dudas m\u00e1s comunes sobre este proyecto de\ninvestigaci\u00f3n, y ayudar a que cualquiera pueda poner en marcha y realizar las\npruebas que desee con el mismo.\n\n\u00bfQu\u00e9 demonios es Pineboo?\n----------------------------\nPineboo es un proyecto de investigaci\u00f3n, donde no se pretende obtener un producto\nfinal, sino sentar una base y crear las tecnolog\u00edas necesarias para el d\u00eda de ma\u00f1ana\ncrear realmente el/los producto(s) que se deseen.\n\nLo que se desea es contestar a la frase: \"Qu\u00e9 necesitamos para poder ejecutar un proyecto\nde m\u00f3dulos de Eneboo sin Eneboo?\"\n\nPara ello, se crea un micro-proyecto (o mejor dicho, pico-proyecto) que solo cubre\nlo m\u00ednimo necesario para cumplir esa frase, y estrictamente esa frase.\n\nEs posible que exista m\u00e1s de una versi\u00f3n de Pineboo, cada una con distintas aproximaciones\ny tecnolog\u00edas. Actualmente, en el momento de escribir esta documentaci\u00f3n, solo existe una.\n\nEl nombre de Pineboo viene de Pico-eneboo, y hace referencia que es un proyecto de\ninvestigaci\u00f3n\n\n\nAproximaciones existentes\n---------------------------\nSolo existe una \u00fanica aproximaci\u00f3n a la ejecuci\u00f3n de proyectos de Eneboo:\n\n - Python3.x + PyQt6\n - Permite ejecutarlo en PostgreSQL, SQLite ,MySQL y MSSQL.\n - Motor realizado integramente en Python\n - Conversi\u00f3n al vuelo de QSA a PY con parseador FLScriptParser2\n - Conversi\u00f3n al vuelo de formularios Qt3 a Qt4 creando un UiLoader manualmente\n - Conversi\u00f3n al vuelo de fichero .mtd a modelos sqlAlchemy\n - Conversi\u00f3n al vuelo de fichros .kut a pdf\n\n\nDependencias\n----------------\n - Python >= 3.8\n - PyQt6 >= 6.0.3\n - PsycoPG2\n\nAlcance actual de Pineboo\n---------------------------\nPineboo es capaz de conectarse a cualquier base de datos de Eneboo y realizar\nlas siguientes tareas:\n\n - Funcionamientos habituales de las acciones\n - Trabajos normales de cursor (afterCommit, beforeCommit, ...)\n - Transacciones plenamente operativas sobre postgres\n - Impresi\u00f3n con jasperPluging configurado\n\n\nAl iniciar una acci\u00f3n, el formulario es convertido al vuelo a Qt4 (con errores) y\nel script QS es convertido a Python y ejecutado (con muchos m\u00e1s errores). Se\nlanza el init() autom\u00e1ticamente.\n\nLas referencias entre m\u00f3dulos (flfacturac.iface.XYZ) funcionan con carga de m\u00f3dulo\nretrasada.\n\nLa API de QSA y Eneboo est\u00e1 practicamente terminada. En la API a\u00fan existente son\nfunciones y clases \"fake\", que desde el script, parece que funcionen pero no\nrealizan ning\u00fan trabajo. Esto permite ejecutar los scripts, pero no opera correctamente.\n\n\u00bfSi cargo Pineboo en mi base de datos de producci\u00f3n, puedo perder datos?\n-------------------------------------------------------------------------\nS\u00ed, pueden perderse datos. Los experimentos con gaseosa.\n\nDado que es un motor experimental, puede que no realice el trabajo que se le\nmande, sino otro inesperado. Un script podr\u00eda de forma inadvertida borrar registros\npor fallos en la API implementada. Y aqu\u00ed nadie se hace responsable de esto.\n\nLo mejor es usarlo en bases de datos de desarrollo para evitar problemas.\n\n\nC\u00f3mo poner en marcha Pineboo\n------------------------------\n\n1) Instalar desde apt-get.\n\nsudo apt-get install python3-pip git libmysqlclient-dev\n\n2) Actualizar pip.\n\nsudo -H pip3 install --upgrade pip\n\n3) Descargamos pineboo\n\nsudo -H pip3 install pineboo\n\n\nAl llamar al programa Pineboo \u00e9ste crea el subdirectorio \"/profiles\".\n\nDesde ese formulario se configura el acceso a la empresa elegida\n\n\n\nCon esto, pineboo deber\u00eda iniciarse as\u00ed::\n\n pineboo\n\nCosas que se pueden probar en Pineboo\n----------------------------------------\nLa opci\u00f3n --help ofrece un listado de opciones, algunas pueden ser interesantes.\n\nLos formularios con convertidos al vuelo, y a\u00fan requiere este proceso de muchos\nretoques. Las caracter\u00edsticas m\u00e1s usadas funcionan, pero muchas de las cosas\nque se pueden hacer en un formulario de Eneboo a\u00fan no son intepretadas correctamente.\n\nPara ejecutar los scripts se usan tres capas de compatibilidad: flcontrols, qsaglobals\ny qsatypes.\n\nLos ficheros son convertidos a python y guardados junto al fichero QS de cache.\nPor ejemplo, las conversiones de masterarticulos.qs se pueden ver en la ruta\n`tempdata/cache/nombre_bd/flfactalma/file.qs/masterarticulos/`.\n",
"bugtrack_url": null,
"license": null,
"summary": "ERP replacement for Eneboo written in Python",
"version": "0.99.90",
"project_urls": {
"Homepage": "https://github.com/deavid/pineboo"
},
"split_keywords": [
"erp",
"pineboo",
"eneboo",
"accounting",
"sales",
"warehouse"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "50c4067f569087237fdfa7f6b9915581a576155f28dd307fceeaef2f6bc950f6",
"md5": "c2d64a379f8038e556b1c0c87636cb2a",
"sha256": "d85326f3b58d4345204572025791b950afc4341a7979be74458a83dc6ebcc146"
},
"downloads": -1,
"filename": "pineboo-0.99.90-py3-none-any.whl",
"has_sig": false,
"md5_digest": "c2d64a379f8038e556b1c0c87636cb2a",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.8",
"size": 7084994,
"upload_time": "2024-12-02T10:28:34",
"upload_time_iso_8601": "2024-12-02T10:28:34.923315Z",
"url": "https://files.pythonhosted.org/packages/50/c4/067f569087237fdfa7f6b9915581a576155f28dd307fceeaef2f6bc950f6/pineboo-0.99.90-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "469a7a4a556129048b25e5d3a52c353158385cfa898386ca0bcd8c71e2ab450e",
"md5": "a283a7d5c06df4dc4212dda085efff0c",
"sha256": "fdacae00cf8299538d7038fc3767503eb0170b9aa4d594e08f14ad03bb3a4506"
},
"downloads": -1,
"filename": "pineboo-0.99.90.tar.gz",
"has_sig": false,
"md5_digest": "a283a7d5c06df4dc4212dda085efff0c",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.8",
"size": 6855115,
"upload_time": "2024-12-02T10:28:45",
"upload_time_iso_8601": "2024-12-02T10:28:45.311499Z",
"url": "https://files.pythonhosted.org/packages/46/9a/7a4a556129048b25e5d3a52c353158385cfa898386ca0bcd8c71e2ab450e/pineboo-0.99.90.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-12-02 10:28:45",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "deavid",
"github_project": "pineboo",
"travis_ci": false,
"coveralls": false,
"github_actions": false,
"requirements": [
{
"name": "black",
"specs": []
},
{
"name": "flake8",
"specs": []
},
{
"name": "fpdf",
"specs": []
},
{
"name": "mccabe",
"specs": []
},
{
"name": "mypy",
"specs": []
},
{
"name": "mypy-extensions",
"specs": []
},
{
"name": "ninja",
"specs": []
},
{
"name": "pg8000",
"specs": []
},
{
"name": "ply",
"specs": []
},
{
"name": "pylint",
"specs": []
},
{
"name": "PyQt5",
"specs": []
},
{
"name": "PyQt5-sip",
"specs": []
},
{
"name": "PyQt5-stubs",
"specs": []
},
{
"name": "pytest",
"specs": []
},
{
"name": "python-barcode",
"specs": []
},
{
"name": "python-dateutil",
"specs": []
},
{
"name": "pytz",
"specs": []
},
{
"name": "PyYAML",
"specs": []
},
{
"name": "reportlab",
"specs": []
},
{
"name": "SQLAlchemy",
"specs": []
},
{
"name": "sqlparse",
"specs": []
},
{
"name": "sphinx",
"specs": []
},
{
"name": "sphinx-autodoc-typehints",
"specs": []
},
{
"name": "pydocstyle",
"specs": []
},
{
"name": "sphinx-rtd-theme",
"specs": []
},
{
"name": "pyroma",
"specs": []
},
{
"name": "defusedxml",
"specs": []
},
{
"name": "bandit",
"specs": []
},
{
"name": "coverage",
"specs": []
},
{
"name": "pylint-json2html",
"specs": []
},
{
"name": "pytest-cov",
"specs": []
},
{
"name": "json-rpc",
"specs": []
},
{
"name": "werkzeug",
"specs": []
},
{
"name": "odfpy",
"specs": []
},
{
"name": "wheel",
"specs": []
},
{
"name": "lxml",
"specs": []
},
{
"name": "flup",
"specs": []
},
{
"name": "xmljson",
"specs": []
},
{
"name": "cryptography",
"specs": []
}
],
"tox": true,
"lcname": "pineboo"
}