Skip to content
This repository was archived by the owner on Oct 23, 2024. It is now read-only.

Commit 0c03f57

Browse files
committed
init commit
0 parents  commit 0c03f57

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

59 files changed

+10256
-0
lines changed

.gitignore

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
.idea

Makefile

Lines changed: 21 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,21 @@
1+
DOCKER_COMPOSE=docker compose
2+
UP_SERVICE=$(DOCKER_COMPOSE) build --no-cache && $(DOCKER_COMPOSE) up -d && sleep 5
3+
RESTART_SERVICE=$(DOCKER_COMPOSE) restart
4+
EXEC_PHP_FPM=$(DOCKER_COMPOSE) exec php-fpm
5+
COMPOSER=bash -c "composer install" && sleep 5
6+
SEED=bash -c "php artisan migrate --force"
7+
8+
all: help
9+
build: ## Build and deploy project from scratch
10+
@echo "Build and bootstrap project..."
11+
$(UP_SERVICE)
12+
$(EXEC_PHP_FPM) $(COMPOSER)
13+
$(EXEC_PHP_FPM) $(SEED)
14+
composer: ## Install/update/delete composer libraries
15+
@echo "Running composer..."
16+
$(EXEC_PHP_FPM) $(COMPOSER)
17+
down: ## Shut down project but keep mysql db data
18+
@echo "Shutting down project..."
19+
$(DOCKER_COMPOSE) down --remove-orphans
20+
help:
21+
@grep -E '^[a-zA-Z_-]+:.*?## .*$$' $(MAKEFILE_LIST) | awk 'BEGIN {FS = ":.*?## "}; {printf "\033[36m%-30s\033[0m %s\n", $$1, $$2}'

README.md

Lines changed: 90 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,90 @@
1+
<div align="center">
2+
<h3 align="center">TechTest Laravel Application</h3>
3+
<a href="https://github.com/othneildrew/Best-README-Template">
4+
<img src="https://d15ywwv3do91l7.cloudfront.net/medium.webp" alt="Logo" width="80" height="80">
5+
</a>
6+
<p align="center">
7+
<br />
8+
<a href="http://ec2-54-185-223-128.us-west-2.compute.amazonaws.com" target="_blank">View Demo</a>
9+
</p>
10+
</div>
11+
12+
<!-- ABOUT THE PROJECT -->
13+
## About The Project
14+
15+
[![Product Name Screen Shot][product-screenshot]](http://ec2-54-185-223-128.us-west-2.compute.amazonaws.com/)
16+
17+
This repository contains a Dockerized Laravel application designed for local development. The cloud setup and deployment (AWS EC2, RDS, S3, CloudFront) were performed manually to save time. For the local environment, this setup provides a quick way to spin up and showcase the test assignment.
18+
19+
**Note**: My primary framework is Symfony, but for this test assignment, I opted to use Laravel as specified in the requirements.
20+
21+
<!-- GETTING STARTED -->
22+
## Getting Started
23+
24+
### Prerequisites
25+
26+
Ensure you have Docker and Docker Compose installed on your machine.
27+
28+
### Setup and Build
29+
30+
1. Clone the repo
31+
```sh
32+
git clone https://github.com/bumblecoder/tech-task.git
33+
cd tech-task
34+
cp code/.env.example code/.env
35+
```
36+
2. Build and start the Docker containers:
37+
```sh
38+
make build
39+
```
40+
This command will build and start the necessary Docker containers. The process may take some time.
41+
42+
3. Create the stored procedure:
43+
```sh
44+
make run-sql
45+
```
46+
This will execute the SQL script to set up the stored procedure in the MySQL container.
47+
48+
4. Access the application:
49+
50+
By default, the application will be available on port 80 of localhost. Ensure this port is available; otherwise, the build may fail.
51+
52+
Open your browser and go to http://localhost.
53+
54+
## AWS Test Environment
55+
56+
The application is also deployed on an AWS test environment for one week from the submission of the test assignment. After this period, the test environment will be removed.
57+
**AWS EC2 Instance URL:**
58+
59+
http://ec2-54-185-223-128.us-west-2.compute.amazonaws.com
60+
61+
AWS services used for deployment:
62+
63+
- EC2 (Elastic Compute Cloud)
64+
- RDS (Relational Database Service)
65+
- S3 (Simple Storage Service)
66+
- CloudFront (Content Delivery Network)
67+
- Configuration of Security Groups
68+
69+
## API Endpoints
70+
71+
The following API endpoints are available:
72+
73+
- GET /api/articles — Retrieve a list of all articles
74+
- POST /api/articles — Create a new article
75+
- GET /api/articles/{id} — Retrieve an article by ID
76+
- PUT|PATCH /api/articles/{id} — Update an article by ID
77+
- DELETE /api/articles/{id} — Delete an article by ID
78+
79+
## Tests
80+
![image](https://github.com/user-attachments/assets/f4c96200-52b7-45de-b640-abe5d86ccaa3)
81+
82+
83+
<!-- LICENSE -->
84+
## License
85+
86+
Distributed under the MIT License.
87+
88+
<!-- MARKDOWN LINKS & IMAGES -->
89+
<!-- https://www.markdownguide.org/basic-syntax/#reference-style-links -->
90+
[product-screenshot]: https://d15ywwv3do91l7.cloudfront.net/project_screenshot.png

code/.editorconfig

Lines changed: 18 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,18 @@
1+
root = true
2+
3+
[*]
4+
charset = utf-8
5+
end_of_line = lf
6+
indent_size = 4
7+
indent_style = space
8+
insert_final_newline = true
9+
trim_trailing_whitespace = true
10+
11+
[*.md]
12+
trim_trailing_whitespace = false
13+
14+
[*.{yml,yaml}]
15+
indent_size = 2
16+
17+
[docker-compose.yml]
18+
indent_size = 4

code/.env.example

Lines changed: 68 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,68 @@
1+
APP_NAME=Laravel
2+
APP_ENV=local
3+
APP_KEY=
4+
APP_DEBUG=true
5+
APP_TIMEZONE=UTC
6+
APP_URL=http://localhost
7+
8+
APP_LOCALE=en
9+
APP_FALLBACK_LOCALE=en
10+
APP_FAKER_LOCALE=en_US
11+
12+
APP_MAINTENANCE_DRIVER=file
13+
# APP_MAINTENANCE_STORE=database
14+
15+
PHP_CLI_SERVER_WORKERS=4
16+
17+
BCRYPT_ROUNDS=12
18+
19+
LOG_CHANNEL=stack
20+
LOG_STACK=single
21+
LOG_DEPRECATIONS_CHANNEL=null
22+
LOG_LEVEL=debug
23+
24+
DB_CONNECTION=sqlite
25+
# DB_HOST=127.0.0.1
26+
# DB_PORT=3306
27+
# DB_DATABASE=laravel
28+
# DB_USERNAME=root
29+
# DB_PASSWORD=
30+
31+
SESSION_DRIVER=database
32+
SESSION_LIFETIME=120
33+
SESSION_ENCRYPT=false
34+
SESSION_PATH=/
35+
SESSION_DOMAIN=null
36+
37+
BROADCAST_CONNECTION=log
38+
FILESYSTEM_DISK=local
39+
QUEUE_CONNECTION=database
40+
41+
CACHE_STORE=database
42+
CACHE_PREFIX=
43+
44+
MEMCACHED_HOST=127.0.0.1
45+
46+
REDIS_CLIENT=phpredis
47+
REDIS_HOST=127.0.0.1
48+
REDIS_PASSWORD=null
49+
REDIS_PORT=6379
50+
51+
MAIL_MAILER=log
52+
MAIL_HOST=127.0.0.1
53+
MAIL_PORT=2525
54+
MAIL_USERNAME=null
55+
MAIL_PASSWORD=null
56+
MAIL_ENCRYPTION=null
57+
MAIL_FROM_ADDRESS="[email protected]"
58+
MAIL_FROM_NAME="${APP_NAME}"
59+
60+
AWS_ACCESS_KEY_ID=
61+
AWS_SECRET_ACCESS_KEY=
62+
AWS_DEFAULT_REGION=us-east-1
63+
AWS_BUCKET=
64+
AWS_USE_PATH_STYLE_ENDPOINT=false
65+
66+
VITE_APP_NAME="${APP_NAME}"
67+
68+
TRANSACTION_DEVIATION=10

code/.gitattributes

Lines changed: 11 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,11 @@
1+
* text=auto eol=lf
2+
3+
*.blade.php diff=html
4+
*.css diff=css
5+
*.html diff=html
6+
*.md diff=markdown
7+
*.php diff=php
8+
9+
/.github export-ignore
10+
CHANGELOG.md export-ignore
11+
.styleci.yml export-ignore

code/.gitignore

Lines changed: 22 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,22 @@
1+
/.phpunit.cache
2+
/node_modules
3+
/public/build
4+
/public/hot
5+
/public/storage
6+
/storage/*.key
7+
/storage/pail
8+
/vendor
9+
.env
10+
.env.backup
11+
.env.production
12+
.phpactor.json
13+
.phpunit.result.cache
14+
Homestead.json
15+
Homestead.yaml
16+
auth.json
17+
npm-debug.log
18+
yarn-error.log
19+
/.fleet
20+
/.idea
21+
/.vscode
22+
/.zed

code/README.md

Lines changed: 66 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,66 @@
1+
<p align="center"><a href="https://laravel.com" target="_blank"><img src="https://raw.githubusercontent.com/laravel/art/master/logo-lockup/5%20SVG/2%20CMYK/1%20Full%20Color/laravel-logolockup-cmyk-red.svg" width="400" alt="Laravel Logo"></a></p>
2+
3+
<p align="center">
4+
<a href="https://github.com/laravel/framework/actions"><img src="https://github.com/laravel/framework/workflows/tests/badge.svg" alt="Build Status"></a>
5+
<a href="https://packagist.org/packages/laravel/framework"><img src="https://img.shields.io/packagist/dt/laravel/framework" alt="Total Downloads"></a>
6+
<a href="https://packagist.org/packages/laravel/framework"><img src="https://img.shields.io/packagist/v/laravel/framework" alt="Latest Stable Version"></a>
7+
<a href="https://packagist.org/packages/laravel/framework"><img src="https://img.shields.io/packagist/l/laravel/framework" alt="License"></a>
8+
</p>
9+
10+
## About Laravel
11+
12+
Laravel is a web application framework with expressive, elegant syntax. We believe development must be an enjoyable and creative experience to be truly fulfilling. Laravel takes the pain out of development by easing common tasks used in many web projects, such as:
13+
14+
- [Simple, fast routing engine](https://laravel.com/docs/routing).
15+
- [Powerful dependency injection container](https://laravel.com/docs/container).
16+
- Multiple back-ends for [session](https://laravel.com/docs/session) and [cache](https://laravel.com/docs/cache) storage.
17+
- Expressive, intuitive [database ORM](https://laravel.com/docs/eloquent).
18+
- Database agnostic [schema migrations](https://laravel.com/docs/migrations).
19+
- [Robust background job processing](https://laravel.com/docs/queues).
20+
- [Real-time event broadcasting](https://laravel.com/docs/broadcasting).
21+
22+
Laravel is accessible, powerful, and provides tools required for large, robust applications.
23+
24+
## Learning Laravel
25+
26+
Laravel has the most extensive and thorough [documentation](https://laravel.com/docs) and video tutorial library of all modern web application frameworks, making it a breeze to get started with the framework.
27+
28+
You may also try the [Laravel Bootcamp](https://bootcamp.laravel.com), where you will be guided through building a modern Laravel application from scratch.
29+
30+
If you don't feel like reading, [Laracasts](https://laracasts.com) can help. Laracasts contains thousands of video tutorials on a range of topics including Laravel, modern PHP, unit testing, and JavaScript. Boost your skills by digging into our comprehensive video library.
31+
32+
## Laravel Sponsors
33+
34+
We would like to extend our thanks to the following sponsors for funding Laravel development. If you are interested in becoming a sponsor, please visit the [Laravel Partners program](https://partners.laravel.com).
35+
36+
### Premium Partners
37+
38+
- **[Vehikl](https://vehikl.com/)**
39+
- **[Tighten Co.](https://tighten.co)**
40+
- **[WebReinvent](https://webreinvent.com/)**
41+
- **[Kirschbaum Development Group](https://kirschbaumdevelopment.com)**
42+
- **[64 Robots](https://64robots.com)**
43+
- **[Curotec](https://www.curotec.com/services/technologies/laravel/)**
44+
- **[Cyber-Duck](https://cyber-duck.co.uk)**
45+
- **[DevSquad](https://devsquad.com/hire-laravel-developers)**
46+
- **[Jump24](https://jump24.co.uk)**
47+
- **[Redberry](https://redberry.international/laravel/)**
48+
- **[Active Logic](https://activelogic.com)**
49+
- **[byte5](https://byte5.de)**
50+
- **[OP.GG](https://op.gg)**
51+
52+
## Contributing
53+
54+
Thank you for considering contributing to the Laravel framework! The contribution guide can be found in the [Laravel documentation](https://laravel.com/docs/contributions).
55+
56+
## Code of Conduct
57+
58+
In order to ensure that the Laravel community is welcoming to all, please review and abide by the [Code of Conduct](https://laravel.com/docs/contributions#code-of-conduct).
59+
60+
## Security Vulnerabilities
61+
62+
If you discover a security vulnerability within Laravel, please send an e-mail to Taylor Otwell via [[email protected]](mailto:[email protected]). All security vulnerabilities will be promptly addressed.
63+
64+
## License
65+
66+
The Laravel framework is open-sourced software licensed under the [MIT license](https://opensource.org/licenses/MIT).

code/artisan

Lines changed: 15 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,15 @@
1+
#!/usr/bin/env php
2+
<?php
3+
4+
use Symfony\Component\Console\Input\ArgvInput;
5+
6+
define('LARAVEL_START', microtime(true));
7+
8+
// Register the Composer autoloader...
9+
require __DIR__.'/vendor/autoload.php';
10+
11+
// Bootstrap Laravel and handle the command...
12+
$status = (require_once __DIR__.'/bootstrap/app.php')
13+
->handleCommand(new ArgvInput);
14+
15+
exit($status);

code/bootstrap/app.php

Lines changed: 18 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,18 @@
1+
<?php
2+
3+
use Illuminate\Foundation\Application;
4+
use Illuminate\Foundation\Configuration\Exceptions;
5+
use Illuminate\Foundation\Configuration\Middleware;
6+
7+
return Application::configure(basePath: dirname(__DIR__))
8+
->withRouting(
9+
web: __DIR__.'/../routes/web.php',
10+
commands: __DIR__.'/../routes/console.php',
11+
health: '/up',
12+
)
13+
->withMiddleware(function (Middleware $middleware) {
14+
//
15+
})
16+
->withExceptions(function (Exceptions $exceptions) {
17+
//
18+
})->create();

0 commit comments

Comments
 (0)