basic identity creation
This commit is contained in:
parent
2456174cc9
commit
b08d070e15
@ -1,10 +1,51 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
require_once('include/zot.php');
|
||||||
|
require_once('include/crypto.php');
|
||||||
|
|
||||||
function create_identity($arr) {
|
function create_identity($arr) {
|
||||||
|
|
||||||
|
$ret = array('success' => false, 'message' => '');
|
||||||
|
$nick = trim($_POST['nickname']);
|
||||||
|
$name = escape_tags($_POST['name']);
|
||||||
|
|
||||||
|
if(check_webbie(array($nick)) !== 'nick') {
|
||||||
|
$ret['message'] = t('Nickname has unsupported characters or is already being used on this site.');
|
||||||
|
return $ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
$guid = zot_new_uid($nick);
|
||||||
|
$key = new_keypair(4096);
|
||||||
|
|
||||||
|
$primary = true;
|
||||||
|
|
||||||
|
$r = q("insert into entity ( entity_account_id, entity_primary,
|
||||||
|
entity_name, entity_address, entity_global_id, entity_prvkey,
|
||||||
|
entity_pubkey, entity_pageflags )
|
||||||
|
values( %d, %d, '%s', '%s', '%s' '%s', '%s', %d ) ",
|
||||||
|
|
||||||
|
intval(local_user()),
|
||||||
|
intval($primary),
|
||||||
|
dbesc($name),
|
||||||
|
dbesc($nick),
|
||||||
|
dbesc($guid),
|
||||||
|
dbesc($key['prvkey']),
|
||||||
|
dbesc($key['pubkey']),
|
||||||
|
intval(PAGE_NORMAL)
|
||||||
|
);
|
||||||
|
|
||||||
|
$r = q("select * from entity where entity_account_id = %d
|
||||||
|
and entity_global_id = '%s' limit 1",
|
||||||
|
intval(local_user()),
|
||||||
|
dbesc($guid)
|
||||||
|
);
|
||||||
|
if(! ($r && count($r))) {
|
||||||
|
$ret['message'] = t('Unable to retrieve created identity');
|
||||||
|
return $ret;
|
||||||
|
}
|
||||||
|
$ret['entity'] = $r[0];
|
||||||
|
$ret['success'] = true;
|
||||||
|
return $ret;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
require_once('include/identity.php');
|
||||||
|
|
||||||
function zentity_init(&$a) {
|
function zentity_init(&$a) {
|
||||||
$a->page['template'] = 'full';
|
|
||||||
|
|
||||||
$cmd = ((argc() > 1) ? argv(1) : '');
|
$cmd = ((argc() > 1) ? argv(1) : '');
|
||||||
|
|
||||||
@ -50,8 +50,6 @@ function zentity_init(&$a) {
|
|||||||
for($y = 0; $y < 100; $y ++)
|
for($y = 0; $y < 100; $y ++)
|
||||||
$test[] = 'id' . mt_rand(1000,9999);
|
$test[] = 'id' . mt_rand(1000,9999);
|
||||||
|
|
||||||
//print_r($test);
|
|
||||||
|
|
||||||
json_return_and_die(check_webbie($test));
|
json_return_and_die(check_webbie($test));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -61,58 +59,24 @@ function zentity_init(&$a) {
|
|||||||
|
|
||||||
function zentity_post(&$a) {
|
function zentity_post(&$a) {
|
||||||
|
|
||||||
$verified = 0;
|
$arr = $_POST;
|
||||||
$blocked = 1;
|
|
||||||
|
|
||||||
$arr = array('post' => $_POST);
|
if(($uid = intval(local_user())) == 0) {
|
||||||
call_hooks('zregister_post', $arr);
|
|
||||||
|
|
||||||
$max_dailies = intval(get_config('system','max_daily_registrations'));
|
|
||||||
if($max_dailies) {
|
|
||||||
$r = q("select count(*) as total from account where account_created > UTC_TIMESTAMP - INTERVAL 1 day");
|
|
||||||
if($r && $r[0]['total'] >= $max_dailies) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
switch(get_config('system','register_policy')) {
|
|
||||||
|
|
||||||
case REGISTER_OPEN:
|
|
||||||
$blocked = 0;
|
|
||||||
$verified = 0;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case REGISTER_APPROVE:
|
|
||||||
$blocked = 0;
|
|
||||||
$verified = 0;
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
case REGISTER_CLOSED:
|
|
||||||
// TODO check against service class and fix this line
|
|
||||||
if((! x($_SESSION,'authenticated') && (! x($_SESSION,'administrator')))) {
|
|
||||||
notice( t('Permission denied.') . EOL );
|
notice( t('Permission denied.') . EOL );
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
$blocked = 1;
|
|
||||||
$verified = 0;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
require_once('include/account.php');
|
$result = create_identity($arr);
|
||||||
|
|
||||||
$arr = $_POST;
|
|
||||||
|
|
||||||
$arr['blocked'] = $blocked;
|
|
||||||
$arr['verified'] = $verified;
|
|
||||||
|
|
||||||
$result = create_account($arr);
|
|
||||||
|
|
||||||
if(! $result['success']) {
|
if(! $result['success']) {
|
||||||
notice($result['message']);
|
notice($result['message']);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
$user = $result['user'];
|
$user = $result['user'];
|
||||||
|
|
||||||
$using_invites = get_config('system','invitation_only');
|
$using_invites = get_config('system','invitation_only');
|
||||||
|
Reference in New Issue
Block a user