1
0
Fork 0
mirror of https://github.com/YunoHost-Apps/movim_ynh.git synced 2024-09-03 19:46:19 +02:00

update to movim upstream

This commit is contained in:
src386 2016-04-14 13:55:24 +02:00
parent 607c3099dc
commit c3e7628712
12 changed files with 217 additions and 195 deletions

View file

@ -1,7 +1,7 @@
**Changelog**
1.8 2016?
- Update to movim 0.9 git2016-04-12
- Update to movim 0.9 git2016-04-14
1.7.1 2016-30-30
- Update to movim 0.9 git2016-03-30

View file

@ -5,7 +5,7 @@ Movim is a decentralized social network, written in PHP and HTML5 and based on t
It is recommended to use a "valid" certificate to use Movim, auto-signed is sometimes problematic. You might want to take a look a StartSSL or Let's Encrypt.
Provided Movim version : 0.9 git2016-04-12
Provided Movim version : 0.9 git2016-04-14
Please read CHANGELOG.

View file

@ -3,6 +3,9 @@ Movim Changelog
v0.9.1 (trunk)
---------------------------
* Moving values from Sessionx to Session
* Using chart.js for the statistics
* Refactor the "public" system for the Posts
* CSS fixes
* Add Last Message Edition support
* Improve Post discovery in the News page

View file

@ -88,7 +88,7 @@ class Avatar extends \Movim\Widget\Base
->request();
}
function ajaxGetForm()
function ajaxDisplay()
{
$cd = new \modl\ContactDAO();
$me = $cd->get();

View file

@ -50,9 +50,6 @@ var Avatar = {
}
}
MovimWebsocket.attach(function() {
Avatar_ajaxGetForm();
});
/*
function showVideo(){
navigator.getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia || navigator.mozGetUserMedia;

View file

@ -11,15 +11,14 @@
position: fixed;
bottom: 0;
background-color: white;
width: 70%;
width: 65%;
max-width: 100%;
border-top: 1px solid rgba(0, 0, 0, 0.12);
}
#chat_widget .chat_box ul {
margin: 0 auto;
max-width: 100rem;
margin-left: calc(45% - 49rem);
margin: 0;
max-width: 100%;
}
#chat_widget .chat_box form {
@ -53,6 +52,10 @@
right: 2rem;
}
#chat_widget .contained ul {
overflow-x: hidden;
}
/* Chatroom */
#chat_widget ul.simple {
@ -172,11 +175,7 @@ table.emojis td:hover {
@media screen and (max-width: 1024px) {
#chat_widget .chat_box {
width: 100%;
left: 0;
}
#chat_widget .chat_box ul {
margin-left: auto;
width: 100%;
}
}

View file

@ -14,6 +14,7 @@
"monolog/monolog": "1.8.*",
"rain/raintpl": "dev-master",
"michelf/php-markdown": "1.4.*@dev",
"movim/modl": "dev-master",
"movim/sasl2": "dev-master",
"movim/moxl": "dev-master",
@ -26,12 +27,13 @@
"react/socket-client": "dev-master",
"react/stream": "0.4.3",
"react/http": "dev-master",
"react/promise-timer": "^1.1",
"stojg/crop": "dev-master",
"forxer/Gravatar": "~1.2",
"respect/validation": "1.0.*",
"ezyang/htmlpurifier": "^4.7",
"ramsey/uuid": "^3.2",
"react/promise-timer": "^1.1"
"symfony/console": "^3.0"
}
}

74
sources/composer.lock generated
View file

@ -4,8 +4,8 @@
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file",
"This file is @generated automatically"
],
"hash": "959957c08a6e0a7b09d5b3bccf6f6979",
"content-hash": "958b7ab7a85b3465f8038d6848504ff1",
"hash": "03f969c6eb107a15b0b5239da2d3c76e",
"content-hash": "bfebdd8e42854b5a00c9d5dc776a6212",
"packages": [
{
"name": "cboden/ratchet",
@ -439,16 +439,16 @@
},
{
"name": "guzzlehttp/psr7",
"version": "1.2.3",
"version": "1.3.0",
"source": {
"type": "git",
"url": "https://github.com/guzzle/psr7.git",
"reference": "2e89629ff057ebb49492ba08e6995d3a6a80021b"
"reference": "31382fef2889136415751badebbd1cb022a4ed72"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/guzzle/psr7/zipball/2e89629ff057ebb49492ba08e6995d3a6a80021b",
"reference": "2e89629ff057ebb49492ba08e6995d3a6a80021b",
"url": "https://api.github.com/repos/guzzle/psr7/zipball/31382fef2889136415751badebbd1cb022a4ed72",
"reference": "31382fef2889136415751badebbd1cb022a4ed72",
"shasum": ""
},
"require": {
@ -493,7 +493,7 @@
"stream",
"uri"
],
"time": "2016-02-18 21:54:00"
"time": "2016-04-13 19:56:01"
},
{
"name": "heyupdate/emoji",
@ -1636,6 +1636,66 @@
],
"time": "2015-12-03 05:49:01"
},
{
"name": "symfony/console",
"version": "v3.0.4",
"source": {
"type": "git",
"url": "https://github.com/symfony/console.git",
"reference": "6b1175135bc2a74c08a28d89761272de8beed8cd"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/symfony/console/zipball/6b1175135bc2a74c08a28d89761272de8beed8cd",
"reference": "6b1175135bc2a74c08a28d89761272de8beed8cd",
"shasum": ""
},
"require": {
"php": ">=5.5.9",
"symfony/polyfill-mbstring": "~1.0"
},
"require-dev": {
"psr/log": "~1.0",
"symfony/event-dispatcher": "~2.8|~3.0",
"symfony/process": "~2.8|~3.0"
},
"suggest": {
"psr/log": "For using the console logger",
"symfony/event-dispatcher": "",
"symfony/process": ""
},
"type": "library",
"extra": {
"branch-alias": {
"dev-master": "3.0-dev"
}
},
"autoload": {
"psr-4": {
"Symfony\\Component\\Console\\": ""
},
"exclude-from-classmap": [
"/Tests/"
]
},
"notification-url": "https://packagist.org/downloads/",
"license": [
"MIT"
],
"authors": [
{
"name": "Fabien Potencier",
"email": "fabien@symfony.com"
},
{
"name": "Symfony Community",
"homepage": "https://symfony.com/contributors"
}
],
"description": "Symfony Console Component",
"homepage": "https://symfony.com",
"time": "2016-03-16 17:00:50"
},
{
"name": "symfony/event-dispatcher",
"version": "v3.0.4",

View file

@ -40,7 +40,7 @@ if($infos != null) {
}
echo colorize("\nTo update the database run\n", 'green');
echo colorize("php mud.php db set\n", 'purple');
echo colorize("php mud.php db --set\n", 'purple');
exit;
}

View file

@ -5,178 +5,15 @@ require __DIR__ . '/vendor/autoload.php';
define('DOCUMENT_ROOT', dirname(__FILE__));
use Movim\Bootstrap;
use Movim\Console\DatabaseCommand;
use Movim\Console\ConfigCommand;
use Symfony\Component\Console\Application;
$bootstrap = new Bootstrap();
$bootstrap->boot();
$argsize = count($argv);
if($argsize == 1) {
echo
colorize("Welcome to Mud - Movim Unified Doer
$application = new Application;
$application->add(new DatabaseCommand);
$application->add(new ConfigCommand);
$application->run();
Here some requests you can do with me :", 'green')."
- ".colorize("getloc", 'yellow')." grab all the translations in Movim and generate a global locale file
- ".colorize("comploc", 'yellow')." compile the current locales to a simple PHP array to boost Movim execution
- ".colorize("comptz", 'yellow')." compile the timezones
- ".colorize("db", 'yellow')." create/update the database
- ".colorize("config", 'yellow')." set the configuration of Movim (separated by commas and colons) eg. info:Test,description:Hop
";
} elseif($argsize == 2) {
switch ($argv[1]) {
case 'getloc':
getloc();
break;
/*case 'comploc':
comploc();
break;*/
case 'comptz':
comptz();
break;
case 'config':
echo colorize("You need to pass an argument", 'red');
break;
case 'db':
$md = Modl\Modl::getInstance();
$infos = $md->check();
if($infos == null) {
echo colorize("Nothing to do\n", 'green');
} else {
echo colorize("The database need to be updated\n", 'green');
foreach($infos as $i) {
echo colorize($i."\n", 'blue');
}
}
break;
}
} elseif($argsize == 3) {
switch ($argv[1]) {
case 'config':
config($argv[2]);
break;
case 'db':
if($argv[2] == 'set') {
$md = Modl\Modl::getInstance();
$md->check(true);
echo colorize("Database updated\n", 'green');
}
break;
}
}
function config($values) {
echo colorize("Movim configuration setter\n", 'green');
$cd = new \Modl\ConfigDAO();
$config = $cd->get();
$values = explode(',', $values);
foreach($values as $value) {
$exp = explode(':', $value);
$key = $exp[0];
array_shift($exp);
$value = implode(':', $exp);
if(property_exists($config, $key)) {
$old = $config->$key;
$config->$key = $value;
$cd->set($config);
echo colorize("The configuration key ", 'yellow').
colorize($key, 'red').
colorize(" has been updated from ", 'yellow').
colorize($old, 'blue').
colorize(" to ", 'yellow').
colorize($value, 'blue')."\n";
}
}
}
function getloc() {
echo colorize("Locales grabber\n", 'green');
// We look for all the ini files
$inifiles = glob(WIDGETS_PATH.'*/*.ini');
array_push($inifiles, LOCALES_PATH . 'locales.ini');
$locales = CACHE_PATH.'locales.php';
$pot = CACHE_PATH.'messages.pot';
// We create the cache file
$out = "<?php\n";
foreach($inifiles as $ini) {
$keys = parse_ini_file($ini);
foreach($keys as $key => $value) {
$out .= "t(\"$value\");\n";
}
}
$fp = fopen($locales, 'w');
fwrite($fp, $out);
fclose($fp);
echo "File $locales created\n";
// And we run gettext on it
exec("xgettext -e --no-wrap -kt -o $pot -L PHP $locales ");
echo "File $pot created\n";
}
function comploc() {
echo colorize("Locales compiler\n", 'green');
$folder = CACHE_PATH.'/locales/';
if(!file_exists($folder)) {
$bool = mkdir($folder);
if(!$bool) {
echo colorize("The locales cache folder can't be created", 'red');
exit;
}
} else
echo colorize("Folder already exist, don't re-create it\n", 'red');
$langs = loadLangArray();
foreach($langs as $key => $value) {
$langarr = parseLangFile(DOCUMENT_ROOT . '/locales/' . $key . '.po');
$out = '<?php global $translations;
$translations = array(';
foreach($langarr as $msgid => $msgstr)
if($msgid != '')
$out .= '"'.$msgid.'" => "'. $msgstr . '",'."\n";
$out .= ');';
$fp = fopen($folder.$key.'.php', 'w');
fwrite($fp, $out);
fclose($fp);
echo "- $key compiled\n";
}
}
function comptz() {
$file = HELPERS_PATH.'TimezoneList.php';
$tz = generateTimezoneList();
$out = '<?php global $timezones;
$timezones = array(';
foreach($tz as $key => $value)
$out .= '"'.$key.'" => "'. $value . '",'."\n";
$out .= ');';
$fp = fopen($file, 'w');
fwrite($fp, $out);
fclose($fp);
echo "- Timezones compiled in $file\n";
}
echo "\n";

View file

@ -0,0 +1,79 @@
<?php
namespace Movim\Console;
use Symfony\Component\Console\Command\Command;
use Symfony\Component\Console\Input\InputArgument;
use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Input\InputOption;
use Symfony\Component\Console\Output\OutputInterface;
class ConfigCommand extends Command
{
protected function configure()
{
$this
->setName('config')
->setDescription('Change the configuration')
->addOption(
'info',
null,
InputOption::VALUE_REQUIRED,
'Content of the info box on the login page'
)
->addOption(
'username',
null,
InputOption::VALUE_REQUIRED,
'Username for the admin area'
)
->addOption(
'password',
null,
InputOption::VALUE_REQUIRED,
'Password for the admin area'
)
->addOption(
'timezone',
null,
InputOption::VALUE_REQUIRED,
'The server timezone'
)
->addOption(
'loglevel',
null,
InputOption::VALUE_REQUIRED,
'The server loglevel, default 0'
)
->addOption(
'locale',
null,
InputOption::VALUE_REQUIRED,
'The server main locale'
)
;
}
protected function execute(InputInterface $input, OutputInterface $output)
{
$cd = new \Modl\ConfigDAO();
$config = $cd->get();
foreach($input->getOptions() as $key => $value) {
if(property_exists($config, $key) && isset($value)) {
if($key == 'password') $value = sha1($value);
$old = $config->$key;
$config->$key = $value;
$cd->set($config);
$output->writeln(
'<info>The configuration key</info> '.
$key.
' <info>has been updated from</info> '.
$old.
' <info>to</info> '.
$value);
}
}
}
}

View file

@ -0,0 +1,45 @@
<?php
namespace Movim\Console;
use Symfony\Component\Console\Command\Command;
use Symfony\Component\Console\Input\InputArgument;
use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Input\InputOption;
use Symfony\Component\Console\Output\OutputInterface;
class DatabaseCommand extends Command
{
protected function configure()
{
$this
->setName('db')
->setDescription('Database updater')
->addOption(
'set',
's',
InputOption::VALUE_NONE,
'Will apply updates on the database'
)
;
}
protected function execute(InputInterface $input, OutputInterface $output)
{
$md = \Modl\Modl::getInstance();
if($input->getOption('set')) {
$md->check(true);
$output->writeln('<info>Database updated</info>');
} else {
$toDo = $md->check();
if($toDo != null) {
$output->writeln('<comment>The database needs to be updated</comment>');
foreach($toDo as $do) {
$output->writeln('<question>'.$do.'</question>');
}
} else {
$output->writeln('<info>Nothing to do here</info>');
}
}
}
}