{"id":36998482,"url":"https://github.com/mdmunir/dee","last_synced_at":"2026-01-13T23:59:50.645Z","repository":{"id":46628815,"uuid":"59173408","full_name":"mdmunir/dee","owner":"mdmunir","description":"Dee Framework. Simple, fast, MVC framework","archived":false,"fork":false,"pushed_at":"2021-10-14T15:45:42.000Z","size":121,"stargazers_count":21,"open_issues_count":1,"forks_count":12,"subscribers_count":7,"default_branch":"master","last_synced_at":"2024-04-22T19:44:37.594Z","etag":null,"topics":["framework","hacktoberfest"],"latest_commit_sha":null,"homepage":"","language":"PHP","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/mdmunir.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":".github/CONTRIBUTING.md","funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2016-05-19T04:21:46.000Z","updated_at":"2023-03-30T01:39:03.000Z","dependencies_parsed_at":"2022-08-30T16:43:17.433Z","dependency_job_id":null,"html_url":"https://github.com/mdmunir/dee","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/mdmunir/dee","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/mdmunir%2Fdee","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/mdmunir%2Fdee/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/mdmunir%2Fdee/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/mdmunir%2Fdee/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/mdmunir","download_url":"https://codeload.github.com/mdmunir/dee/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/mdmunir%2Fdee/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":28406358,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-01-13T21:51:37.118Z","status":"ssl_error","status_checked_at":"2026-01-13T21:45:14.585Z","response_time":56,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.5:443 state=error: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["framework","hacktoberfest"],"created_at":"2026-01-13T23:59:49.968Z","updated_at":"2026-01-13T23:59:50.640Z","avatar_url":"https://github.com/mdmunir.png","language":"PHP","funding_links":[],"categories":[],"sub_categories":[],"readme":"Dee Framework\n=============\n\nFramework PHP dengan pola MVC. Cocok untuk media belajar cara kerja framework.\n\n[![Latest Stable Version](https://poser.pugx.org/mdmunir/dee-app/v/stable)](https://packagist.org/packages/mdmunir/dee-app)\n[![Latest Unstable Version](https://poser.pugx.org/mdmunir/dee-app/v/unstable)](https://packagist.org/packages/mdmunir/dee-app)\n[![Build Status](https://travis-ci.org/mdmunir/dee.svg?branch=master)](https://travis-ci.org/mdmunir/dee)\n[![License](https://poser.pugx.org/mdmunir/dee-app/license)](https://packagist.org/packages/mdmunir/dee-app)\n\nInstalasi\n---------\nDownload filenya dari [sini](https://github.com/mdmunir/dee/archive/master.zip), kemudian ekstak.\nSetelah itu buka command line, masuk ke folder hasil ekstraksi dan jalankan\n```\nphp init\n```\n\nFitur\n------\n\n* Menggunakan pola MVC.\n* Menggunakan autoloader. Meminimalkan penggunaan `include` dan `require`.\n* `View templating`. Beberapa halaman dapat berbagi `layout` yang sama.\n* Koneksi database dengan PDO.\n* Register js dan css.\n* Asset bundle.\n* Clean url.\n* Support url rules/routing. Bisa untuk membangun aplikasi REST.\n* Aplikasi Console.\n* Dan lain-lain.\n\nCara Penggunaan\n---------------\n\n# Membuat controller.\nBuat class di folder `protected/controllers` dengan nama `Hello.php`.\n```php\nnamespace app\\controllers;\n\nclass Hello extends \\dee\\base\\Controller\n{\n    public function actionIndex()\n    {\n        return $this-\u003erender('index', ['name'=\u003e'World']);\n    }\n}\n```\n\n* Perhatikan huruf besar huruf kecil. Controller class harus merupakan turunan dari class `dee\\base\\Controller`.\n* Nama class harus sama dengan nama file dengan akhiran `.php`.\n* Nama class menggunakan format camel case(huruf besar di awal kata). Misal, routenya adalah `hello`, maka nama classnya\nadalah `Hello`. Jika nama routenya adalah `hello-guys` maka nama classnya adalah `HelloGuys`.\n\n# Membuat view.\nKemudian di folder `protected/views/hello` kita buat file `index.php`\n```php\n\u003cdiv class=\"hello\"\u003e\n    \u003cdiv class=\"jumbotron\"\u003e\n        \u003ch1\u003eWelcome!\u003c/h1\u003e\n\n        \u003cp class=\"lead\"\u003eHello \u003c?= $name; ?\u003e.\u003c/p\u003e\n\n        \u003cp\u003e\u003ca href=\"https://mdmunir.wordpress.com\" class=\"btn btn-lg btn-success\"\u003eGet started\u003c/a\u003e\u003c/p\u003e\n    \u003c/div\u003e\n\u003c/div\u003e\n```\n\n* Folder view dari controller bersesuaian dengan id controller.\n* Jika id controller adalah `hello`, maka viewnya ada di folder `protected/views/hello`. Begitu juga jika\nid controller adalah `hello-guys`, maka viewnya ada di folder `protected/views/hello-guys`.\n* Kita juga bisa menyisipkan kode javascript di view. contoh\n\n```php\n\u003c?php\n$js = \u003c\u003c\u003cJS\n    $('#click-me').click(function(){\n        alert('Hello...');\n    });\nJS;\n$this-\u003eregisterJs($js); // default di register ke jquery ready. \n// opsi lainnya adalah $this-\u003eregisterJs($js,View::POS_HEAD); atau $this-\u003eregisterJs($js,View::POS_END);\n$this-\u003etitle = 'Contoh JS';\n?\u003e\n\u003cdiv\u003e\n    \u003cbutton id=\"click-me\"\u003eClick Me\u003c/button\u003e\n\u003c/div\u003e\n```\n\nUntuk mengakses halaman yang kita buat, urlnya adalah `localhost/path/app/index.php/hello`\n\nAsset Package\n------------\nMeregister file js dapat dilakukan dengan mudah lewat `Asset Package`. Caranya, kita daftarkan paket kita di file config\n```php\n'components' =\u003e [\n    'views' =\u003e [\n        'packages' =\u003e [\n            'bootstrap' =\u003e [\n                'js' =\u003e ['https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js'],\n                'css' =\u003e ['https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css'],\n                'depends' =\u003e ['jquery'],\n            ],\n        ]\n    ]\n]\n```\nSetelah itu di view kita, kita bisa menggunakan paket tersebut dengan merigesternya\n```php\n/* @var $this \\dee\\base\\View */\n\n$this-\u003eregisterPackage('bootstrap');\n```\nSaat ini paket inti yang tersedia adalah `jquery` yang mengarah ke `//code.jquery.com/jquery-2.2.4.min.js`.\nAnda dapat menggunakan jquery anda sendiri dengan cara menimpah konfigursinya\n```php\n'components' =\u003e [\n    'views' =\u003e [\n        'packages' =\u003e [\n            ...\n            'jquery' =\u003e [\n                'js' =\u003e ['@web/main/jquery.min.js'],\n            ],\n        ]\n    ]\n]\n```\nPaket `jquery` akan otomatis tersedia ketika meregister javascript di `POS_READY` atau `POS_LOAD`. Atau Anda\ndapat meregister manual dengan memanggil dari view `$this-\u003eregisterPackage('jquery')`.\n\n\n# Clean URL\nUntuk membuat url yang lebih bersih (menghilangkan `index.php`) lakukan beberapa langkah berikut.\n\n* Membuat file `.htaccess`.\n```\nRewriteEngine on\n# RewriteBase /\nRewriteCond %{REQUEST_FILENAME} !-f\nRewriteCond %{REQUEST_FILENAME} !-d\nRewriteRule . index.php\n```\n* Merubah setingan `showScriptName`. Buka file `protected/config/web.php`. Ubah `showScriptName` menjadi `false`. \n\n# REST Url\nRest url dapat dibuat dengan mengisi setingan `request-\u003erules`. Contoh:\n\n```php\n'rules' =\u003e [\n    'GET,HEAD product' =\u003e 'product/index',\n    'GET,HEAD product/{id:\\d+}' =\u003e 'product/view',\n    'POST product' =\u003e 'product/create',\n    'PUT product/{id:\\d+}' =\u003e 'product/update',\n    'DELETE product/{id:\\d+}' =\u003e 'product/delete',\n]\n```\nSetelah itu kita buat controller `ProductController` dan mengimplementasikan action `actionIndex()`, `actionView()` dan seterusnya.\n\n# Koneksi ke Database\nEdit file `protected/config/db.php` kemudian sesuaikan dsn, user dan passwordnya.\nMisal untuk konek ke mysql, maka dsnnya adalah 'mysql:host=localhost;dbname=mydb'.\nSetelah koneksi terbentuk, maka kita bisa memakainya di kontroller, misalnya.\n```php\npublic function actionTampil()\n{\n    $sql = 'select * from user';\n    $users = Dee::$app-\u003edb-\u003equeryAll($sql);\n    return $this-\u003erender('tampil',['users' =\u003e $users]);\n}\n\n// kemudian di view tampil.php\n\u003ctable\u003e\n    \u003cthead\u003e\n        \u003ctr\u003e\n            \u003cth\u003eId\u003c/th\u003e\n            \u003cth\u003eUsername\u003c/th\u003e\n            \u003cth\u003eFull Name\u003c/th\u003e\n        \u003c/tr\u003e\n    \u003c/thead\u003e\n    \u003ctbody\u003e\n        \u003c?php foreach($users as $user): ?\u003e\n        \u003ctr\u003e\n            \u003ctd\u003e\u003c?= $user['id']?\u003e\u003c/td\u003e\n            \u003ctd\u003e\u003c?= $user['username']?\u003e\u003c/td\u003e\n            \u003ctd\u003e\u003c?= $user['fullname']?\u003e\u003c/td\u003e\n        \u003c/tr\u003e\n        \u003c?php endforeach ?\u003e\n    \u003c/tbody\u003e\n\u003c/table\u003e\n```\n\nSelain diakses langsung dari controller. Kita juga bisa membuat model untuk menangani input output database.\nBuat file `User.php` di folder `protected/models`.\n```php\nnamespace app\\models;\n\nclass User\n{\n    public function getAll()\n    {\n        $sql = 'select * from user';\n        return \\Dee::$app-\u003edb-\u003equeryAll($sql);\n    }\n\n    public function addNew($user)\n    {\n        $sql = 'insert into user(username,fullname) values (:username,:fullname)';\n        return \\Dee::$app-\u003edb-\u003eexecute($sql,[\n            ':username' =\u003e $user['username'], \n            ':fullname' =\u003e $user['fullname'],\n        ]);\n    }\n}\n\n// di controller\npublic function actionCreate()\n{\n    $model = new \\app\\models\\User();\n    $user = $_POST;\n    $model-\u003eaddNew($user);\n}\n```\n## Sql Builder\nUntuk memudahkan penggunaan komponen database, maka beberapa fitur ditambahkan untuk membuat sintak sql sederhana. \n\n### Where Builder\n\n```php\n$where = [\n    'colom1' =\u003e 'nilai 1',\n    'colom2' =\u003e [1, 2, 3],\n    \"colom3 \u003c\u003e 5\",\n];\n$params = [];\n$conditions = Dee::$app-\u003edb-\u003ebuildCondition($where, $params);\n// maka variable $conditions dan $params akan bernilai\n// $conditions = \"(colom1 = :p1) AND (colom2 in (:p2,:p3,:p4)) AND (colom3 \u003c\u003e 5)\"\n// $params = [':p1' =\u003e 'nilai 1', ':p2' =\u003e 1,  ':p3' =\u003e 2,  ':p4' =\u003e 3, ];\n```\n\n### Insert Builder\n\n```php\nDee::$app-\u003edb-\u003einsert('user', [\n    'username' =\u003e 'mdmunir,\n    'password' =\u003e md5($password),\n    'company_id' =\u003e 1001,    \n]);\n// akan memeksekusi sql\n// INSERT INTO user(username, password, company_id) values(:p1, :p2, :p3);\n// dengan $params = [':p1' =\u003e 'mdmunir', ':p2' =\u003e 'md5hash',  ':p3' =\u003e 1001 ];\n```\n\n### Update Builder\n```php\nDee::$app-\u003edb-\u003eupdate('user', [\n    'password' =\u003e md5($password),\n], ['id' =\u003e 1]);\n// akan memeksekusi sql\n// UPDATE user SET password = :p1 WHERE (id = :p2);\n// dengan $params = [':p1' =\u003e 'md5hash', ':p2' =\u003e 1];\n```\n\n### Delete Builder\n```php\nDee::$app-\u003edb-\u003edelete('user', ['id' =\u003e 1]);\n// akan memeksekusi sql\n// DELETE FROM user WHERE (id = :p1);\n// dengan $params = [':p1' =\u003e 1];\n```\n\n# Autoloader\nAgar class-class dapat diload dengan benar, maka pastikan class-class yang ada memiliki namesapce yang bersesuaian dengan pathnya.\nUntuk class-class yang berada di bawah folder `protected`, maka root namespace-nya adalah `app`. Sub namespace-nya sesuai\ndengan folder class tersebut berada. Misal untuk class di bawah folder models, maka namespacenya adalah `app\\models`.\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fmdmunir%2Fdee","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fmdmunir%2Fdee","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fmdmunir%2Fdee/lists"}