Skip to content

Latest commit

 

History

History
192 lines (138 loc) · 8.29 KB

README.md

File metadata and controls

192 lines (138 loc) · 8.29 KB

DigitalKataclysm

Laravel inspired Framework for small projects.

Working with PHP it tries to emulate how frameworks such as Laravel works, but in their minimal state and the maximun code reach. Its not intended for final users or huge projects (not yet), but in the future it can take that path.

You will see that there are a lot of similarities with Laravel, and a lot of methods with the same name; but this does not mean that it works exactly the same. This familiar code will help usual Laravel developers to get use to this framework, and at the same time, get to know its differences.

The real objective of this project is not to become popular, or replace other MVC such as Laravel, but to offer another lightweight option for those sites that does not require so much code power, but still want to keep its common structure.

Requirements

This framework was made using PHP 7.1. That means that we are not providing backward compatibility with older versions of PHP (Sorry, we have to aim for the future).

Environment

I recommend using Linux Based servers to work with PHP since Microsoft Windows Servers are kind of hard to set up with PHP, specially if we want to use custom libraries and complex functionality. There is a really good manual at Digital Ocean explaining how to install and set up everything you would require for a full PHP server, from the installation of Apache2 to the installation of all PHP libraries.

If there is no other option but to work in a Microsoft Windows environment, I recommend using the Laragon package that will, automatically, install everything you would need to work with PHP in Microsoft Windows based systems (works with Server and Desktop versions).

Talking about the tools, right now I am working in the PHP STORM IDE. If in the future we find a better IDE to work PHP then we will switch, but for now, I am very comfortable using it. If you want to give it a try go ahead.

Similarities with Laravel

Database

We are using the same database engine as described in here. This is powerful database class and we don't think is necessary to redo another class if this works like a charm.

Blade system

One of the most powerful tools in Laravel is its views system. Since we are trying to emulate that part, we are using the same Blade System to take advantage of all its features.

Dumper

Easier way to debug the code. Belong to the Illiminate Support.

HTAccess

We are using the exact same .htaccess file that Laravel provides.

Validation

Digital Kataclysm implements a strong and robust Validation Class called GUMP. You can find more information about this Library in the here. It works really similar to the Laravel Integrated Validation Class, so for those Laravel Developers won't be a problem to migrate to this library. Also, we are implementing some wrappers to allow the coder to access this functions easier.

We provide a form example in the main installation that shows exactly how this library should work in your project.

Shell scripting?

Laravel is famous for using a SHELL scripting called Artisan where you can code commands to be executed manually or using crontab. Well, we didn't want to be left behind so Digital Kataclysm has a scripting system called meteor that works in a very similar way. What is the advantage? meteor is simpler and faster because it does not have a lot of the funcionality that artisan has, but it has enough power to handle most of the most basic functions you would want.

Why don't just use Laravel/Lumen/CakePHP? What its wrong with them?

Even when there are a lot of frameworks, libraries and free code out there, and they can be used by Digital Kataclysm, I decided to make some of them by my own. For example the routes management is being made from scratch (instead of using for example Slim Framework), and this is because we want to make a lighter one instead of keep adding libraries to the project composer (and also, learn in the process).

We know that there are a lot of libraries out there that make most of the work we are doing here; like the great example: Laravel that includes everything you will see here; but maybe it is including code, libraries and functions that we will never use, or worse, we will never understand how they work.

Want to help me?

If you are willing to spend some time checking the code and adding improvements, you can request a PUSH to this repository and I will, personally, check it and add it.

I accept all kinds of help from full design pages to classes and even composer requirements that you can suggest. Just be sure to comment all you can, links from where you are taking the classes of methods or even a little poetry of how you manage to get that awesome logic in your code.

Your reward? You will be able to use this little project for small ideas or sites wherever you like, and even you can folk it and modify it yourself. What is better than that? Maybe other frameworks are not suitable for your needs, so why just don't take this one and make it exactly as you want?

Copyright

All the code made in this repository was made by Danilo Ramírez Mattey. Please use it carefully and be sure to credit me if you are using any of it, including independent classes.

Copyright 2010-2018 | San José, Costa Rica

Instalation

DigitalKataclysm installation is similar to every other composer project. First find a place where your code will be stored, and using any code terminal (command line or linux terminal)

$ git clone https://github.com/danilor/DigitalKataclysm.git

Or if you are using GITHUB by SSH

$ git clone [email protected]:danilor/DigitalKataclysm.git

After that, you will have to run the composer install function that will download and register all required libraries and modules for Digital Kataclysm.

$ composer install

Later, open the app.ini file (if you don't have one, clone the app.ini_example file) and change its information with the one of your machine.

[DEVELOPMENT ENVIORONMENT]
ENV=development
KEY=64STR98WOFM7492N3F5VM7324FGHOQ21

[DATABASE INFORMATION]
DB_HOST=
DB_NAME=
DB_USER=
DB_PASS=
DB_PORT=

Doing this, you should be able to open your browser and navigate to the main page and start using the Framework. You can check the example pages for more information.

Working status

  • Composer set up
    • Composer installation
  • Public Folder
  • PHP Documentor integration
  • View Class
    • Blade or similar (for Views)
  • Request Class
    • Request Input
    • Request Method
    • Request Server
    • Request Integration
  • Config class
  • File .INI compatibility
  • Bootstrap and Jquery addition (With the configuration for each version)
  • URL Management
    • URL Rewrite
    • Routing with wildcards
    • Error and not found system (pages 500 and 404) (Still not working as I would like it to work)
  • User session class
  • Framework integration
  • Database Global
  • Integrated validations
  • Console commands
    • Working options
  • Create logo
  • Closures
  • Responses
    • View JSON type
    • View XML type
    • Redirect Response type
  • Crypt Class
  • Angular compatibility

Contributors

  • Danilo Ramírez

Yes yes I know, sometimes I write "we" and other times I write "I", sometimes I feel kind of lonely in this project :D. Don't judge me.

Technologies

Composer PHP JQUERY BOOTSTRAP FONT-AWESOME

  • Composer
  • PHP
  • Jquery
  • Bootstrap
  • FontAwesome