3cb4ca790c
* New .gitignore Added violinist.io configuration Start with CI Started moving CSS/JS to NPM * Fix & improvements Security improves (SHA256 instead of MD5) and new PHP7 random function Security fix admin check from database instead of session Security fix user active for every page that require login UX fix admin cannot demote himself Added Gruntfile.js Updated composer.json dependency Addeded PHP >=7.1 to composer.json Moved static file to src * Results of .gitignore "static/" * Fix migration for admin user_code * Travis test for grunt (JS) * Changed user_code generation method Updated Travis test |
||
---|---|---|
app | ||
bin | ||
bootstrap | ||
logs | ||
resources | ||
src | ||
.gitignore | ||
.htaccess | ||
.travis.yml | ||
CHANGELOG.md | ||
composer.json | ||
composer.lock | ||
config.example.php | ||
Gruntfile.js | ||
index.php | ||
LICENSE | ||
package.json | ||
README.md | ||
yarn.lock |
XBackBone 📤
XBackBone is a simple, self-hosted, lightweight PHP backend for the instant sharing tool ShareX. It supports uploading and displaying images, GIF, video, code, formatted text, and file downloading and uploading. Also have a web UI with multi user management and past uploads history.
Features
- Supports every upload type from ShareX.
- User management, multi user features.
- Public and private uploads.
- Web UI for each user.
- Logging system.
- Auto config generator for ShareX.
How to Install
XBackBone require PHP >= 7.1
, the composer package manager and writable storage path:
-
[release, stable] Download latest release from GitHub: https://github.com/SergiX44/XBackBone/releases/latest
-
[master, unstable] Clone this repository in your web root folder:
git clone http://github.com/SergiX44/XBackBone .
- Run a composer from your shell:
composer install --no-dev
- Setup the config file:
cp config.example.php config.php
By default, XBackBone will use Sqlite as DB engine, and a storage
dir in the current directory. You can leave these settings unchanged for a simple personal installation.
You must set the base_url
, or remove it for get dynamically the url from request (not raccomanded).
return [
'base_url' => 'https://myaswesomedomain.com', // no trailing slash
'storage_dir' => 'storage',
'db' => [
'connection' => 'sqlite',
'dsn' => 'resources/database/xbackbone.db',
'username' => null, // username and password not needed for sqlite
'password' => null,
]
];
- Finally, run the migrate script to setup the database
php bin/migrate --install
- Now just login with
admin/admin
, be sure to change these credentials after your first login.
ShareX Configuration
Once you are logged in, just go in your profile settings and download the ShareX config file for your account.
Notes
If you do not use Apache, or the Apache .htaccess
is not enabled, set your web server so that the static/
folder is the only one accessible from the outside, otherwise even private uploads and logs will be accessible!
The NGINX configuration should be something like this:
# nginx configuration
location /app {
return 403;
}
location /bin {
return 403;
}
location /bootstrap {
return 403;
}
location /resources {
return 403;
}
location /storage {
return 403;
}
location /vendor {
return 403;
}
location /logs {
return 403;
}
autoindex off;
location / {
if (!-e $request_filename){
rewrite ^(.*)$ /index.php break;
}
}
Built with
- FlightPHP (http://flightphp.com/)
- Bootstrap 4 (https://getbootstrap.com/)
- Font Awesome 5 (http://fontawesome.com)
- ClipboardJS (https://clipboardjs.com/)
- HighlightJS (https://highlightjs.org/)
- JQuery (https://jquery.com/)