{"id":13395207,"url":"https://github.com/ivanceras/diwata","last_synced_at":"2025-03-13T20:31:57.764Z","repository":{"id":76197683,"uuid":"113599055","full_name":"ivanceras/diwata","owner":"ivanceras","description":"A user-friendly database interface","archived":true,"fork":false,"pushed_at":"2020-10-29T18:07:31.000Z","size":4563,"stargazers_count":395,"open_issues_count":5,"forks_count":15,"subscribers_count":17,"default_branch":"master","last_synced_at":"2024-10-29T18:37:34.072Z","etag":null,"topics":["database","database-gui","database-interface","database-management","postgresql"],"latest_commit_sha":null,"homepage":"","language":"Rust","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"apache-2.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/ivanceras.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null}},"created_at":"2017-12-08T17:15:42.000Z","updated_at":"2024-09-11T12:49:17.000Z","dependencies_parsed_at":"2023-02-27T13:30:50.785Z","dependency_job_id":null,"html_url":"https://github.com/ivanceras/diwata","commit_stats":{"total_commits":798,"total_committers":2,"mean_commits":399.0,"dds":"0.0012531328320801727","last_synced_commit":"5b9d1efc623d6bc40b867fb45983238ef484ab01"},"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ivanceras%2Fdiwata","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ivanceras%2Fdiwata/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ivanceras%2Fdiwata/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ivanceras%2Fdiwata/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/ivanceras","download_url":"https://codeload.github.com/ivanceras/diwata/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":243319661,"owners_count":20272329,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","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":["database","database-gui","database-interface","database-management","postgresql"],"created_at":"2024-07-30T17:01:46.184Z","updated_at":"2025-03-13T20:31:57.729Z","avatar_url":"https://github.com/ivanceras.png","language":"Rust","funding_links":["https://www.patreon.com/ivanceras","https://opencollective.com/diwata"],"categories":["Applications","Rust","应用","应用 Applications"],"sub_categories":["贡献"],"readme":"# Diwata\n\n\nDiwata is a database interface for PostgreSQL,Mysql, Sqlite with the goal of being usable, user-friendly with its basic and advanced functionality be discoverable by the user.\n\n[![](https://travis-ci.org/ivanceras/diwata.svg?branch=master)](https://travis-ci.org/ivanceras/diwata)\n[![Backers on Open Collective](https://opencollective.com/diwata/backers/badge.svg)](#backers)\n [![Sponsors on Open Collective](https://opencollective.com/diwata/sponsors/badge.svg)](#sponsors)\n\n## Demo\n[sakila database in heroku](http://diwata.herokuapp.com/)\n\n![](https://raw.githubusercontent.com/ivanceras/ivanceras.github.io/master/diwata/diwata-sauron2.gif)\n\n## Quick local demo setup using sqlite sakila.db\n\nUse the nightly compiler.\n\n```sh\ngit clone https://github.com/ivanceras/diwata\ncd diwata\ngit submodule update --init --recursive\n./run_sqlite_sakila.sh\nopen http://localhost:9000\n```\n\n## Features\n- Automatic display of direct and indirect linked record\n- Freeze column and freeze rows\n- Infinite scrolling / loading of page on scrolling\n- User friendly granular search and filter\n- Diplay descriptive referred records. (ie: Instead of displaying the foreign_key value integer or uuid, display the referred records in such a way it is distinguisable by the user)\n- Well integrated with the browsers, clickable tables, records and tabs can be openned in a new window and displays the data as though clicking on it.\n\n\n## Roadmap checklist:\n- [ ] Basic data display\n- [X] Infinite load-on-deman scrolling\n- [ ] Meaningful dropdown lookup\n- [X] Seamless url-based navigation\n- [ ] Delete records\n- [ ] Update records\n- [ ] Insert records\n- [ ] Detail record update/insert, delete link detail records\n     [ ] Filtering and searching on has_many and indirect records for detailed record\n- [ ] Undo update/delete records (upon deletion/modification, user have a grace period to undo the changes)\n- [ ] Search and filter data\n- [ ] Drag/Rearrange and resize columns\n- [ ] Multi column sorting\n- [ ] Smart delete cascade messages\n- [ ] Error Handling/Error messages display\n- [ ] Advanced filtering, where user can type in the logic for filtering\n- [X] Display of images and file attachments\n- [ ] Interactive/dynamic record count indicator for toolbar buttons\n- [X] Loading indicators\n- [ ] Page transition animation\n- [ ] Search/filter on tables\n- [ ] Table/Columns filtering based on privilege system.\n    - [X] Display only tables that the user has privilege\n    - [X] Display only columns that the user has privilege\n    - [ ] An interface for superusers to set user privileges for each tables\n- [ ] Row level security\n    - [ ] When the server is configured to require user login, the user will be forced to login\n- [ ] Plugin and module system\n- [ ] Custom validation on field\n- [ ] Custom buttons for application specific functionality\n\n\nNotes:\n\n[1]: You can use sakila database dump as demo database https://github.com/ivanceras/sakila\n\n## Patreon:\nPlease support me on [patreon](https://www.patreon.com/ivanceras), so I can dedicate more time to the development of this project\n\n## Contact me:\nivanceras [a t] gmail.com\n\n\n## Contributors\n\nThis project exists thanks to all the people who contribute.\n\u003ca href=\"https://github.com/ivanceras/diwata/graphs/contributors\"\u003e\u003cimg src=\"https://opencollective.com/diwata/contributors.svg?width=890\u0026button=false\" /\u003e\u003c/a\u003e\n\n\n## Backers\n\nPlease be a backer of this project! 🙏 [[Become a backer](https://opencollective.com/diwata#backer)]\n\n\u003ca href=\"https://opencollective.com/diwata#backers\" target=\"_blank\"\u003e\u003cimg src=\"https://opencollective.com/diwata/backers.svg?width=890\"\u003e\u003c/a\u003e\n\n\n## Sponsors\n\nSupport this project by becoming a sponsor. Your logo will show up here with a link to your website. [[Become a sponsor](https://opencollective.com/diwata#sponsor)]\n\n\u003ca href=\"https://opencollective.com/diwata/sponsor/0/website\" target=\"_blank\"\u003e\u003cimg src=\"https://opencollective.com/diwata/sponsor/0/avatar.svg\"\u003e\u003c/a\u003e\n\u003ca href=\"https://opencollective.com/diwata/sponsor/1/website\" target=\"_blank\"\u003e\u003cimg src=\"https://opencollective.com/diwata/sponsor/1/avatar.svg\"\u003e\u003c/a\u003e\n\u003ca href=\"https://opencollective.com/diwata/sponsor/2/website\" target=\"_blank\"\u003e\u003cimg src=\"https://opencollective.com/diwata/sponsor/2/avatar.svg\"\u003e\u003c/a\u003e\n\u003ca href=\"https://opencollective.com/diwata/sponsor/3/website\" target=\"_blank\"\u003e\u003cimg src=\"https://opencollective.com/diwata/sponsor/3/avatar.svg\"\u003e\u003c/a\u003e\n\u003ca href=\"https://opencollective.com/diwata/sponsor/4/website\" target=\"_blank\"\u003e\u003cimg src=\"https://opencollective.com/diwata/sponsor/4/avatar.svg\"\u003e\u003c/a\u003e\n\u003ca href=\"https://opencollective.com/diwata/sponsor/5/website\" target=\"_blank\"\u003e\u003cimg src=\"https://opencollective.com/diwata/sponsor/5/avatar.svg\"\u003e\u003c/a\u003e\n\u003ca href=\"https://opencollective.com/diwata/sponsor/6/website\" target=\"_blank\"\u003e\u003cimg src=\"https://opencollective.com/diwata/sponsor/6/avatar.svg\"\u003e\u003c/a\u003e\n\u003ca href=\"https://opencollective.com/diwata/sponsor/7/website\" target=\"_blank\"\u003e\u003cimg src=\"https://opencollective.com/diwata/sponsor/7/avatar.svg\"\u003e\u003c/a\u003e\n\u003ca href=\"https://opencollective.com/diwata/sponsor/8/website\" target=\"_blank\"\u003e\u003cimg src=\"https://opencollective.com/diwata/sponsor/8/avatar.svg\"\u003e\u003c/a\u003e\n\u003ca href=\"https://opencollective.com/diwata/sponsor/9/website\" target=\"_blank\"\u003e\u003cimg src=\"https://opencollective.com/diwata/sponsor/9/avatar.svg\"\u003e\u003c/a\u003e\n\n\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fivanceras%2Fdiwata","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fivanceras%2Fdiwata","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fivanceras%2Fdiwata/lists"}