Neues Projekt: file delivery

Nach Goetemp und Werdertweets schmeiss ich jetzt mal file delivery hier raus ins Netz. Die Idee des Projekts ist relativ simpel. Ueber einen einfachen Weg Dateien im Internet zur Verfuegung zu stellen ohne den echten Dateinamen bekannt zu geben sowie die Dokumente im DocumentRoot vorzuhalten.
Dabei herausgekommen ist file delivery. Es ist ein in PHP geschriebenes kleines System wo ueber ein Webinterface Dateien hochgeladen werden koennen. Die Dateien koennen irgendwo im Dateisystem liegen und muessen nicht im DocumentRoot des Webservers verfuegbar sein. Nach dem Upload gibt es eine URL die aus dem Benutzernamen des Nutzers der die Datei hochgeladen und der MD5-Checksum der hochgeladenen Datei besteht. Nur mit dieser kryptischen URL kann man nun die eine Datei herunterladen.
Als kleines Addon ist eine optionale Emailbenachrichtigung implementiert, die eine Email verschickt, wenn die gewaehlte Datei heruntergeladen wird.

Das System hat eine simple Benutzerverwaltung. Neue Nutzer koennen von dem Administrator Account hinzugefuegt werden. Wenn das PHP-Modul „apc“ installiert und aktiviert ist, wird auch ein Upload Fortschrittsbalken angezeigt. file delivery nutzt Smarty als Templateengine und kann dadurch komplett geskinnt werden.

Das System habe ich unter http://files.pregos.info installiert. Zugangsdaten zum Testen sind „admin/password“. Fuer diese Installation habe ich das Passwort aendern fuer den Administrator deaktiviert.

Wer Anmerkungen, Kritik oder aehnliches hat, bitte immer her damit. Code gibts fuer interessierte auf Anfrage per Mail.

mysql snippets

rename table FooBar to foobar:

ALTER TABLE FooBar RENAME AS foobar;

rename column bar to foo:

ALTER TABLE foobar CHANGE bar foo VARCHAR(255) NOT NULL;

modify column definition:

ALTER TABLE foobar MODIFY foo BIGINT NOT NULL;

add new column baz after foo :

ALTER TABLE foobar ADD baz VARCHAR(60) AFTER foo;

optimize table:

OPTIMIZE TABLE foobar;

show tables description, columns etc:

DESCRIBE TABLE foobar;

show all available mysql users:

SELECT * FROM mysql.user;

delete mysql user:

DROP USER username@host;

mysql snippet

mysql -u root -p
create database MYDATABASENAME;
create user 'MYUSERNAME'@'localhost' identified by 'MYPASSWORD';
grant all privileges on MYDATABASENAME.* to 'MYUSERNAME'@'localhost' with grant option;
flush privileges;
quit