From 49999c964f518e2b2a12a17c41d5fdac4e4a706a Mon Sep 17 00:00:00 2001 From: DavidDevGt Date: Sun, 10 Nov 2024 03:06:25 -0600 Subject: [PATCH] =?UTF-8?q?Agregar=20configuraci=C3=B3n=20inicial=20del=20?= =?UTF-8?q?proyecto,=20incluyendo=20.gitignore,=20archivo=20de=20entorno,?= =?UTF-8?q?=20dependencias=20de=20Composer=20y=20esquema=20de=20base=20de?= =?UTF-8?q?=20datos.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .env.example | 7 + .gitignore | 2 + app/Infrastructure/Config/Config.php | 14 + composer.json | 8 + composer.lock | 859 +++++++++++++++++++++++++++ schema.sql | 181 ++++++ 6 files changed, 1071 insertions(+) create mode 100644 .env.example create mode 100644 .gitignore create mode 100644 app/Infrastructure/Config/Config.php create mode 100644 composer.json create mode 100644 composer.lock create mode 100644 schema.sql diff --git a/.env.example b/.env.example new file mode 100644 index 0000000..96e6301 --- /dev/null +++ b/.env.example @@ -0,0 +1,7 @@ +DB_HOST= +DB_NAME= +DB_USER= +DB_PASS= +DB_TYPE= +DB_PORT= +LOG_LEVEL=debug diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..8b453d0 --- /dev/null +++ b/.gitignore @@ -0,0 +1,2 @@ +vendor +.env diff --git a/app/Infrastructure/Config/Config.php b/app/Infrastructure/Config/Config.php new file mode 100644 index 0000000..f61728d --- /dev/null +++ b/app/Infrastructure/Config/Config.php @@ -0,0 +1,14 @@ +load(); + } +} \ No newline at end of file diff --git a/composer.json b/composer.json new file mode 100644 index 0000000..8162648 --- /dev/null +++ b/composer.json @@ -0,0 +1,8 @@ +{ + "require": { + "monolog/monolog": "^3.7", + "vlucas/phpdotenv": "^5.6", + "symfony/http-foundation": "^7.1", + "catfan/medoo": "^2.1" + } +} diff --git a/composer.lock b/composer.lock new file mode 100644 index 0000000..e688357 --- /dev/null +++ b/composer.lock @@ -0,0 +1,859 @@ +{ + "_readme": [ + "This file locks the dependencies of your project to a known state", + "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies", + "This file is @generated automatically" + ], + "content-hash": "57c3842c4d48907781b6145f34bfe8a7", + "packages": [ + { + "name": "catfan/medoo", + "version": "v2.1.12", + "source": { + "type": "git", + "url": "https://github.com/catfan/Medoo.git", + "reference": "d1ff4e0e873a3e032e3d8804031dd6be4e013b22" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/catfan/Medoo/zipball/d1ff4e0e873a3e032e3d8804031dd6be4e013b22", + "reference": "d1ff4e0e873a3e032e3d8804031dd6be4e013b22", + "shasum": "" + }, + "require": { + "ext-pdo": "*", + "php": ">=7.3" + }, + "require-dev": { + "phpunit/phpunit": "^9.0" + }, + "suggest": { + "ext-pdo_dblib": "For MSSQL or Sybase database on Linux/UNIX platform", + "ext-pdo_mysql": "For MySQL or MariaDB database", + "ext-pdo_oci": "For Oracle database", + "ext-pdo_pqsql": "For PostgreSQL database", + "ext-pdo_sqlite": "For SQLite database", + "ext-pdo_sqlsrv": "For MSSQL database on both Window/Liunx platform" + }, + "type": "framework", + "autoload": { + "psr-4": { + "Medoo\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Angel Lai", + "email": "angel@medoo.in" + } + ], + "description": "The lightweight PHP database framework to accelerate development", + "homepage": "https://medoo.in", + "keywords": [ + "database", + "database library", + "lightweight", + "mariadb", + "mssql", + "mysql", + "oracle", + "php framework", + "postgresql", + "sql", + "sqlite" + ], + "support": { + "issues": "https://github.com/catfan/Medoo/issues", + "source": "https://github.com/catfan/Medoo" + }, + "funding": [ + { + "url": "https://paypal.me/AngelaonLai", + "type": "custom" + }, + { + "url": "https://opencollective.com/medoo", + "type": "open_collective" + } + ], + "time": "2024-02-03T11:28:59+00:00" + }, + { + "name": "graham-campbell/result-type", + "version": "v1.1.3", + "source": { + "type": "git", + "url": "https://github.com/GrahamCampbell/Result-Type.git", + "reference": "3ba905c11371512af9d9bdd27d99b782216b6945" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/GrahamCampbell/Result-Type/zipball/3ba905c11371512af9d9bdd27d99b782216b6945", + "reference": "3ba905c11371512af9d9bdd27d99b782216b6945", + "shasum": "" + }, + "require": { + "php": "^7.2.5 || ^8.0", + "phpoption/phpoption": "^1.9.3" + }, + "require-dev": { + "phpunit/phpunit": "^8.5.39 || ^9.6.20 || ^10.5.28" + }, + "type": "library", + "autoload": { + "psr-4": { + "GrahamCampbell\\ResultType\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Graham Campbell", + "email": "hello@gjcampbell.co.uk", + "homepage": "https://github.com/GrahamCampbell" + } + ], + "description": "An Implementation Of The Result Type", + "keywords": [ + "Graham Campbell", + "GrahamCampbell", + "Result Type", + "Result-Type", + "result" + ], + "support": { + "issues": "https://github.com/GrahamCampbell/Result-Type/issues", + "source": "https://github.com/GrahamCampbell/Result-Type/tree/v1.1.3" + }, + "funding": [ + { + "url": "https://github.com/GrahamCampbell", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/graham-campbell/result-type", + "type": "tidelift" + } + ], + "time": "2024-07-20T21:45:45+00:00" + }, + { + "name": "monolog/monolog", + "version": "3.7.0", + "source": { + "type": "git", + "url": "https://github.com/Seldaek/monolog.git", + "reference": "f4393b648b78a5408747de94fca38beb5f7e9ef8" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/Seldaek/monolog/zipball/f4393b648b78a5408747de94fca38beb5f7e9ef8", + "reference": "f4393b648b78a5408747de94fca38beb5f7e9ef8", + "shasum": "" + }, + "require": { + "php": ">=8.1", + "psr/log": "^2.0 || ^3.0" + }, + "provide": { + "psr/log-implementation": "3.0.0" + }, + "require-dev": { + "aws/aws-sdk-php": "^3.0", + "doctrine/couchdb": "~1.0@dev", + "elasticsearch/elasticsearch": "^7 || ^8", + "ext-json": "*", + "graylog2/gelf-php": "^1.4.2 || ^2.0", + "guzzlehttp/guzzle": "^7.4.5", + "guzzlehttp/psr7": "^2.2", + "mongodb/mongodb": "^1.8", + "php-amqplib/php-amqplib": "~2.4 || ^3", + "phpstan/phpstan": "^1.9", + "phpstan/phpstan-deprecation-rules": "^1.0", + "phpstan/phpstan-strict-rules": "^1.4", + "phpunit/phpunit": "^10.5.17", + "predis/predis": "^1.1 || ^2", + "ruflin/elastica": "^7", + "symfony/mailer": "^5.4 || ^6", + "symfony/mime": "^5.4 || ^6" + }, + "suggest": { + "aws/aws-sdk-php": "Allow sending log messages to AWS services like DynamoDB", + "doctrine/couchdb": "Allow sending log messages to a CouchDB server", + "elasticsearch/elasticsearch": "Allow sending log messages to an Elasticsearch server via official client", + "ext-amqp": "Allow sending log messages to an AMQP server (1.0+ required)", + "ext-curl": "Required to send log messages using the IFTTTHandler, the LogglyHandler, the SendGridHandler, the SlackWebhookHandler or the TelegramBotHandler", + "ext-mbstring": "Allow to work properly with unicode symbols", + "ext-mongodb": "Allow sending log messages to a MongoDB server (via driver)", + "ext-openssl": "Required to send log messages using SSL", + "ext-sockets": "Allow sending log messages to a Syslog server (via UDP driver)", + "graylog2/gelf-php": "Allow sending log messages to a GrayLog2 server", + "mongodb/mongodb": "Allow sending log messages to a MongoDB server (via library)", + "php-amqplib/php-amqplib": "Allow sending log messages to an AMQP server using php-amqplib", + "rollbar/rollbar": "Allow sending log messages to Rollbar", + "ruflin/elastica": "Allow sending log messages to an Elastic Search server" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-main": "3.x-dev" + } + }, + "autoload": { + "psr-4": { + "Monolog\\": "src/Monolog" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Jordi Boggiano", + "email": "j.boggiano@seld.be", + "homepage": "https://seld.be" + } + ], + "description": "Sends your logs to files, sockets, inboxes, databases and various web services", + "homepage": "https://github.com/Seldaek/monolog", + "keywords": [ + "log", + "logging", + "psr-3" + ], + "support": { + "issues": "https://github.com/Seldaek/monolog/issues", + "source": "https://github.com/Seldaek/monolog/tree/3.7.0" + }, + "funding": [ + { + "url": "https://github.com/Seldaek", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/monolog/monolog", + "type": "tidelift" + } + ], + "time": "2024-06-28T09:40:51+00:00" + }, + { + "name": "phpoption/phpoption", + "version": "1.9.3", + "source": { + "type": "git", + "url": "https://github.com/schmittjoh/php-option.git", + "reference": "e3fac8b24f56113f7cb96af14958c0dd16330f54" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/schmittjoh/php-option/zipball/e3fac8b24f56113f7cb96af14958c0dd16330f54", + "reference": "e3fac8b24f56113f7cb96af14958c0dd16330f54", + "shasum": "" + }, + "require": { + "php": "^7.2.5 || ^8.0" + }, + "require-dev": { + "bamarni/composer-bin-plugin": "^1.8.2", + "phpunit/phpunit": "^8.5.39 || ^9.6.20 || ^10.5.28" + }, + "type": "library", + "extra": { + "bamarni-bin": { + "bin-links": true, + "forward-command": false + }, + "branch-alias": { + "dev-master": "1.9-dev" + } + }, + "autoload": { + "psr-4": { + "PhpOption\\": "src/PhpOption/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "Apache-2.0" + ], + "authors": [ + { + "name": "Johannes M. Schmitt", + "email": "schmittjoh@gmail.com", + "homepage": "https://github.com/schmittjoh" + }, + { + "name": "Graham Campbell", + "email": "hello@gjcampbell.co.uk", + "homepage": "https://github.com/GrahamCampbell" + } + ], + "description": "Option Type for PHP", + "keywords": [ + "language", + "option", + "php", + "type" + ], + "support": { + "issues": "https://github.com/schmittjoh/php-option/issues", + "source": "https://github.com/schmittjoh/php-option/tree/1.9.3" + }, + "funding": [ + { + "url": "https://github.com/GrahamCampbell", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/phpoption/phpoption", + "type": "tidelift" + } + ], + "time": "2024-07-20T21:41:07+00:00" + }, + { + "name": "psr/log", + "version": "3.0.2", + "source": { + "type": "git", + "url": "https://github.com/php-fig/log.git", + "reference": "f16e1d5863e37f8d8c2a01719f5b34baa2b714d3" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/php-fig/log/zipball/f16e1d5863e37f8d8c2a01719f5b34baa2b714d3", + "reference": "f16e1d5863e37f8d8c2a01719f5b34baa2b714d3", + "shasum": "" + }, + "require": { + "php": ">=8.0.0" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "3.x-dev" + } + }, + "autoload": { + "psr-4": { + "Psr\\Log\\": "src" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "PHP-FIG", + "homepage": "https://www.php-fig.org/" + } + ], + "description": "Common interface for logging libraries", + "homepage": "https://github.com/php-fig/log", + "keywords": [ + "log", + "psr", + "psr-3" + ], + "support": { + "source": "https://github.com/php-fig/log/tree/3.0.2" + }, + "time": "2024-09-11T13:17:53+00:00" + }, + { + "name": "symfony/http-foundation", + "version": "v7.1.7", + "source": { + "type": "git", + "url": "https://github.com/symfony/http-foundation.git", + "reference": "5183b61657807099d98f3367bcccb850238b17a9" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/http-foundation/zipball/5183b61657807099d98f3367bcccb850238b17a9", + "reference": "5183b61657807099d98f3367bcccb850238b17a9", + "shasum": "" + }, + "require": { + "php": ">=8.2", + "symfony/polyfill-mbstring": "~1.1", + "symfony/polyfill-php83": "^1.27" + }, + "conflict": { + "doctrine/dbal": "<3.6", + "symfony/cache": "<6.4" + }, + "require-dev": { + "doctrine/dbal": "^3.6|^4", + "predis/predis": "^1.1|^2.0", + "symfony/cache": "^6.4|^7.0", + "symfony/dependency-injection": "^6.4|^7.0", + "symfony/expression-language": "^6.4|^7.0", + "symfony/http-kernel": "^6.4|^7.0", + "symfony/mime": "^6.4|^7.0", + "symfony/rate-limiter": "^6.4|^7.0" + }, + "type": "library", + "autoload": { + "psr-4": { + "Symfony\\Component\\HttpFoundation\\": "" + }, + "exclude-from-classmap": [ + "/Tests/" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Defines an object-oriented layer for the HTTP specification", + "homepage": "https://symfony.com", + "support": { + "source": "https://github.com/symfony/http-foundation/tree/v7.1.7" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-11-06T09:02:46+00:00" + }, + { + "name": "symfony/polyfill-ctype", + "version": "v1.31.0", + "source": { + "type": "git", + "url": "https://github.com/symfony/polyfill-ctype.git", + "reference": "a3cc8b044a6ea513310cbd48ef7333b384945638" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/polyfill-ctype/zipball/a3cc8b044a6ea513310cbd48ef7333b384945638", + "reference": "a3cc8b044a6ea513310cbd48ef7333b384945638", + "shasum": "" + }, + "require": { + "php": ">=7.2" + }, + "provide": { + "ext-ctype": "*" + }, + "suggest": { + "ext-ctype": "For best performance" + }, + "type": "library", + "extra": { + "thanks": { + "name": "symfony/polyfill", + "url": "https://github.com/symfony/polyfill" + } + }, + "autoload": { + "files": [ + "bootstrap.php" + ], + "psr-4": { + "Symfony\\Polyfill\\Ctype\\": "" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Gert de Pagter", + "email": "BackEndTea@gmail.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Symfony polyfill for ctype functions", + "homepage": "https://symfony.com", + "keywords": [ + "compatibility", + "ctype", + "polyfill", + "portable" + ], + "support": { + "source": "https://github.com/symfony/polyfill-ctype/tree/v1.31.0" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-09-09T11:45:10+00:00" + }, + { + "name": "symfony/polyfill-mbstring", + "version": "v1.31.0", + "source": { + "type": "git", + "url": "https://github.com/symfony/polyfill-mbstring.git", + "reference": "85181ba99b2345b0ef10ce42ecac37612d9fd341" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/polyfill-mbstring/zipball/85181ba99b2345b0ef10ce42ecac37612d9fd341", + "reference": "85181ba99b2345b0ef10ce42ecac37612d9fd341", + "shasum": "" + }, + "require": { + "php": ">=7.2" + }, + "provide": { + "ext-mbstring": "*" + }, + "suggest": { + "ext-mbstring": "For best performance" + }, + "type": "library", + "extra": { + "thanks": { + "name": "symfony/polyfill", + "url": "https://github.com/symfony/polyfill" + } + }, + "autoload": { + "files": [ + "bootstrap.php" + ], + "psr-4": { + "Symfony\\Polyfill\\Mbstring\\": "" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Nicolas Grekas", + "email": "p@tchwork.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Symfony polyfill for the Mbstring extension", + "homepage": "https://symfony.com", + "keywords": [ + "compatibility", + "mbstring", + "polyfill", + "portable", + "shim" + ], + "support": { + "source": "https://github.com/symfony/polyfill-mbstring/tree/v1.31.0" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-09-09T11:45:10+00:00" + }, + { + "name": "symfony/polyfill-php80", + "version": "v1.31.0", + "source": { + "type": "git", + "url": "https://github.com/symfony/polyfill-php80.git", + "reference": "60328e362d4c2c802a54fcbf04f9d3fb892b4cf8" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/polyfill-php80/zipball/60328e362d4c2c802a54fcbf04f9d3fb892b4cf8", + "reference": "60328e362d4c2c802a54fcbf04f9d3fb892b4cf8", + "shasum": "" + }, + "require": { + "php": ">=7.2" + }, + "type": "library", + "extra": { + "thanks": { + "name": "symfony/polyfill", + "url": "https://github.com/symfony/polyfill" + } + }, + "autoload": { + "files": [ + "bootstrap.php" + ], + "psr-4": { + "Symfony\\Polyfill\\Php80\\": "" + }, + "classmap": [ + "Resources/stubs" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Ion Bazan", + "email": "ion.bazan@gmail.com" + }, + { + "name": "Nicolas Grekas", + "email": "p@tchwork.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Symfony polyfill backporting some PHP 8.0+ features to lower PHP versions", + "homepage": "https://symfony.com", + "keywords": [ + "compatibility", + "polyfill", + "portable", + "shim" + ], + "support": { + "source": "https://github.com/symfony/polyfill-php80/tree/v1.31.0" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-09-09T11:45:10+00:00" + }, + { + "name": "symfony/polyfill-php83", + "version": "v1.31.0", + "source": { + "type": "git", + "url": "https://github.com/symfony/polyfill-php83.git", + "reference": "2fb86d65e2d424369ad2905e83b236a8805ba491" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/polyfill-php83/zipball/2fb86d65e2d424369ad2905e83b236a8805ba491", + "reference": "2fb86d65e2d424369ad2905e83b236a8805ba491", + "shasum": "" + }, + "require": { + "php": ">=7.2" + }, + "type": "library", + "extra": { + "thanks": { + "name": "symfony/polyfill", + "url": "https://github.com/symfony/polyfill" + } + }, + "autoload": { + "files": [ + "bootstrap.php" + ], + "psr-4": { + "Symfony\\Polyfill\\Php83\\": "" + }, + "classmap": [ + "Resources/stubs" + ] + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Nicolas Grekas", + "email": "p@tchwork.com" + }, + { + "name": "Symfony Community", + "homepage": "https://symfony.com/contributors" + } + ], + "description": "Symfony polyfill backporting some PHP 8.3+ features to lower PHP versions", + "homepage": "https://symfony.com", + "keywords": [ + "compatibility", + "polyfill", + "portable", + "shim" + ], + "support": { + "source": "https://github.com/symfony/polyfill-php83/tree/v1.31.0" + }, + "funding": [ + { + "url": "https://symfony.com/sponsor", + "type": "custom" + }, + { + "url": "https://github.com/fabpot", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/symfony/symfony", + "type": "tidelift" + } + ], + "time": "2024-09-09T11:45:10+00:00" + }, + { + "name": "vlucas/phpdotenv", + "version": "v5.6.1", + "source": { + "type": "git", + "url": "https://github.com/vlucas/phpdotenv.git", + "reference": "a59a13791077fe3d44f90e7133eb68e7d22eaff2" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/vlucas/phpdotenv/zipball/a59a13791077fe3d44f90e7133eb68e7d22eaff2", + "reference": "a59a13791077fe3d44f90e7133eb68e7d22eaff2", + "shasum": "" + }, + "require": { + "ext-pcre": "*", + "graham-campbell/result-type": "^1.1.3", + "php": "^7.2.5 || ^8.0", + "phpoption/phpoption": "^1.9.3", + "symfony/polyfill-ctype": "^1.24", + "symfony/polyfill-mbstring": "^1.24", + "symfony/polyfill-php80": "^1.24" + }, + "require-dev": { + "bamarni/composer-bin-plugin": "^1.8.2", + "ext-filter": "*", + "phpunit/phpunit": "^8.5.34 || ^9.6.13 || ^10.4.2" + }, + "suggest": { + "ext-filter": "Required to use the boolean validator." + }, + "type": "library", + "extra": { + "bamarni-bin": { + "bin-links": true, + "forward-command": false + }, + "branch-alias": { + "dev-master": "5.6-dev" + } + }, + "autoload": { + "psr-4": { + "Dotenv\\": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "BSD-3-Clause" + ], + "authors": [ + { + "name": "Graham Campbell", + "email": "hello@gjcampbell.co.uk", + "homepage": "https://github.com/GrahamCampbell" + }, + { + "name": "Vance Lucas", + "email": "vance@vancelucas.com", + "homepage": "https://github.com/vlucas" + } + ], + "description": "Loads environment variables from `.env` to `getenv()`, `$_ENV` and `$_SERVER` automagically.", + "keywords": [ + "dotenv", + "env", + "environment" + ], + "support": { + "issues": "https://github.com/vlucas/phpdotenv/issues", + "source": "https://github.com/vlucas/phpdotenv/tree/v5.6.1" + }, + "funding": [ + { + "url": "https://github.com/GrahamCampbell", + "type": "github" + }, + { + "url": "https://tidelift.com/funding/github/packagist/vlucas/phpdotenv", + "type": "tidelift" + } + ], + "time": "2024-07-20T21:52:34+00:00" + } + ], + "packages-dev": [], + "aliases": [], + "minimum-stability": "stable", + "stability-flags": [], + "prefer-stable": false, + "prefer-lowest": false, + "platform": [], + "platform-dev": [], + "plugin-api-version": "2.3.0" +} diff --git a/schema.sql b/schema.sql new file mode 100644 index 0000000..aed93ee --- /dev/null +++ b/schema.sql @@ -0,0 +1,181 @@ +CREATE DATABASE IF NOT EXISTS finanzas_personales + CHARACTER SET utf8mb4 + COLLATE utf8mb4_unicode_ci; + +USE finanzas_personales; + +CREATE TABLE estados_usuario ( + id INT AUTO_INCREMENT PRIMARY KEY, + nombre VARCHAR(50) NOT NULL UNIQUE +) ENGINE=InnoDB; + +INSERT INTO estados_usuario (nombre) VALUES +('ACTIVO'), +('INACTIVO'), +('BLOQUEADO'); + +CREATE TABLE tipos_transaccion ( + id INT AUTO_INCREMENT PRIMARY KEY, + nombre VARCHAR(50) NOT NULL UNIQUE, + descripcion VARCHAR(255) +) ENGINE=InnoDB; + +INSERT INTO tipos_transaccion (nombre, descripcion) VALUES +('INGRESO', 'Dinero que entra a la cuenta'), +('EGRESO', 'Dinero que sale de la cuenta'); + +CREATE TABLE monedas ( + id INT AUTO_INCREMENT PRIMARY KEY, + codigo CHAR(3) NOT NULL UNIQUE, + nombre VARCHAR(50) NOT NULL, + simbolo VARCHAR(10), + pais VARCHAR(50) +) ENGINE=InnoDB; + +INSERT INTO monedas (codigo, nombre, simbolo, pais) VALUES +('USD', 'Dólar Estadounidense', '$', 'Estados Unidos'), +('EUR', 'Euro', '€', 'Unión Europea'), +('MXN', 'Peso Mexicano', '$', 'México'), +('COP', 'Peso Colombiano', '$', 'Colombia'), +('GTQ', 'Quetzal', 'Q', 'Guatemala'); + +CREATE TABLE periodos ( + id INT AUTO_INCREMENT PRIMARY KEY, + nombre VARCHAR(20) NOT NULL UNIQUE, + descripcion VARCHAR(255) +) ENGINE=InnoDB; + +INSERT INTO periodos (nombre, descripcion) VALUES +('MENSUAL', 'Cada mes'), +('ANUAL', 'Cada año'); + +CREATE TABLE tipos_cuenta ( + id INT AUTO_INCREMENT PRIMARY KEY, + nombre VARCHAR(50) NOT NULL UNIQUE, + descripcion VARCHAR(255) +) ENGINE=InnoDB; + +INSERT INTO tipos_cuenta (nombre, descripcion) VALUES +('EFECTIVO', 'Dinero en efectivo'), +('BANCARIA', 'Cuenta bancaria'), +('INVERSION', 'Cuenta de inversión'), +('CREDITO', 'Tarjeta de crédito'); + +CREATE TABLE usuarios ( + id BIGINT UNSIGNED AUTO_INCREMENT PRIMARY KEY, + nombre VARCHAR(100) NOT NULL, + email VARCHAR(150) NOT NULL UNIQUE, + contraseña VARCHAR(255) NOT NULL, + fecha_creacion TIMESTAMP DEFAULT CURRENT_TIMESTAMP, + ultima_conexion TIMESTAMP NULL, + estado_id INT NOT NULL DEFAULT 1, + FOREIGN KEY (estado_id) REFERENCES estados_usuario(id), + INDEX (email) +) ENGINE=InnoDB; + +CREATE TABLE categorias ( + id INT AUTO_INCREMENT PRIMARY KEY, + nombre VARCHAR(100) NOT NULL, + descripcion VARCHAR(255), + tipo_transaccion_id INT NOT NULL, + FOREIGN KEY (tipo_transaccion_id) REFERENCES tipos_transaccion(id), + UNIQUE (nombre, tipo_transaccion_id), + INDEX (tipo_transaccion_id) +) ENGINE=InnoDB; + +INSERT INTO categorias (nombre, descripcion, tipo_transaccion_id) VALUES +('SALARIO', 'Ingresos por salario', 1), +('VENTA', 'Ingresos por ventas', 1), +('ALQUILER', 'Gasto en alquiler', 2), +('COMIDA', 'Gasto en alimentos', 2), +('TRANSPORTE', 'Gasto en transporte', 2), +('ENTRETENIMIENTO', 'Gasto en entretenimiento', 2); + +CREATE TABLE cuentas ( + id BIGINT UNSIGNED AUTO_INCREMENT PRIMARY KEY, + usuario_id BIGINT UNSIGNED NOT NULL, + nombre VARCHAR(100) NOT NULL, + tipo_cuenta_id INT NOT NULL, + moneda_id INT NOT NULL, + saldo DECIMAL(20, 4) NOT NULL DEFAULT 0.0000, + fecha_creacion TIMESTAMP DEFAULT CURRENT_TIMESTAMP, + FOREIGN KEY (usuario_id) REFERENCES usuarios(id) ON DELETE CASCADE, + FOREIGN KEY (tipo_cuenta_id) REFERENCES tipos_cuenta(id), + FOREIGN KEY (moneda_id) REFERENCES monedas(id), + INDEX (usuario_id), + INDEX (tipo_cuenta_id), + INDEX (moneda_id) +) ENGINE=InnoDB; + +CREATE TABLE transacciones ( + id BIGINT UNSIGNED AUTO_INCREMENT PRIMARY KEY, + usuario_id BIGINT UNSIGNED NOT NULL, + tipo_transaccion_id INT NOT NULL, + categoria_id INT NOT NULL, + monto DECIMAL(10, 2) NOT NULL, + moneda_id INT NOT NULL, + fecha DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP, + descripcion VARCHAR(255), + fecha_creacion TIMESTAMP DEFAULT CURRENT_TIMESTAMP, + fecha_actualizacion TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, + FOREIGN KEY (usuario_id) REFERENCES usuarios(id) ON DELETE CASCADE, + FOREIGN KEY (tipo_transaccion_id) REFERENCES tipos_transaccion(id), + FOREIGN KEY (categoria_id) REFERENCES categorias(id), + FOREIGN KEY (moneda_id) REFERENCES monedas(id), + INDEX (usuario_id), + INDEX (tipo_transaccion_id), + INDEX (categoria_id), + INDEX (moneda_id), + INDEX (fecha) +) ENGINE=InnoDB; + +CREATE TABLE presupuestos ( + id BIGINT UNSIGNED AUTO_INCREMENT PRIMARY KEY, + usuario_id BIGINT UNSIGNED NOT NULL, + categoria_id INT NOT NULL, + monto DECIMAL(10, 2) NOT NULL, + periodo_id INT NOT NULL, + fecha_inicio DATE NOT NULL, + fecha_fin DATE NOT NULL, + fecha_creacion TIMESTAMP DEFAULT CURRENT_TIMESTAMP, + fecha_actualizacion TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, + FOREIGN KEY (usuario_id) REFERENCES usuarios(id) ON DELETE CASCADE, + FOREIGN KEY (categoria_id) REFERENCES categorias(id), + FOREIGN KEY (periodo_id) REFERENCES periodos(id), + INDEX (usuario_id), + INDEX (categoria_id), + INDEX (periodo_id), + INDEX (fecha_inicio), + INDEX (fecha_fin) +) ENGINE=InnoDB; + +-- ============================================ +-- Índices Adicionales para Optimización +-- ============================================ + +-- Índice para consultas de transacciones por usuario y fecha +CREATE INDEX idx_transacciones_usuario_fecha ON transacciones(usuario_id, fecha); + +-- Índice para consultas de transacciones por categoría y monto +CREATE INDEX idx_transacciones_categoria_monto ON transacciones(categoria_id, monto); + +-- Índice para consultas de presupuestos por usuario y periodo +CREATE INDEX idx_presupuestos_usuario_periodo ON presupuestos(usuario_id, periodo_id); + +-- Optimiza búsquedas por fechas de inicio y fin de presupuestos +CREATE INDEX idx_presupuestos_fechas ON presupuestos(fecha_inicio, fecha_fin); + +-- Índice para consultas de transacciones por moneda +CREATE INDEX idx_transacciones_moneda ON transacciones(moneda_id); + +-- Optimiza búsquedas por estado y fecha de última conexión +CREATE INDEX idx_usuarios_estado ON usuarios(estado_id, ultima_conexion); + +-- Optimiza búsquedas por fecha de creación +CREATE INDEX idx_usuarios_fecha_creacion ON usuarios(fecha_creacion); + +-- Optimiza búsquedas de cuentas por tipo y saldo +CREATE INDEX idx_cuentas_tipo_saldo ON cuentas(tipo_cuenta_id, saldo); + +-- Optimiza búsquedas por fecha de creación y saldo +CREATE INDEX idx_cuentas_fecha_saldo ON cuentas(fecha_creacion, saldo); \ No newline at end of file