Merge branch 'master' of github.com:annando/friendica
3
.gitignore
vendored
Executable file → Normal file
|
@ -13,6 +13,9 @@ addon
|
||||||
#ignore documentation, it should be newly built
|
#ignore documentation, it should be newly built
|
||||||
doc/api
|
doc/api
|
||||||
|
|
||||||
|
#ignore reports, should be generted with every build
|
||||||
|
report/
|
||||||
|
|
||||||
#ignore config files from eclipse, we don't want IDE files in our repository
|
#ignore config files from eclipse, we don't want IDE files in our repository
|
||||||
.project
|
.project
|
||||||
.buildpath
|
.buildpath
|
||||||
|
|
2
.htaccess
Executable file → Normal file
|
@ -1,4 +1,4 @@
|
||||||
#Options -Indexes
|
Options -Indexes
|
||||||
AddType application/x-java-archive .jar
|
AddType application/x-java-archive .jar
|
||||||
AddType audio/ogg .oga
|
AddType audio/ogg .oga
|
||||||
|
|
||||||
|
|
0
INSTALL.txt
Executable file → Normal file
0
LICENSE
Executable file → Normal file
7
README
|
@ -1,4 +1,11 @@
|
||||||
Friendica Social Communications Server
|
Friendica Social Communications Server
|
||||||
======================================
|
======================================
|
||||||
|
|
||||||
|
http://friendica.com
|
||||||
|
|
||||||
Welcome to the free social web.
|
Welcome to the free social web.
|
||||||
|
|
||||||
|
|
||||||
|
Friendica is a communications platform for integrated social communications utilising decentralised communications and linkage to several indie social projects - as well as popular mainstream providers.
|
||||||
|
|
||||||
|
Our mission is to free our friends and families from the clutches of data-harvesting corporations, and pave the way to a future where social communications are free and open and flow between alternate providers as easily as email does today.
|
129
boot.php
Executable file → Normal file
|
@ -9,9 +9,9 @@ require_once('include/nav.php');
|
||||||
require_once('include/cache.php');
|
require_once('include/cache.php');
|
||||||
|
|
||||||
define ( 'FRIENDICA_PLATFORM', 'Friendica');
|
define ( 'FRIENDICA_PLATFORM', 'Friendica');
|
||||||
define ( 'FRIENDICA_VERSION', '2.3.1269' );
|
define ( 'FRIENDICA_VERSION', '2.3.1304' );
|
||||||
define ( 'DFRN_PROTOCOL_VERSION', '2.22' );
|
define ( 'DFRN_PROTOCOL_VERSION', '2.23' );
|
||||||
define ( 'DB_UPDATE_VERSION', 1131 );
|
define ( 'DB_UPDATE_VERSION', 1137 );
|
||||||
|
|
||||||
define ( 'EOL', "<br />\r\n" );
|
define ( 'EOL', "<br />\r\n" );
|
||||||
define ( 'ATOM_TIME', 'Y-m-d\TH:i:s\Z' );
|
define ( 'ATOM_TIME', 'Y-m-d\TH:i:s\Z' );
|
||||||
|
@ -90,13 +90,14 @@ define ( 'PAGE_SOAPBOX', 1 );
|
||||||
define ( 'PAGE_COMMUNITY', 2 );
|
define ( 'PAGE_COMMUNITY', 2 );
|
||||||
define ( 'PAGE_FREELOVE', 3 );
|
define ( 'PAGE_FREELOVE', 3 );
|
||||||
define ( 'PAGE_BLOG', 4 );
|
define ( 'PAGE_BLOG', 4 );
|
||||||
|
define ( 'PAGE_PRVGROUP', 5 );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Network and protocol family types
|
* Network and protocol family types
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define ( 'NETWORK_ZOT', 'zot!'); // Zot!
|
|
||||||
define ( 'NETWORK_DFRN', 'dfrn'); // Friendica, Mistpark, other DFRN implementations
|
define ( 'NETWORK_DFRN', 'dfrn'); // Friendica, Mistpark, other DFRN implementations
|
||||||
|
define ( 'NETWORK_ZOT', 'zot!'); // Zot!
|
||||||
define ( 'NETWORK_OSTATUS', 'stat'); // status.net, identi.ca, GNU-social, other OStatus implementations
|
define ( 'NETWORK_OSTATUS', 'stat'); // status.net, identi.ca, GNU-social, other OStatus implementations
|
||||||
define ( 'NETWORK_FEED', 'feed'); // RSS/Atom feeds with no known "post/notify" protocol
|
define ( 'NETWORK_FEED', 'feed'); // RSS/Atom feeds with no known "post/notify" protocol
|
||||||
define ( 'NETWORK_DIASPORA', 'dspr'); // Diaspora
|
define ( 'NETWORK_DIASPORA', 'dspr'); // Diaspora
|
||||||
|
@ -108,6 +109,28 @@ define ( 'NETWORK_XMPP', 'xmpp'); // XMPP
|
||||||
define ( 'NETWORK_MYSPACE', 'mysp'); // MySpace
|
define ( 'NETWORK_MYSPACE', 'mysp'); // MySpace
|
||||||
define ( 'NETWORK_GPLUS', 'goog'); // Google+
|
define ( 'NETWORK_GPLUS', 'goog'); // Google+
|
||||||
|
|
||||||
|
/*
|
||||||
|
* These numbers are used in stored permissions
|
||||||
|
* and existing allocations MUST NEVER BE CHANGED
|
||||||
|
* OR RE-ASSIGNED! You may only add to them.
|
||||||
|
*/
|
||||||
|
|
||||||
|
$netgroup_ids = array(
|
||||||
|
NETWORK_DFRN => (-1),
|
||||||
|
NETWORK_ZOT => (-2),
|
||||||
|
NETWORK_OSTATUS => (-3),
|
||||||
|
NETWORK_FEED => (-4),
|
||||||
|
NETWORK_DIASPORA => (-5),
|
||||||
|
NETWORK_MAIL => (-6),
|
||||||
|
NETWORK_MAIL2 => (-7),
|
||||||
|
NETWORK_FACEBOOK => (-8),
|
||||||
|
NETWORK_LINKEDIN => (-9),
|
||||||
|
NETWORK_XMPP => (-10),
|
||||||
|
NETWORK_MYSPACE => (-11),
|
||||||
|
NETWORK_GPLUS => (-12),
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Maximum number of "people who like (or don't like) this" that we will list by name
|
* Maximum number of "people who like (or don't like) this" that we will list by name
|
||||||
*/
|
*/
|
||||||
|
@ -135,6 +158,9 @@ define ( 'NOTIFY_PROFILE', 0x0040 );
|
||||||
define ( 'NOTIFY_TAGSELF', 0x0080 );
|
define ( 'NOTIFY_TAGSELF', 0x0080 );
|
||||||
define ( 'NOTIFY_TAGSHARE', 0x0100 );
|
define ( 'NOTIFY_TAGSHARE', 0x0100 );
|
||||||
|
|
||||||
|
define ( 'NOTIFY_SYSTEM', 0x8000 );
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* various namespaces we may need to parse
|
* various namespaces we may need to parse
|
||||||
*/
|
*/
|
||||||
|
@ -268,6 +294,8 @@ class App {
|
||||||
|
|
||||||
public $nav_sel;
|
public $nav_sel;
|
||||||
|
|
||||||
|
public $category;
|
||||||
|
|
||||||
private $scheme;
|
private $scheme;
|
||||||
private $hostname;
|
private $hostname;
|
||||||
private $baseurl;
|
private $baseurl;
|
||||||
|
@ -286,7 +314,12 @@ class App {
|
||||||
|
|
||||||
startup();
|
startup();
|
||||||
|
|
||||||
$this->scheme = ((isset($_SERVER['HTTPS']) && ($_SERVER['HTTPS'])) ? 'https' : 'http' );
|
$this->scheme = 'http';
|
||||||
|
if(x($_SERVER,'HTTPS') && $_SERVER['HTTPS'])
|
||||||
|
$this->scheme = 'https';
|
||||||
|
elseif(x($_SERVER,'SERVER_PORT') && (intval($_SERVER['SERVER_PORT']) == 443))
|
||||||
|
$this->scheme = 'https';
|
||||||
|
|
||||||
|
|
||||||
if(x($_SERVER,'SERVER_NAME')) {
|
if(x($_SERVER,'SERVER_NAME')) {
|
||||||
$this->hostname = $_SERVER['SERVER_NAME'];
|
$this->hostname = $_SERVER['SERVER_NAME'];
|
||||||
|
@ -347,6 +380,9 @@ class App {
|
||||||
$this->argc = count($this->argv);
|
$this->argc = count($this->argv);
|
||||||
if((array_key_exists('0',$this->argv)) && strlen($this->argv[0])) {
|
if((array_key_exists('0',$this->argv)) && strlen($this->argv[0])) {
|
||||||
$this->module = str_replace(".", "_", $this->argv[0]);
|
$this->module = str_replace(".", "_", $this->argv[0]);
|
||||||
|
if(array_key_exists('2',$this->argv)) {
|
||||||
|
$this->category = $this->argv[2];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
$this->argc = 1;
|
$this->argc = 1;
|
||||||
|
@ -379,11 +415,22 @@ class App {
|
||||||
|
|
||||||
$scheme = $this->scheme;
|
$scheme = $this->scheme;
|
||||||
|
|
||||||
if(x($this->config,'ssl_policy')) {
|
if((x($this->config,'system')) && (x($this->config['system'],'ssl_policy'))) {
|
||||||
if(($ssl) || ($this->config['ssl_policy'] == SSL_POLICY_FULL))
|
if(intval($this->config['system']['ssl_policy']) === intval(SSL_POLICY_FULL))
|
||||||
$scheme = 'https';
|
|
||||||
if(($this->config['ssl_policy'] == SSL_POLICY_SELFSIGN) && (local_user() || x($_POST,'auth-params')))
|
|
||||||
$scheme = 'https';
|
$scheme = 'https';
|
||||||
|
|
||||||
|
// We need to populate the $ssl flag across the entire program before turning this on.
|
||||||
|
// Basically, we'll have $ssl = true on any links which can only be seen by a logged in user
|
||||||
|
// (and also the login link). Anything seen by an outsider will have it turned off.
|
||||||
|
// At present, setting SSL_POLICY_SELFSIGN will only force remote contacts to update their
|
||||||
|
// contact links to this site with "http:" if they are currently using "https:"
|
||||||
|
|
||||||
|
// if($this->config['system']['ssl_policy'] == SSL_POLICY_SELFSIGN) {
|
||||||
|
// if($ssl)
|
||||||
|
// $scheme = 'https';
|
||||||
|
// else
|
||||||
|
// $scheme = 'http';
|
||||||
|
// }
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->baseurl = $scheme . "://" . $this->hostname . ((isset($this->path) && strlen($this->path)) ? '/' . $this->path : '' );
|
$this->baseurl = $scheme . "://" . $this->hostname . ((isset($this->path) && strlen($this->path)) ? '/' . $this->path : '' );
|
||||||
|
@ -544,6 +591,10 @@ function absurl($path) {
|
||||||
return $path;
|
return $path;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function is_ajax() {
|
||||||
|
return (!empty($_SERVER['HTTP_X_REQUESTED_WITH']) && strtolower($_SERVER['HTTP_X_REQUESTED_WITH']) == 'xmlhttprequest');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// Primarily involved with database upgrade, but also sets the
|
// Primarily involved with database upgrade, but also sets the
|
||||||
// base url for use in cmdline programs which don't have
|
// base url for use in cmdline programs which don't have
|
||||||
|
@ -685,6 +736,7 @@ function get_guid($size=16) {
|
||||||
|
|
||||||
if(! function_exists('login')) {
|
if(! function_exists('login')) {
|
||||||
function login($register = false, $hiddens=false) {
|
function login($register = false, $hiddens=false) {
|
||||||
|
$a = get_app();
|
||||||
$o = "";
|
$o = "";
|
||||||
$reg = false;
|
$reg = false;
|
||||||
if ($register) {
|
if ($register) {
|
||||||
|
@ -696,16 +748,20 @@ function login($register = false, $hiddens=false) {
|
||||||
|
|
||||||
$noid = get_config('system','no_openid');
|
$noid = get_config('system','no_openid');
|
||||||
|
|
||||||
|
$dest_url = $a->get_baseurl(true) . '/' . $a->query_string;
|
||||||
|
|
||||||
if(local_user()) {
|
if(local_user()) {
|
||||||
$tpl = get_markup_template("logout.tpl");
|
$tpl = get_markup_template("logout.tpl");
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
$tpl = get_markup_template("login.tpl");
|
$tpl = get_markup_template("login.tpl");
|
||||||
|
$_SESSION['return_url'] = $a->query_string;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
$o .= replace_macros($tpl,array(
|
$o .= replace_macros($tpl,array(
|
||||||
|
|
||||||
|
'$dest_url' => $dest_url,
|
||||||
'$logout' => t('Logout'),
|
'$logout' => t('Logout'),
|
||||||
'$login' => t('Login'),
|
'$login' => t('Login'),
|
||||||
|
|
||||||
|
@ -934,6 +990,12 @@ function profile_sidebar($profile, $block = 0) {
|
||||||
if((remote_user()) && ($_SESSION['visitor_visiting'] == $profile['uid']))
|
if((remote_user()) && ($_SESSION['visitor_visiting'] == $profile['uid']))
|
||||||
$connect = False;
|
$connect = False;
|
||||||
|
|
||||||
|
if(get_my_url() && $profile['unkmail'])
|
||||||
|
$wallmessage = t('Message');
|
||||||
|
else
|
||||||
|
$wallmessage = false;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// show edit profile to yourself
|
// show edit profile to yourself
|
||||||
if ($profile['uid'] == local_user()) {
|
if ($profile['uid'] == local_user()) {
|
||||||
|
@ -1016,6 +1078,7 @@ function profile_sidebar($profile, $block = 0) {
|
||||||
$o .= replace_macros($tpl, array(
|
$o .= replace_macros($tpl, array(
|
||||||
'$profile' => $profile,
|
'$profile' => $profile,
|
||||||
'$connect' => $connect,
|
'$connect' => $connect,
|
||||||
|
'$wallmessage' => $wallmessage,
|
||||||
'$location' => template_escape($location),
|
'$location' => template_escape($location),
|
||||||
'$gender' => $gender,
|
'$gender' => $gender,
|
||||||
'$pdesc' => $pdesc,
|
'$pdesc' => $pdesc,
|
||||||
|
@ -1209,19 +1272,22 @@ function current_theme(){
|
||||||
$a = get_app();
|
$a = get_app();
|
||||||
|
|
||||||
$system_theme = ((isset($a->config['system']['theme'])) ? $a->config['system']['theme'] : '');
|
$system_theme = ((isset($a->config['system']['theme'])) ? $a->config['system']['theme'] : '');
|
||||||
$theme_name = ((is_array($_SESSION) && x($_SESSION,'theme')) ? $_SESSION['theme'] : $system_theme);
|
$theme_name = ((isset($_SESSION) && x($_SESSION,'theme')) ? $_SESSION['theme'] : $system_theme);
|
||||||
|
|
||||||
if($theme_name && file_exists('view/theme/' . $theme_name . '/style.css'))
|
if($theme_name &&
|
||||||
|
(file_exists('view/theme/' . $theme_name . '/style.css') ||
|
||||||
|
file_exists('view/theme/' . $theme_name . '/style.php')))
|
||||||
return($theme_name);
|
return($theme_name);
|
||||||
|
|
||||||
foreach($app_base_themes as $t) {
|
foreach($app_base_themes as $t) {
|
||||||
if(file_exists('view/theme/' . $t . '/style.css'))
|
if(file_exists('view/theme/' . $t . '/style.css')||
|
||||||
|
file_exists('view/theme/' . $t . '/style.php'))
|
||||||
return($t);
|
return($t);
|
||||||
}
|
}
|
||||||
|
|
||||||
$fallback = glob('view/theme/*/style.css');
|
$fallback = glob('view/theme/*/style.[css|php]');
|
||||||
if(count($fallback))
|
if(count($fallback))
|
||||||
return (str_replace('view/theme/','', str_replace("/style.css","",$fallback[0])));
|
return (str_replace('view/theme/','', substr($fallback[0],0,-10)));
|
||||||
|
|
||||||
}}
|
}}
|
||||||
|
|
||||||
|
@ -1233,6 +1299,8 @@ if(! function_exists('current_theme_url')) {
|
||||||
function current_theme_url() {
|
function current_theme_url() {
|
||||||
global $a;
|
global $a;
|
||||||
$t = current_theme();
|
$t = current_theme();
|
||||||
|
if (file_exists('view/theme/' . $t . '/style.php'))
|
||||||
|
return($a->get_baseurl() . '/view/theme/' . $t . '/style.pcss');
|
||||||
return($a->get_baseurl() . '/view/theme/' . $t . '/style.css');
|
return($a->get_baseurl() . '/view/theme/' . $t . '/style.css');
|
||||||
}}
|
}}
|
||||||
|
|
||||||
|
@ -1258,8 +1326,12 @@ function feed_birthday($uid,$tz) {
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
$birthday = '';
|
$birthday = '';
|
||||||
|
|
||||||
|
if(! strlen($tz))
|
||||||
|
$tz = 'UTC';
|
||||||
|
|
||||||
$p = q("SELECT `dob` FROM `profile` WHERE `is-default` = 1 AND `uid` = %d LIMIT 1",
|
$p = q("SELECT `dob` FROM `profile` WHERE `is-default` = 1 AND `uid` = %d LIMIT 1",
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
|
@ -1335,7 +1407,7 @@ function profile_tabs($a, $is_owner=False, $nickname=Null){
|
||||||
array(
|
array(
|
||||||
'label' => t('Profile'),
|
'label' => t('Profile'),
|
||||||
'url' => $url.'/?tab=profile',
|
'url' => $url.'/?tab=profile',
|
||||||
'sel' => (($tab=='profile')?'active':''),
|
'sel' => ((isset($tab) && $tab=='profile')?'active':''),
|
||||||
),
|
),
|
||||||
array(
|
array(
|
||||||
'label' => t('Photos'),
|
'label' => t('Photos'),
|
||||||
|
@ -1357,6 +1429,29 @@ function profile_tabs($a, $is_owner=False, $nickname=Null){
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
$arr = array('is_owner' => $is_owner, 'nickname' => $nickname, 'tab' => (($tab) ? $tab : false), 'tabs' => $tabs);
|
||||||
|
call_hooks('profile_tabs', $arr);
|
||||||
|
|
||||||
$tpl = get_markup_template('common_tabs.tpl');
|
$tpl = get_markup_template('common_tabs.tpl');
|
||||||
return replace_macros($tpl,array('$tabs'=>$tabs));
|
|
||||||
|
return replace_macros($tpl,array('$tabs' => $arr['tabs']));
|
||||||
}}
|
}}
|
||||||
|
|
||||||
|
function get_my_url() {
|
||||||
|
if(x($_SESSION,'my_url'))
|
||||||
|
return $_SESSION['my_url'];
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
function zrl($s) {
|
||||||
|
if(! strlen($s))
|
||||||
|
return $s;
|
||||||
|
if(! strpos($s,'/profile/'))
|
||||||
|
return $s;
|
||||||
|
$achar = strpos($s,'?') ? '&' : '?';
|
||||||
|
$mine = get_my_url();
|
||||||
|
if($mine and ! link_compare($mine,$s))
|
||||||
|
return $s . $achar . 'zrl=' . urlencode($mine);
|
||||||
|
return $s;
|
||||||
|
}
|
||||||
|
|
44
build.xml
|
@ -1,14 +1,49 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
|
||||||
<project name="friendica" default="test">
|
<project name="friendica" default="test">
|
||||||
|
<!-- ====================================================== -->
|
||||||
|
<!-- Target: clean-test -->
|
||||||
|
<!-- deletes directories with old test reports -->
|
||||||
|
<!-- ====================================================== -->
|
||||||
|
<target name="clean-test">
|
||||||
|
<delete dir="report" />
|
||||||
|
</target>
|
||||||
|
|
||||||
|
<!-- ====================================================== -->
|
||||||
|
<!-- Target: prepare-test -->
|
||||||
|
<!-- creates directories for test reports -->
|
||||||
|
<!-- ====================================================== -->
|
||||||
|
<target name="prepare-test" depends="clean-test">
|
||||||
|
<mkdir dir="report" />
|
||||||
|
</target>
|
||||||
|
|
||||||
<!-- =================================== -->
|
<!-- =================================== -->
|
||||||
<!-- Target: test -->
|
<!-- Target: test -->
|
||||||
<!-- this target runs all test files -->
|
<!-- this target runs all test files -->
|
||||||
<!-- =================================== -->
|
<!-- =================================== -->
|
||||||
|
<target name="test" depends="prepare-test">
|
||||||
<target name="test">
|
<!-- coverage-setup database="./report/coverage-database">
|
||||||
<!-- there are no tests by now, so, nothing to do -->
|
<fileset dir=".">
|
||||||
|
<include name="**/*.php" />
|
||||||
|
<exclude name="*test.php"/>
|
||||||
|
<exclude name="index.php"/>
|
||||||
|
<exclude name="library/**"/>
|
||||||
|
<exclude name="doc/**"/>
|
||||||
|
<exclude name=".."/>
|
||||||
|
</fileset>
|
||||||
|
</coverage-setup -->
|
||||||
|
<phpunit printsummary="true">
|
||||||
|
<batchtest>
|
||||||
|
<fileset dir="tests">
|
||||||
|
<include name="*test.php" />
|
||||||
|
</fileset>
|
||||||
|
</batchtest>
|
||||||
|
<formatter type="xml" todir="report" outfile="testlog.xml" />
|
||||||
|
</phpunit>
|
||||||
|
<phpunitreport infile="report/testlog.xml" todir="report" />
|
||||||
|
<!-- coverage-report outfile="report/coverage-database">
|
||||||
|
<report todir="report" styledir="/home/phing/etc" />
|
||||||
|
</coverage-report -->
|
||||||
</target>
|
</target>
|
||||||
|
|
||||||
<!-- ===================================================== -->
|
<!-- ===================================================== -->
|
||||||
|
@ -31,6 +66,9 @@
|
||||||
<docblox title="Friendica API" destdir="./doc/api">
|
<docblox title="Friendica API" destdir="./doc/api">
|
||||||
<fileset dir=".">
|
<fileset dir=".">
|
||||||
<include name="**/*.php" />
|
<include name="**/*.php" />
|
||||||
|
<include name="README"/>
|
||||||
|
<include name="INSTALL.txt"/>
|
||||||
|
<include name="LICENSE"/>
|
||||||
</fileset>
|
</fileset>
|
||||||
</docblox>
|
</docblox>
|
||||||
</target>
|
</target>
|
||||||
|
|
33
database.sql
Executable file → Normal file
|
@ -34,10 +34,11 @@ CREATE TABLE IF NOT EXISTS `challenge` (
|
||||||
|
|
||||||
CREATE TABLE IF NOT EXISTS `config` (
|
CREATE TABLE IF NOT EXISTS `config` (
|
||||||
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
|
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
|
||||||
`cat` char(255) NOT NULL,
|
`cat` char(255) CHARACTER SET ascii COLLATE ascii_general_ci NOT NULL,
|
||||||
`k` char(255) NOT NULL,
|
`k` char(255) CHARACTER SET ascii COLLATE ascii_general_ci NOT NULL,
|
||||||
`v` text NOT NULL,
|
`v` text NOT NULL,
|
||||||
PRIMARY KEY (`id`)
|
PRIMARY KEY (`id`),
|
||||||
|
UNIQUE KEY `access`(`cat`,`k`)
|
||||||
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
|
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
@ -92,6 +93,7 @@ CREATE TABLE IF NOT EXISTS `contact` (
|
||||||
`blocked` tinyint(1) NOT NULL DEFAULT '1',
|
`blocked` tinyint(1) NOT NULL DEFAULT '1',
|
||||||
`readonly` tinyint(1) NOT NULL DEFAULT '0',
|
`readonly` tinyint(1) NOT NULL DEFAULT '0',
|
||||||
`writable` tinyint(1) NOT NULL DEFAULT '0',
|
`writable` tinyint(1) NOT NULL DEFAULT '0',
|
||||||
|
`forum` tinyint(1) NOT NULL DEFAULT '0',
|
||||||
`hidden` tinyint(1) NOT NULL DEFAULT '0',
|
`hidden` tinyint(1) NOT NULL DEFAULT '0',
|
||||||
`pending` tinyint(1) NOT NULL DEFAULT '1',
|
`pending` tinyint(1) NOT NULL DEFAULT '1',
|
||||||
`rating` tinyint(1) NOT NULL DEFAULT '0',
|
`rating` tinyint(1) NOT NULL DEFAULT '0',
|
||||||
|
@ -116,6 +118,7 @@ CREATE TABLE IF NOT EXISTS `contact` (
|
||||||
KEY `dfrn-id` (`dfrn-id`),
|
KEY `dfrn-id` (`dfrn-id`),
|
||||||
KEY `blocked` (`blocked`),
|
KEY `blocked` (`blocked`),
|
||||||
KEY `readonly` (`readonly`),
|
KEY `readonly` (`readonly`),
|
||||||
|
KEY `forum` (`forum`),
|
||||||
KEY `hidden` (`hidden`),
|
KEY `hidden` (`hidden`),
|
||||||
KEY `pending` (`pending`),
|
KEY `pending` (`pending`),
|
||||||
KEY `closeness` (`closeness`)
|
KEY `closeness` (`closeness`)
|
||||||
|
@ -287,9 +290,10 @@ CREATE TABLE IF NOT EXISTS `mail` (
|
||||||
`convid` int(10) unsigned NOT NULL,
|
`convid` int(10) unsigned NOT NULL,
|
||||||
`title` char(255) NOT NULL,
|
`title` char(255) NOT NULL,
|
||||||
`body` mediumtext NOT NULL,
|
`body` mediumtext NOT NULL,
|
||||||
`seen` tinyint(1) NOT NULL,
|
`seen` tinyint(1) NOT NULL DEFAULT '0',
|
||||||
`reply` tinyint(1) NOT NULL DEFAULT '0',
|
`reply` tinyint(1) NOT NULL DEFAULT '0',
|
||||||
`replied` tinyint(1) NOT NULL,
|
`replied` tinyint(1) NOT NULL DEFAULT '0',
|
||||||
|
`unknown` tinyint(1) NOT NULL DEFAULT '0',
|
||||||
`uri` char(255) NOT NULL,
|
`uri` char(255) NOT NULL,
|
||||||
`parent-uri` char(255) NOT NULL,
|
`parent-uri` char(255) NOT NULL,
|
||||||
`created` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
|
`created` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
|
||||||
|
@ -298,6 +302,7 @@ CREATE TABLE IF NOT EXISTS `mail` (
|
||||||
KEY `guid` (`guid`),
|
KEY `guid` (`guid`),
|
||||||
KEY `convid` (`convid`),
|
KEY `convid` (`convid`),
|
||||||
KEY `reply` (`reply`),
|
KEY `reply` (`reply`),
|
||||||
|
KEY `unknown` (`unknown`),
|
||||||
KEY `uri` (`uri`),
|
KEY `uri` (`uri`),
|
||||||
KEY `parent-uri` (`parent-uri`),
|
KEY `parent-uri` (`parent-uri`),
|
||||||
KEY `created` (`created`)
|
KEY `created` (`created`)
|
||||||
|
@ -451,6 +456,8 @@ CREATE TABLE IF NOT EXISTS `user` (
|
||||||
`blockwall` tinyint(1) unsigned NOT NULL DEFAULT '0',
|
`blockwall` tinyint(1) unsigned NOT NULL DEFAULT '0',
|
||||||
`hidewall` tinyint(1) unsigned NOT NULL DEFAULT '0',
|
`hidewall` tinyint(1) unsigned NOT NULL DEFAULT '0',
|
||||||
`blocktags` tinyint(1) unsigned NOT NULL DEFAULT '0',
|
`blocktags` tinyint(1) unsigned NOT NULL DEFAULT '0',
|
||||||
|
`unkmail` tinyint(1) unsigned NOT NULL DEFAULT '0',
|
||||||
|
`cntunkmail` int(11) unsigned NOT NULL DEFAULT '10',
|
||||||
`notify-flags` int(11) unsigned NOT NULL DEFAULT '65535',
|
`notify-flags` int(11) unsigned NOT NULL DEFAULT '65535',
|
||||||
`page-flags` int(11) unsigned NOT NULL DEFAULT '0',
|
`page-flags` int(11) unsigned NOT NULL DEFAULT '0',
|
||||||
`prvnets` tinyint(1) NOT NULL DEFAULT '0',
|
`prvnets` tinyint(1) NOT NULL DEFAULT '0',
|
||||||
|
@ -470,6 +477,8 @@ CREATE TABLE IF NOT EXISTS `user` (
|
||||||
KEY `account_expired` (`account_expired`),
|
KEY `account_expired` (`account_expired`),
|
||||||
KEY `hidewall` (`hidewall`),
|
KEY `hidewall` (`hidewall`),
|
||||||
KEY `blockwall` (`blockwall`),
|
KEY `blockwall` (`blockwall`),
|
||||||
|
KEY `unkmail` (`unkmail`),
|
||||||
|
KEY `cntunkmail` (`cntunkmail`),
|
||||||
KEY `blocked` (`blocked`),
|
KEY `blocked` (`blocked`),
|
||||||
KEY `verified` (`verified`),
|
KEY `verified` (`verified`),
|
||||||
KEY `login_date` (`login_date`)
|
KEY `login_date` (`login_date`)
|
||||||
|
@ -534,9 +543,10 @@ INDEX ( `batch` )
|
||||||
CREATE TABLE IF NOT EXISTS `pconfig` (
|
CREATE TABLE IF NOT EXISTS `pconfig` (
|
||||||
`id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
|
`id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
|
||||||
`uid` INT NOT NULL DEFAULT '0',
|
`uid` INT NOT NULL DEFAULT '0',
|
||||||
`cat` CHAR( 255 ) NOT NULL ,
|
`cat` CHAR( 255 ) CHARACTER SET ascii COLLATE ascii_general_ci NOT NULL ,
|
||||||
`k` CHAR( 255 ) NOT NULL ,
|
`k` CHAR( 255 ) CHARACTER SET ascii COLLATE ascii_general_ci NOT NULL ,
|
||||||
`v` MEDIUMTEXT NOT NULL
|
`v` MEDIUMTEXT NOT NULL,
|
||||||
|
UNIQUE KEY `access`(`cat`, `k`)
|
||||||
) ENGINE = MyISAM DEFAULT CHARSET=utf8;
|
) ENGINE = MyISAM DEFAULT CHARSET=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
@ -636,6 +646,7 @@ CREATE TABLE IF NOT EXISTS `mailacct` (
|
||||||
`mailbox` CHAR( 255 ) NOT NULL,
|
`mailbox` CHAR( 255 ) NOT NULL,
|
||||||
`user` CHAR( 255 ) NOT NULL ,
|
`user` CHAR( 255 ) NOT NULL ,
|
||||||
`pass` TEXT NOT NULL ,
|
`pass` TEXT NOT NULL ,
|
||||||
|
`reply_to` CHAR( 255 ) NOT NULL ,
|
||||||
`action` INT NOT NULL ,
|
`action` INT NOT NULL ,
|
||||||
`movetofolder` CHAR(255) NOT NULL ,
|
`movetofolder` CHAR(255) NOT NULL ,
|
||||||
`pubmail` TINYINT(1) NOT NULL DEFAULT '0',
|
`pubmail` TINYINT(1) NOT NULL DEFAULT '0',
|
||||||
|
@ -858,3 +869,9 @@ INDEX ( `term` )
|
||||||
) ENGINE = MyISAM DEFAULT CHARSET=utf8;
|
) ENGINE = MyISAM DEFAULT CHARSET=utf8;
|
||||||
|
|
||||||
|
|
||||||
|
CREATE TABLE IF NOT EXISTS `userd` (
|
||||||
|
`id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
|
||||||
|
`username` CHAR( 255 ) NOT NULL,
|
||||||
|
INDEX ( `username` )
|
||||||
|
) ENGINE = MyISAM DEFAULT CHARSET=utf8;
|
||||||
|
|
||||||
|
|
18
doc/Account-Basics.md
Executable file → Normal file
|
@ -6,7 +6,9 @@ Account Basics
|
||||||
|
|
||||||
**Registration**
|
**Registration**
|
||||||
|
|
||||||
Not all Friendica sites allow open registration. If registration is allowed, you will see a "Register" link immediately below the login prompts on the site home page. Following this link will take you to the site Registration page.
|
Not all Friendica sites allow open registration. If registration is allowed, you will see a "Register" link immediately below the login prompts on the site home page. Following this link will take you to the site registration page. The strength of our network is that lots of different sites are all completely compatible with each other. If the site you're visting doesn't allow registration, or you think you might prefer another one, you can find a <a href ="http://dir.friendica.com/siteinfo">list of public servers here</a>, and find one that meets your needs.
|
||||||
|
|
||||||
|
If you'd like to have your own server, you can do that too. Visit <a href = "http://friendica.com/download">the Friendica website</a> to download the code with setup instructions. It's a very simple install process that anybody experienced in hosting websites, or with basic Linux experience can handle easily.
|
||||||
|
|
||||||
*OpenID*
|
*OpenID*
|
||||||
|
|
||||||
|
@ -14,11 +16,11 @@ The first field on the Registration page is for an OpenID address. If you do not
|
||||||
|
|
||||||
*Your Full Name*
|
*Your Full Name*
|
||||||
|
|
||||||
Please provide your full name as you would like it to be displayed on this system.
|
Please provide your full name **as you would like it to be displayed on this system**. Most people use their real name for this, but you're under no obligation to do so yourself.
|
||||||
|
|
||||||
*Email Address*
|
*Email Address*
|
||||||
|
|
||||||
Please provide a valid email address. Your email address is **never** published. We need this to send you account information and your login details. You may also occasionally receive notifications of incoming messages or items requiring your attention, but you have the ability to completely disable these from your Settings page once you have logged in.
|
Please provide a valid email address. Your email address is **never** published. We need this to send you account information and your login details. You may also occasionally receive notifications of incoming messages or items requiring your attention, but you have the ability to completely disable these from your Settings page once you have logged in. This doesn't have to be your primary email address, but it does need to be a real email address. You can't get your initial password, or reset a lost password later without it. This is the only bit of personal information that has to be accurate.
|
||||||
|
|
||||||
*Nickname*
|
*Nickname*
|
||||||
|
|
||||||
|
@ -30,10 +32,10 @@ A nickname is used to generate web addresses for many of your personal pages, an
|
||||||
|
|
||||||
The Registration form also allows you to choose whether or not to list your account in the online directory. This is like a "phone book" and you may choose to be unlisted. We recommend that you select 'Yes' so that other people (friends, family, etc.) will be able to find you. If you choose 'No', you will essentially be invisible and have few opportunities for interaction. Whichever you choose, this can be changed any time from your Settings page after you login.
|
The Registration form also allows you to choose whether or not to list your account in the online directory. This is like a "phone book" and you may choose to be unlisted. We recommend that you select 'Yes' so that other people (friends, family, etc.) will be able to find you. If you choose 'No', you will essentially be invisible and have few opportunities for interaction. Whichever you choose, this can be changed any time from your Settings page after you login.
|
||||||
|
|
||||||
|
|
||||||
*Register*
|
*Register*
|
||||||
|
|
||||||
Once you have provided the necessary details, click the 'Register' button. An email will be sent to you providing your account login details. Some sites may require administrator approval before the registration is processed, and you will be alerted if this is the case. Please watch your email (including spam folders) for your registration approval.
|
Once you have provided the necessary details, click the 'Register' button. An email will be sent to you providing your account login details. Please watch your email (including spam folders) for your registration details and initial password.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -58,6 +60,11 @@ After your first login, please visit the 'Settings' page from the top menu bar a
|
||||||
A ['Tips for New Members'](newmember) link will show up on your home page for two weeks to provide some important Getting Started information.
|
A ['Tips for New Members'](newmember) link will show up on your home page for two weeks to provide some important Getting Started information.
|
||||||
|
|
||||||
|
|
||||||
|
**Retrieving Personal Data**
|
||||||
|
|
||||||
|
You can export a copy of your personal data in XML format from the "Export personal data" link at the top of your settings page.
|
||||||
|
|
||||||
|
|
||||||
**See Also**
|
**See Also**
|
||||||
|
|
||||||
* [Profiles](help/Profiles)
|
* [Profiles](help/Profiles)
|
||||||
|
@ -66,4 +73,3 @@ A ['Tips for New Members'](newmember) link will show up on your home page for tw
|
||||||
|
|
||||||
* [Remove Account](help/Remove-Account)
|
* [Remove Account](help/Remove-Account)
|
||||||
|
|
||||||
|
|
11
doc/Bugs-and-Issues.md
Executable file → Normal file
|
@ -4,18 +4,19 @@ Bugs and Issues
|
||||||
* [Home](help)
|
* [Home](help)
|
||||||
|
|
||||||
|
|
||||||
Please report any bugs/issues you encounter using our bug tracker at [[http://bugs.friendica.com]]
|
If your server has a support page, you should report any bugs/issues you encounter there first. Reporting to your support page before reporting to the developers makes their job easier, as they don't have to deal with bug reports that might not have anything to do with them, and that helps us get new features faster.
|
||||||
|
|
||||||
Try to provide as much information as you can about the bug (including the full text of any error messages or notices), and if possible your Friendica version.
|
If you're a technical user, or your site doesn't have a support page, you'll need to use the <a href = "http://bugs.friendica.com/">Bug Tracker</a>. Please perform a search to see if there's already an open bug that matches yours before submitting anything.
|
||||||
|
|
||||||
Your Friendica version may be found in newer releases by visiting http://YOURFRIENDICASITE/friendica
|
Try to provide as much information as you can about the bug, including the **full** text of any error messages or notices, and any steps required to replicate the problem in as much detail as possible. It's generally better to provide too much information than not enough.
|
||||||
|
|
||||||
For older versions, view the HTML source of your profile page. The Friendica version is in the HTML header, 5-10 lines from the top of the page.
|
<a href = "http://www.chiark.greenend.org.uk/~sgtatham/bugs.html">See this article</a> to learn more about submitting **good** bug reports.
|
||||||
|
|
||||||
For really old versions which don't have a version number in the HTML header - please upgrade. Your bug was probably fixed a long time ago.
|
|
||||||
|
|
||||||
**Bug Sponsorship**
|
**Bug Sponsorship**
|
||||||
|
|
||||||
|
If you find a bug, and it is caused by a problem in main branch (ie, is not specific to our site), you may sponsor it.
|
||||||
|
|
||||||
The bug/issue database allows you to sponsor issues. This provides an incentive for developers to work on your issue. This isn't necessary - we don't like bugs and will try to fix them. This has more importance for future development projects and feature requests.
|
The bug/issue database allows you to sponsor issues. This provides an incentive for developers to work on your issue. This isn't necessary - we don't like bugs and will try to fix them. This has more importance for future development projects and feature requests.
|
||||||
|
|
||||||
Bug sponsorship works on the honour system. If you agree to pay $10 to fix a bug, when the fix has been checked in and verified you should send a paypal payment to the developer assigned to the bug. Don't ever think you can get away with not paying a developer for work performed. Some of these guys could hack into your credit card account if you make them mad.
|
Bug sponsorship works on the honour system. If you agree to pay $10 to fix a bug, when the fix has been checked in and verified you should send a paypal payment to the developer assigned to the bug. Don't ever think you can get away with not paying a developer for work performed. Some of these guys could hack into your credit card account if you make them mad.
|
||||||
|
|
0
doc/Connectors.md
Executable file → Normal file
0
doc/Developers.md
Executable file → Normal file
1
doc/Home.md
Executable file → Normal file
|
@ -5,6 +5,7 @@ Friendica Documentation and Resources
|
||||||
**Contents**
|
**Contents**
|
||||||
|
|
||||||
* [Account Basics](help/Account-Basics)
|
* [Account Basics](help/Account-Basics)
|
||||||
|
* [New User Quick Start](help/guide)
|
||||||
* [Profiles](help/Profiles)
|
* [Profiles](help/Profiles)
|
||||||
* [Connectors](help/Connectors)
|
* [Connectors](help/Connectors)
|
||||||
* [Making Friends](help/Making-Friends)
|
* [Making Friends](help/Making-Friends)
|
||||||
|
|
0
doc/Install.md
Executable file → Normal file
0
doc/Installing-Connectors.md
Executable file → Normal file
9
doc/Making-Friends.md
Executable file → Normal file
|
@ -5,7 +5,13 @@ Making Friends
|
||||||
|
|
||||||
Friendship in Friendica can take on a great many different meanings. But let's keep it simple, you want to be friends with somebody. How do you do it?
|
Friendship in Friendica can take on a great many different meanings. But let's keep it simple, you want to be friends with somebody. How do you do it?
|
||||||
|
|
||||||
The first thing you can do is look at the Directory for somebody you would like to connect with. Visit their profile. Just beneath their profile picture will be the word 'Connect' (we're assuming this is an English language profile).
|
The easiest thing to do is to join the <a href = "http://kakste.com/profile/newhere">New Here</a> group. This group is especially for people new to the Friendica network. Simply connect to the group, post to the wall, and make new friends. You don't even have to like us - comment on a few of our posts, and other people will start to add you too.
|
||||||
|
|
||||||
|
The next thing you can do is look at the Directory. The directory is split up into two parts. If you click the directory button, you will be presented with a list of all members (who chose to be listed) on your server. You'll also see a link to the Global Directory. If you click through to the global directory, you will be presented with a list of everybody who chose to be listed across all instances of Friendica. You will also see a "Show Community Forums" link, which will direct you to Groups, Forums and Fanpages. You connect to people, groups and forums in the same way, except groups and forums will automatically accept your introduction request, whereas a human will approve you manually.
|
||||||
|
|
||||||
|
To connect with other Friendica user
|
||||||
|
|
||||||
|
Visit their profile. Just beneath their profile picture will be the word 'Connect' (we're assuming this is an English language profile).
|
||||||
|
|
||||||
Click that. It will take you to a "Connect" form.
|
Click that. It will take you to a "Connect" form.
|
||||||
|
|
||||||
|
@ -23,6 +29,7 @@ When you've submitted the connection page, it will take you back to your own sit
|
||||||
|
|
||||||
If you already know somebody's Identity Address, you can enter it in the "connect" box on your "Contacts" page. This will take you through a similar process.
|
If you already know somebody's Identity Address, you can enter it in the "connect" box on your "Contacts" page. This will take you through a similar process.
|
||||||
|
|
||||||
|
|
||||||
**Alternate Networks**
|
**Alternate Networks**
|
||||||
|
|
||||||
You can also use your Identity Address or other people's Identity Addresses to become friends across networks. The list of possible networks is growing all the time. If you know (for instance) "bob" on identi.ca (a Status.Net site) you could put bob@identi.ca into your Contact page and become friends across networks. (Or you can put in the URL to Bob's identi.ca page if you wish). You can also be "partial" friends with somebody on Google Buzz by putting in their gmail address. Google Buzz does not yet support all the protocols we need for direct messaging, but you should be able to follow status updates from within Friendica. You can do the same for Twitter accounts and Diaspora accounts. In fact you can "follow" most anybody or any website that produces a syndication feed (RSS/Atom,etc.). If we can find an information stream and a name to attach to the contact, we'll try to connect with them.
|
You can also use your Identity Address or other people's Identity Addresses to become friends across networks. The list of possible networks is growing all the time. If you know (for instance) "bob" on identi.ca (a Status.Net site) you could put bob@identi.ca into your Contact page and become friends across networks. (Or you can put in the URL to Bob's identi.ca page if you wish). You can also be "partial" friends with somebody on Google Buzz by putting in their gmail address. Google Buzz does not yet support all the protocols we need for direct messaging, but you should be able to follow status updates from within Friendica. You can do the same for Twitter accounts and Diaspora accounts. In fact you can "follow" most anybody or any website that produces a syndication feed (RSS/Atom,etc.). If we can find an information stream and a name to attach to the contact, we'll try to connect with them.
|
||||||
|
|
0
doc/Message-Flow.md
Executable file → Normal file
0
doc/Pages.md
Executable file → Normal file
0
doc/Plugins.md
Executable file → Normal file
0
doc/Profiles.md
Executable file → Normal file
15
doc/Remove-Account.md
Executable file → Normal file
|
@ -5,9 +5,20 @@ Remove Account
|
||||||
|
|
||||||
We don't like to see people leave Friendica, but if you need to remove your account, you should visit the URL
|
We don't like to see people leave Friendica, but if you need to remove your account, you should visit the URL
|
||||||
|
|
||||||
http://friendica-site/removeme
|
http://sitename/removeme
|
||||||
|
|
||||||
with your web browser. You will need to be logged in at the time. (Replace "friendica-site" with the hostname of your Friendica server)
|
with your web browser. You will need to be logged in at the time.
|
||||||
|
|
||||||
You will be asked for your password to confirm the request. If this matches your stored password, your account will immediately be removed. Unlike some social networks we do **not** hold onto it for a grace period in case you change your mind. Your user details, your conversations, your photos, your friends - everything; will be removed immediately and you will be logged out.
|
You will be asked for your password to confirm the request. If this matches your stored password, your account will immediately be removed. Unlike some social networks we do **not** hold onto it for a grace period in case you change your mind. Your user details, your conversations, your photos, your friends - everything; will be removed immediately and you will be logged out.
|
||||||
|
|
||||||
|
When we expire posts we send notifications out to Friendica to remove the posts. Diaspora doesn't have a bulk delete so this step is skipped on that network - and hopefully it will be obvious that deletion doesn't work on any other networks. If you manually delete a post or a range of posts we send individual delete notifications to Friendica and Diaspora for each deleted post.
|
||||||
|
|
||||||
|
Diaspora often loses these.
|
||||||
|
|
||||||
|
If you delete a post but somebody else has starred it, it is still removed. Your wishes take priority.
|
||||||
|
|
||||||
|
When you remove your account we physically remove all your posts and your profile and user data, etc. immediately.
|
||||||
|
|
||||||
|
In order to send out a bulk remove we would need to keep your account around to do this, as we would need to prove to your friends who it is that is submitting the request. We can't do this if you don't have an account.
|
||||||
|
|
||||||
|
Your friends may still see your posts if your account is gone, but there is no public place within Friendica where they can be viewed. If you had friends on Diaspora, your public posts may stick around and be visible to others from that network.
|
||||||
|
|
0
doc/Settings.md
Executable file → Normal file
0
doc/Tags-and-Mentions.md
Executable file → Normal file
24
doc/andfinally.md
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
And that brings the Quick Start to an end.
|
||||||
|
|
||||||
|
Here are some more things to help get you started:
|
||||||
|
|
||||||
|
**Groups**
|
||||||
|
|
||||||
|
|
||||||
|
- <a href = "https://kakste.com/profile/newhere">New Here</a> - a group for people new to Friendica
|
||||||
|
|
||||||
|
- <a href = "http://helpers.pyxis.uberspace.de/profile/helpers">Friendica Support</a> - problems? This is the place to ask.
|
||||||
|
|
||||||
|
- <a href = "https://kakste.com/profile/public_stream">Public Stream</a> - a place to talk about anything to anyone.
|
||||||
|
|
||||||
|
- <a href = "https://letstalk.pyxis.uberspace.de/profile/letstalk">Let's Talk</a> a group for finding people and groups who share similar interests.
|
||||||
|
|
||||||
|
- <a href = "http://newzot.hydra.uberspace.de/profile/newzot">Local Friendica</a> a page for local Friendica groups</a>
|
||||||
|
|
||||||
|
|
||||||
|
**Documentation**
|
||||||
|
|
||||||
|
- <a href = "/help/Connectors">Connecting to more networks</a>
|
||||||
|
- <a href = "/help">Help Index</a>
|
||||||
|
|
||||||
|
|
11
doc/groupsandpages.md
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
This is the global directory. If you get lost, you can <a href = "/help/groupsandpages">click this link</a> to bring yourself back here.
|
||||||
|
|
||||||
|
On this page, you'll find a collection of groups, forums and celebrity pages. Groups are not real people. Connecting to them is similar to "liking" something on Facebook, or signing up for a new forum. You don't have to feel awkward about introducing yourself to a new person, because they're not people!
|
||||||
|
|
||||||
|
When you connect to a group, all messages to that group will start appearing in your network tab. You can comment on these posts, or post to the group yourself without ever having to add any of the groups members. This is a great way to make friends dynamically - you'll find people you like and add each other naturally instead of adding random strangers. Simply find a group you're interested in, and connect to it the same way you did with people in the last section. There are a lot of groups, and you're likely to get lost. Remember the link at the top of this page will bring you back here.
|
||||||
|
|
||||||
|
Once you've added some groups, <a href = "/help/andfinally">move on to the next section</a>.
|
||||||
|
|
||||||
|
<iframe src="http://dir.friendica.com/directory/forum" width="950" height = "600"></iframe>
|
||||||
|
|
||||||
|
|
13
doc/guide.md
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
First things first, let's make sure you're logged in to your account. If you're not already logged in, do so in the frame below.
|
||||||
|
|
||||||
|
Once you've logged in (or if you are already logged in), you'll now be looking at your profile page.
|
||||||
|
|
||||||
|
This is a bit like your Facebook wall. It's where all your status messgages are kept, and where your friends come to post on your wall. To write your status, simply click in the box that says "share". When you do this, the box will expand. You can see some formatting options at the top such as Bold, Italics and Underline, as well as ways to add links and pictures. At the bottom you'll find some more links. You can use these to upload pictures and files from your computer, share websites with a bit of preview text, or embed video and audio files from elsewhere on the web. You can also set your post location here.
|
||||||
|
|
||||||
|
Once you've finished writing your post, click on the padlock icon to select who can see it. If you do not use the padlock icon, your post will be public. This means it will appear to anybody who views your profile, and in the community tab if your site has it enabled, as well as in the network tab of any of your contacts.
|
||||||
|
|
||||||
|
Play around with this a bit, then when you're ready to move on, we'll take a look at the <a href = "/help/network">Network Tab</a>
|
||||||
|
|
||||||
|
<iframe src="/login" width="950" height = "600"></iframe>
|
||||||
|
|
||||||
|
|
11
doc/makingnewfriends.md
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
This is your Suggested Friends page. If you get lost, you can <a href = "/help/makenewfriends">click this link</a> to bring yourself back here.
|
||||||
|
|
||||||
|
This is a bit like the Friend Suggestions page of Facebook. Everybody on this list has agreed that they may be suggested as a friend. This means they're unlikely to refuse an introduction you send, and they want to meet new people too!
|
||||||
|
|
||||||
|
See somebody you like the look of? Click the connect button beneath their photograph. This will bring you to the introductions page. Fill in the form as instructed, and add a small note (optional). Now, wait a bit and they'll accept your request - note that these are real people, and it might take a while. Now you've added one, you're probably lost. Click the link at the top of this page to go back to the suggested friends list and add some more.
|
||||||
|
|
||||||
|
Feel uncomfortable adding people you don't know? Don't worry - that's where <a href = "/help/groupsandpages">Groups and Pages</a> come in!
|
||||||
|
|
||||||
|
<iframe src="/suggest" width="950" height = "600"></iframe>
|
||||||
|
|
||||||
|
|
9
doc/network.md
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
This is your Network Tab. If you get lost, you can <a href = "/help/network">click this link</a> to bring yourself back here.
|
||||||
|
|
||||||
|
This is a bit like the Newsfeed at Facebook or the Stream at Diaspora. It's where all the posts from your contacts, groups, and feeds will appear. If you're new, you won't see anything in this page, unless you posted your status in the last step. If you've already added a few friends, you'll be able to see their posts. Here, you can comment, like, or dislike posts, or click on somebody's name to visit their profile page where you can write on their wall.
|
||||||
|
|
||||||
|
Now we need to fill it up, the first step, is to <a href = "/help/peopleyouknow"> add people you already know from Facebook</a>.
|
||||||
|
|
||||||
|
<iframe src="/network" width="950" height = "600"></iframe>
|
||||||
|
|
||||||
|
|
13
doc/peopleyouknow.md
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
This is your connector settings page. If you get lost, you can <a href = "/help/network">click this link</a> to bring yourself back here.
|
||||||
|
|
||||||
|
This is the bit that makes Friendica unique. You can connect to <i>anybody on the internet</i> from your Friendica account using this page! The available connectors varies depending on which plugins you have installed, but for now, we'll walk you through Facebook. Note that not all servers have the Facebook connector installed. If you can't find it in the list below, don't worry, we'll look at ways of connecting to more people in the following pages.
|
||||||
|
|
||||||
|
The biggest of all social networks is Facebook. Fortunately, this connector is really easy. Scroll down the page, and click Facebook Connector Settings. Enter your Facebook user name and password and let the application (the connector) do everything the options suggest. You can <a href = "https://github.com/friendica/friendica/wiki/How-to:-Friendica%E2%80%99s-Facebook-connector" target="new">fine tune this</a> or experiment with the other connectors too. If you need help, you can always ask at <a href = "http://helpers.pyxis.uberspace.de/profile/helpers" target="new">Friendica Support</a> or <a href = "/help/Connectors" target="new">see the instructions here</a>.
|
||||||
|
|
||||||
|
When you're ready, we can move on to <a href = "/help/makingnewfriends">making new friends</a>.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<iframe src="/settings/connectors" width="950" height = "600"></iframe>
|
||||||
|
|
||||||
|
|
13
docblox.dist.xml
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8" ?>
|
||||||
|
<docblox>
|
||||||
|
<parser>
|
||||||
|
<target>data/output</target>
|
||||||
|
</parser>
|
||||||
|
<transformer>
|
||||||
|
<target>data/output</target>
|
||||||
|
</transformer>
|
||||||
|
<files>
|
||||||
|
<directory>.</directory>
|
||||||
|
</files>
|
||||||
|
</docblox>
|
||||||
|
|
11
htconfig.php
Executable file → Normal file
|
@ -69,7 +69,7 @@ $a->config['system']['rino_encrypt'] = true;
|
||||||
|
|
||||||
// allowed themes (change this from admin panel after installation)
|
// allowed themes (change this from admin panel after installation)
|
||||||
|
|
||||||
$a->config['system']['allowed_themes'] = 'dispy,quattro,testbubble,vier,darkbubble,darkzero,duepuntozero,greenzero,purplezero,quattro-green,slackr,diabook';
|
$a->config['system']['allowed_themes'] = 'dispy,quattro,testbubble,vier,darkbubble,darkzero,duepuntozero,greenzero,purplezero,quattro-green,slackr,diabook,diabook-blue';
|
||||||
|
|
||||||
// default system theme
|
// default system theme
|
||||||
|
|
||||||
|
@ -79,3 +79,12 @@ $a->config['system']['theme'] = 'duepuntozero';
|
||||||
// By default allow pseudonyms
|
// By default allow pseudonyms
|
||||||
|
|
||||||
$a->config['system']['no_regfullname'] = true;
|
$a->config['system']['no_regfullname'] = true;
|
||||||
|
|
||||||
|
// If set to true the priority settings of ostatus contacts are used
|
||||||
|
$a->config['system']['ostatus_use_priority'] = false;
|
||||||
|
|
||||||
|
// If enabled, all items are cached in the given directory
|
||||||
|
$a->config['system']['itemcache'] = "";
|
||||||
|
|
||||||
|
// If enabled, the lockpath is used for a lockfile to check if the poller is running
|
||||||
|
$a->config['system']['lockpath'] = "";
|
||||||
|
|
0
images/article.gif
Executable file → Normal file
Before Width: | Height: | Size: 1 KiB After Width: | Height: | Size: 1 KiB |
0
images/audio.gif
Executable file → Normal file
Before Width: | Height: | Size: 559 B After Width: | Height: | Size: 559 B |
0
images/b_block.gif
Executable file → Normal file
Before Width: | Height: | Size: 83 B After Width: | Height: | Size: 83 B |
0
images/b_drop.gif
Executable file → Normal file
Before Width: | Height: | Size: 138 B After Width: | Height: | Size: 138 B |
0
images/b_drop.png
Executable file → Normal file
Before Width: | Height: | Size: 311 B After Width: | Height: | Size: 311 B |
0
images/b_drophide.gif
Executable file → Normal file
Before Width: | Height: | Size: 111 B After Width: | Height: | Size: 111 B |
0
images/b_dropshow.gif
Executable file → Normal file
Before Width: | Height: | Size: 138 B After Width: | Height: | Size: 138 B |
0
images/b_edit.gif
Executable file → Normal file
Before Width: | Height: | Size: 311 B After Width: | Height: | Size: 311 B |
0
images/b_edit.png
Executable file → Normal file
Before Width: | Height: | Size: 451 B After Width: | Height: | Size: 451 B |
Before Width: | Height: | Size: 1 KiB After Width: | Height: | Size: 1,021 B |
BIN
images/blank.png
Normal file
After Width: | Height: | Size: 1.3 KiB |
BIN
images/bug-x.gif
Normal file
After Width: | Height: | Size: 134 B |
0
images/calendar.png
Executable file → Normal file
Before Width: | Height: | Size: 853 B After Width: | Height: | Size: 853 B |
0
images/camera-icon.gif
Executable file → Normal file
Before Width: | Height: | Size: 1,015 B After Width: | Height: | Size: 1,015 B |
0
images/connect-bg.png
Executable file → Normal file
Before Width: | Height: | Size: 689 B After Width: | Height: | Size: 689 B |
0
images/content-types.png
Executable file → Normal file
Before Width: | Height: | Size: 3.8 KiB After Width: | Height: | Size: 3.8 KiB |
0
images/default-group-mm.png
Executable file → Normal file
Before Width: | Height: | Size: 598 B After Width: | Height: | Size: 598 B |
0
images/default-profile-mm.jpg
Executable file → Normal file
Before Width: | Height: | Size: 322 B After Width: | Height: | Size: 322 B |
0
images/default-profile-sm.jpg
Executable file → Normal file
Before Width: | Height: | Size: 346 B After Width: | Height: | Size: 346 B |
0
images/default-profile.jpg
Executable file → Normal file
Before Width: | Height: | Size: 490 B After Width: | Height: | Size: 490 B |
0
images/diaspora.png
Executable file → Normal file
Before Width: | Height: | Size: 461 B After Width: | Height: | Size: 461 B |
0
images/dislike.gif
Executable file → Normal file
Before Width: | Height: | Size: 119 B After Width: | Height: | Size: 119 B |
0
images/document.gif
Executable file → Normal file
Before Width: | Height: | Size: 1.3 KiB After Width: | Height: | Size: 1.3 KiB |
0
images/ff-128.jpg
Executable file → Normal file
Before Width: | Height: | Size: 4.4 KiB After Width: | Height: | Size: 4.4 KiB |
0
images/ff-16.jpg
Executable file → Normal file
Before Width: | Height: | Size: 644 B After Width: | Height: | Size: 644 B |
0
images/ff-256.jpg
Executable file → Normal file
Before Width: | Height: | Size: 2.7 KiB After Width: | Height: | Size: 2.7 KiB |
0
images/ff-32.jpg
Executable file → Normal file
Before Width: | Height: | Size: 1.6 KiB After Width: | Height: | Size: 1.6 KiB |
0
images/ff-64.jpg
Executable file → Normal file
Before Width: | Height: | Size: 2.8 KiB After Width: | Height: | Size: 2.8 KiB |
0
images/ff.xcf
Executable file → Normal file
0
images/friendica-128.jpg
Executable file → Normal file
Before Width: | Height: | Size: 8.2 KiB After Width: | Height: | Size: 8.2 KiB |
0
images/friendica-128.png
Executable file → Normal file
Before Width: | Height: | Size: 6.3 KiB After Width: | Height: | Size: 6.3 KiB |
0
images/friendica-16.jpg
Executable file → Normal file
Before Width: | Height: | Size: 659 B After Width: | Height: | Size: 659 B |
0
images/friendica-16.png
Executable file → Normal file
Before Width: | Height: | Size: 756 B After Width: | Height: | Size: 756 B |
0
images/friendica-1600.png
Executable file → Normal file
Before Width: | Height: | Size: 280 KiB After Width: | Height: | Size: 280 KiB |
0
images/friendica-256.jpg
Executable file → Normal file
Before Width: | Height: | Size: 17 KiB After Width: | Height: | Size: 17 KiB |
0
images/friendica-256.png
Executable file → Normal file
Before Width: | Height: | Size: 10 KiB After Width: | Height: | Size: 10 KiB |
0
images/friendica-32.jpg
Executable file → Normal file
Before Width: | Height: | Size: 1.5 KiB After Width: | Height: | Size: 1.5 KiB |
0
images/friendica-32.png
Executable file → Normal file
Before Width: | Height: | Size: 1.6 KiB After Width: | Height: | Size: 1.6 KiB |
0
images/friendica-48.png
Executable file → Normal file
Before Width: | Height: | Size: 2.3 KiB After Width: | Height: | Size: 2.3 KiB |
0
images/friendica-64.jpg
Executable file → Normal file
Before Width: | Height: | Size: 3.4 KiB After Width: | Height: | Size: 3.4 KiB |
0
images/friendica-64.png
Executable file → Normal file
Before Width: | Height: | Size: 3.2 KiB After Width: | Height: | Size: 3.2 KiB |
0
images/friendica-96.png
Executable file → Normal file
Before Width: | Height: | Size: 5.4 KiB After Width: | Height: | Size: 5.4 KiB |
0
images/friendica.svg
Executable file → Normal file
Before Width: | Height: | Size: 7.2 KiB After Width: | Height: | Size: 7.2 KiB |
0
images/friendika-128.jpg
Executable file → Normal file
Before Width: | Height: | Size: 8.2 KiB After Width: | Height: | Size: 8.2 KiB |
0
images/friendika-128.png
Executable file → Normal file
Before Width: | Height: | Size: 6.3 KiB After Width: | Height: | Size: 6.3 KiB |
0
images/friendika-16.jpg
Executable file → Normal file
Before Width: | Height: | Size: 659 B After Width: | Height: | Size: 659 B |
0
images/friendika-16.png
Executable file → Normal file
Before Width: | Height: | Size: 756 B After Width: | Height: | Size: 756 B |
0
images/friendika-1600.png
Executable file → Normal file
Before Width: | Height: | Size: 280 KiB After Width: | Height: | Size: 280 KiB |
0
images/friendika-256.jpg
Executable file → Normal file
Before Width: | Height: | Size: 17 KiB After Width: | Height: | Size: 17 KiB |
0
images/friendika-256.png
Executable file → Normal file
Before Width: | Height: | Size: 10 KiB After Width: | Height: | Size: 10 KiB |
0
images/friendika-32.jpg
Executable file → Normal file
Before Width: | Height: | Size: 1.5 KiB After Width: | Height: | Size: 1.5 KiB |
0
images/friendika-32.png
Executable file → Normal file
Before Width: | Height: | Size: 1.6 KiB After Width: | Height: | Size: 1.6 KiB |
0
images/friendika-48.png
Executable file → Normal file
Before Width: | Height: | Size: 2.3 KiB After Width: | Height: | Size: 2.3 KiB |
0
images/friendika-64.jpg
Executable file → Normal file
Before Width: | Height: | Size: 3.4 KiB After Width: | Height: | Size: 3.4 KiB |
0
images/friendika-64.png
Executable file → Normal file
Before Width: | Height: | Size: 3.2 KiB After Width: | Height: | Size: 3.2 KiB |
0
images/friendika-96.png
Executable file → Normal file
Before Width: | Height: | Size: 5.4 KiB After Width: | Height: | Size: 5.4 KiB |
0
images/friendika.svg
Executable file → Normal file
Before Width: | Height: | Size: 7.2 KiB After Width: | Height: | Size: 7.2 KiB |
0
images/globe.gif
Executable file → Normal file
Before Width: | Height: | Size: 1 KiB After Width: | Height: | Size: 1 KiB |
0
images/hide_off.png
Executable file → Normal file
Before Width: | Height: | Size: 281 B After Width: | Height: | Size: 281 B |
0
images/hide_on.png
Executable file → Normal file
Before Width: | Height: | Size: 277 B After Width: | Height: | Size: 277 B |
0
images/icons.png
Executable file → Normal file
Before Width: | Height: | Size: 12 KiB After Width: | Height: | Size: 12 KiB |
0
images/icons/10/add.png
Executable file → Normal file
Before Width: | Height: | Size: 2.9 KiB After Width: | Height: | Size: 2.9 KiB |
0
images/icons/10/delete.png
Executable file → Normal file
Before Width: | Height: | Size: 2.9 KiB After Width: | Height: | Size: 2.9 KiB |
0
images/icons/10/edit.png
Executable file → Normal file
Before Width: | Height: | Size: 2.9 KiB After Width: | Height: | Size: 2.9 KiB |
0
images/icons/10/feed.png
Executable file → Normal file
Before Width: | Height: | Size: 535 B After Width: | Height: | Size: 535 B |
0
images/icons/10/gear.png
Executable file → Normal file
Before Width: | Height: | Size: 3 KiB After Width: | Height: | Size: 3 KiB |
0
images/icons/10/group.png
Executable file → Normal file
Before Width: | Height: | Size: 543 B After Width: | Height: | Size: 543 B |
0
images/icons/10/info.png
Executable file → Normal file
Before Width: | Height: | Size: 488 B After Width: | Height: | Size: 488 B |
0
images/icons/10/link.png
Executable file → Normal file
Before Width: | Height: | Size: 410 B After Width: | Height: | Size: 410 B |