diff --git a/README.md b/README.md index 7c7d025a..dc545adb 100644 --- a/README.md +++ b/README.md @@ -1,119 +1,225 @@ # Capture The Flag -[![CTF](https://img.shields.io/badge/Capture%20The%20Flag-SA:MP-red)](https://github.com/MrDave1999/Capture-the-flag) -[![CTF](https://img.shields.io/badge/.NET%20Core-SampSharp.net-blue)](https://github.com/MrDave1999/Capture-the-flag) -[![CTF](https://img.shields.io/badge/GameMode-CSharp-yellow)](https://github.com/MrDave1999/Capture-the-flag) -[![CTF](https://img.shields.io/badge/Team%20DeathMatch-+Ranks-green)](https://github.com/MrDave1999/Capture-the-flag) - -**Capture The Flag** is a gamemode for [SA-MP](https://www.sa-mp.mp) (San Andreas Multiplayer, a multiplayer mod for GTA San Andreas) created with [sampsharp](https://github.com/ikkentim/SampSharp). -Capture The Flag is a style of play in which two teams try to catch a flag and carry it to a certain location to score points. -To play, players are divided into two teams (Alpha and Beta), each on a field. To earn points, you must capture the flag and take it to a certain location. -Currently, the gamemode has more than 10 maps and every 20 minutes there is a map change. - -In this video you can find a demo of how the gamemode is looking: https://youtu.be/yrPtJBuqB14 - -## Main features - -- The gamemode has more than 10 maps. Every 20 minutes the map will be changed. -- Every time you capture, recover and carry the flag, the player will earn a percentage of adrenaline. That "adrenaline" can be changed for some benefit with the `/combos` command or the H key. Some benefits that the player can redeem are: Invisibility, Jumps, Speed. -- You can create your own weapon pack with the `/weapons` command (or with the Y key). For each respawn, you will have the same weapons. -- You can remove a weapon from your weapon pack with the `/packet` command. -- The gamemode has a killing sprees system. This way, players will know if any player has had a good killing streak. -- The gamemode has a save system with MySQL `8.0.22`. So that players can create their account and save their statistics. -- You can talk to your team members "privately" using the exclamation point (!). - Example: `!hello guys`. -- The gamemode has a basic VIP system with 3 levels: Silver, Gold and Premium. -- The gamemode has a basic administration system with 4 levels: Assistant, Moderator, Administrator and Owner. -- Each player has their own rank. The gamemode has 15 ranks that are obtained for a certain amount of kills. - You can see the available ranges with the `/ranks` command. -- You can see the top 10 players in terms of kills, deaths, dropped flags, headshots and killing sprees with the `/top` command. - -## Deployment with Docker - -**1.** Clone the repository: -```sh -git clone https://github.com/MrDave1999/Capture-The-Flag.git -``` -**2.** Change directory: -```sh -cd Capture-The-Flag -``` -**3.** Copy the contents of `.env.example` to `.env`: -**On Linux:** -```sh -cp .env.example .env -``` -**On Windows:** -```sh -copy .env.example .env -``` +![SA-MP logo](https://github.com/user-attachments/assets/dd12935e-5897-470b-ab06-a72b492a521c) -**4.** Build the image and initiate services: -```sh -docker-compose up --build -d -``` -**5.** Add the server IP in your SA-MP client: -``` -localhost:7777 -``` +

+ + + + + + + + + + + + + + + +

-## Deployment without Docker +

+ + + +

-**1.** You must download the SA-MP server [here](https://github.com/MrDave1999/Capture-The-Flag/releases/latest) (choose the `.zip` file depending on the operating system you use.). +**Capture The Flag** is a game mode for [SA-MP](https://www.sa-mp.mp) (San Andreas Multiplayer, a multiplayer mod for GTA San Andreas) created with [SampSharp](https://github.com/ikkentim/SampSharp). +There are 2 flags on the map, one for each team. Players need to capture the enemy's flag and bring it back to their own one. -**2.** Once downloaded, modify the `.env` file according to your needs (for example, you need to specify the credentials you will use to connect to the database). +## Index +- [About](#about) +- [Screenshots](#screenshots) +- [Technologies used](#technologies-used) + - [Programming Languages](#programming-languages) + - [Softwares](#softwares) + - [Frameworks and libraries](#frameworks-and-libraries) + - [Testing](#testing) + - [Own libraries](#own-libraries) +- [Software Engineering](#software-engineering) +- [Installation](#installation) +- [Credentials](#credentials) +- [Supported RDBMS](#supported-rdbms) +- [Architectural overview](#architectural-overview) +- [Credits](#credits) + - [Mappers](#mappers) +- [Contribution](#contribution) -**3.** Download [MySQL Server 8.0](https://dev.mysql.com/downloads/mysql/). +## About -**4.** You must create the database: -```sql -CREATE DATABASE gamemode; -``` -**5.** You must import the database: -```sql -mysql -h localhost -u MyUserName -p gamemode < gamemode.sql -``` -**6.** This step should only be followed if you are using a Linux distribution. You need to install certain **32-bit packages** to be able to run the samp-server without problems. +The Beta team plays against the Alpha team. The aim is to carry the enemy's flag to the spawn of the own flag. The own flag needs to be at the spawn to score. So you have to conquer the opponent's flag and defend your own team's one at the same time. It's necassary for the whole team to work together tactically to win. + +The team which which got more points after x minutes wins. If both teams have the same points after the time is up, it's a draw. + +Beware! Enemies will see flag carriers on their radar as well! + +In this video, you can watch a gameplay demo: https://youtu.be/yrPtJBuqB14 + +## Screenshots + +
+sa-mp-000 + +![sa-mp-000](https://github.com/MrDave1999/Capture-The-Flag/blob/dev/screenshots/sa-mp-000.png) +
+ +
+sa-mp-001 + +![sa-mp-001](https://github.com/MrDave1999/Capture-The-Flag/blob/dev/screenshots/sa-mp-001.png) +
+ +
+sa-mp-002 + +![sa-mp-002](https://github.com/MrDave1999/Capture-The-Flag/blob/dev/screenshots/sa-mp-002.png) +
+ +
+sa-mp-003 + +![sa-mp-003](https://github.com/MrDave1999/Capture-The-Flag/blob/dev/screenshots/sa-mp-003.png) +
+ +
+sa-mp-004 -An example in Ubuntu: +![sa-mp-004](https://github.com/MrDave1999/Capture-The-Flag/blob/dev/screenshots/sa-mp-004.png) +
+ +## Technologies used + +### Programming Languages +- [C Sharp](https://github.com/dotnet/csharplang) +- [Pawn](https://github.com/compuphase/pawn) + +### Softwares +- [.NET CLI](https://learn.microsoft.com/en-us/dotnet/core/tools) +- [SA-MP Server](https://www.sa-mp.mp/downloads) +- [Visual Studio 2022](https://visualstudio.microsoft.com) +- [vscode](https://github.com/microsoft/vscode) +- [MariaDB](https://github.com/mariadb) +- [SQLite](https://www.sqlite.org) +- [DB Browser for SQLite](https://sqlitebrowser.org) +- [HeidiSQL](https://github.com/HeidiSQL) +- [GitHub Actions](https://github.com/actions) +- [Git](https://git-scm.com) +- [Docker](https://github.com/docker) + +### Frameworks and libraries +- [.NET SDK 8.0](https://github.com/dotnet/runtime) +- [SampSharp](https://github.com/ikkentim/SampSharp) +- [samp-streamer-plugin](https://github.com/samp-incognito/samp-streamer-plugin) +- [SmartFormat](https://github.com/axuno/SmartFormat) +- [MySqlConnector](https://github.com/mysql-net/MySqlConnector) +- [Microsoft.Data.Sqlite](https://www.nuget.org/packages/Microsoft.Data.SQLite) +- [Microsoft.Extensions.DependencyInjection](https://www.nuget.org/packages/Microsoft.Extensions.DependencyInjection) +- [Microsoft.Extensions.Configuration.Binder](https://www.nuget.org/packages/Microsoft.Extensions.Configuration.Binder) +- [Microsoft.Extensions.Configuration.EnvironmentVariables](https://www.nuget.org/packages/Microsoft.Extensions.Configuration.EnvironmentVariables) +- [BCrypt.Net-Next](https://github.com/BcryptNet/bcrypt.net) + +### Testing +- [NUnit](https://github.com/nunit/nunit) +- [FluentAssertions](https://github.com/fluentassertions/fluentassertions) + +### Own libraries +- [DotEnv.Core](https://github.com/MrDave1999/dotenv.core) +- [YeSql.Net](https://github.com/ose-net/yesql.net) +- [seztion-parser](https://github.com/MrDave1999/seztion-parser) + +## Software Engineering + +Software engineering concepts have been applied in this project: +- [Entity–component–system (ECS)](https://en.wikipedia.org/wiki/Entity_component_system) +- [Object-oriented programming](https://en.wikipedia.org/wiki/Object-oriented_programming) +- [Interface-based programming](https://en.wikipedia.org/wiki/Interface-based_programming) +- [Modular programming](https://en.wikipedia.org/wiki/Modular_programming) +- [Dependency injection](https://en.wikipedia.org/wiki/Dependency_injection) +- [Operation Result Pattern](https://medium.com/@wgyxxbf/result-pattern-a01729f42f8c) +- [Guard Clause](https://deviq.com/design-patterns/guard-clause) +- [Open-closed principle](https://en.wikipedia.org/wiki/Open%E2%80%93closed_principle) +- [Explicit dependencies](https://deviq.com/principles/explicit-dependencies-principle) +- [Separation of concerns](https://en.wikipedia.org/wiki/Separation_of_concerns) + +## Installation + +In progress.. + +## Credentials + +The following table shows the default credentials for authentication from the game mode. + +| PlayerName | Password | +|-------------------------|-----------------------------| +| Admin_Player | 123456 | +| Moderator_Player | 123456 | +| VIP_Player | 123456 | +| Basic_Player | 123456 | + +Note that these credentials are only available if your database provider is **in-memory**. In your .env file you must indicate it as follows. ```sh -sudo dpkg --add-architecture i386 -sudo apt-get update && apt-get install libc6:i386 libstdc++6:i386 libssl1.1:i386 libicu-dev:i386 +DatabaseProvider=InMemory ``` -**7.** Finally run the samp-server and enjoy :) -## Frequently Asked Questions +## Supported RDBMS -#### How do I edit the connection string? +- [MariaDB](https://github.com/mariadb) +- [SQLite](https://github.com/sqlite/sqlite) -Go to the `.env` file and modify the `CONNECTION_STRING` key. +You must specify the name of the database provider from the .env file. -#### How can I become an administrator on the server? +Examples: +```sh +DatabaseProvider=MariaDB +``` +Or also +```sh +DatabaseProvider=SQLite +``` -Go to the `.env` file and modify the `HIDDEN_COMMAND` key, then log in in to the server and type the command. +If you choose to use MariaDB, you must specify the connection string in the .env file. +```sh +MariaDB__Server=localhost +MariaDB__Port=3306 +MariaDB__Database=gamemode +MariaDB__UserName=root +MariaDB__Password=123456789 +``` +Or, if you choose to use SQLite, you must specify the location of the database file. +```sh +SQLite__DataSource=C:\Users\dave\OneDrive\Desktop\gamemode.db +``` + +See the [example .env file](https://github.com/MrDave1999/Capture-The-Flag/blob/dev/.env.example) for more information. -#### How do I change the length of the game? +## Architectural overview -Go to the `.env` file and modify the `MAX_TIME_ROUND` key, the time must be expressed in `seconds`. +
+Show diagram -#### How can I change the timeout when the map is loading? +![overview](https://github.com/MrDave1999/Capture-The-Flag/blob/dev/screenshots/architectural-overview.png) -Go to the `.env` file and modify the `MAX_TIME_LOADING` key, the time must be expressed in `seconds`. +
-## Images -![image](https://user-images.githubusercontent.com/43916038/114632050-6d19fa80-9c83-11eb-812e-0241a288564d.png) -![image](https://user-images.githubusercontent.com/43916038/114632071-77d48f80-9c83-11eb-9ff5-61609b64289e.png) +### Main components +- **Application Core.** Contains all the logic of the game called "Capture the Flag", including the rules and procedures that define how the game is played. +- **Persistence layer.** Contains all data access logic. The purpose of this layer is to prevent the filtering of data access logic in the application core. +- **Host Application.** Contains everything needed to run the game mode. It represents the entry point of the application. + This layer performs other tasks such as: + - Load application settings from `.env` file. + - Select the database provider. + - Register services to DI Container. + - Add systems to the services collection. + - Enable desired ECS system features. ## Credits -- [ikkentim](https://github.com/ikkentim/SampSharp) by create SampSharp. -- [rickyah](https://github.com/rickyah/ini-parser) by create ini-parser. -- [Nickk888SAMP](https://github.com/Nickk888SAMP/TextDraw-Editor) by create NTD (TextDraw Editor). -- [samp-incognito](https://github.com/samp-incognito/samp-streamer-plugin) by create streamer-plugin. -- [MrDave1999](https://github.com/MrDave1999/Capture-The-Flag) by create gamemode. -- [Ts-Pytham](https://github.com/Ts-Pytham) for collaborating with the administration system. -- [IllidanS4](https://github.com/IllidanS4/YSF) by create YSF-plugin. -- [BlasterDv](https://github.com/BlasterDv/SampSharp-YSF) by create Wrapper SampSharp.YSF of the YSF plugin. +- [MrDave1999](https://github.com/MrDave1999/Capture-The-Flag) for creating the "Capture The Flag" game mode. +- [ikkentim](https://github.com/ikkentim/SampSharp) for creating the SampSharp framework. +- [Nickk888SAMP](https://github.com/Nickk888SAMP/TextDraw-Editor) for creating NTD (TextDraw Editor). +- [samp-incognito](https://github.com/samp-incognito/samp-streamer-plugin) for creating the streamer-plugin. ### Mappers @@ -140,3 +246,15 @@ Go to the `.env` file and modify the `MAX_TIME_LOADING` key, the time must be ex - ZM_Italy - Unknown. - zone_paintball by Famous. - mp_island by Leo. + +## Contribution + +Any contribution is welcome! Remember that you can contribute not only in the code, but also in the documentation or even improve the tests. + +Follow the steps below: + +- Fork it +- Create your custom branch (git checkout -b my-new-change) +- Commit your changes (git commit -am 'Add some change') +- Push to the branch (git push origin my-new-change) +- Create new Pull Request \ No newline at end of file diff --git a/screenshots/architectural-overview.png b/screenshots/architectural-overview.png new file mode 100644 index 00000000..3c29dbca Binary files /dev/null and b/screenshots/architectural-overview.png differ diff --git a/screenshots/sa-mp-000.png b/screenshots/sa-mp-000.png new file mode 100644 index 00000000..5031ac8d Binary files /dev/null and b/screenshots/sa-mp-000.png differ diff --git a/screenshots/sa-mp-001.png b/screenshots/sa-mp-001.png new file mode 100644 index 00000000..e20dc5aa Binary files /dev/null and b/screenshots/sa-mp-001.png differ diff --git a/screenshots/sa-mp-002.png b/screenshots/sa-mp-002.png new file mode 100644 index 00000000..d37f9b65 Binary files /dev/null and b/screenshots/sa-mp-002.png differ diff --git a/screenshots/sa-mp-003.png b/screenshots/sa-mp-003.png new file mode 100644 index 00000000..3029bff2 Binary files /dev/null and b/screenshots/sa-mp-003.png differ diff --git a/screenshots/sa-mp-005.png b/screenshots/sa-mp-005.png new file mode 100644 index 00000000..0523b475 Binary files /dev/null and b/screenshots/sa-mp-005.png differ