Revision 566 (by ahitrov, 2016/04/19 21:56:45) |
Bug during existing phone storing
|
<%args>
$object
$name => undef
$SETS => undef
</%args>
<%init>
return undef unless ref $SETS;
return undef unless $name;
my @props = $object->structure();
my ($prop) = grep { $_->{attr} eq $name } @props;
return undef unless ref $prop;
if ( $state->{users}->use_credentials && $object->id ) {
my %struct;
while ( my ($key, $val) = each %$SETS ) {
my $template = $name.'_name_orig_';
if ( $key =~ /^$template/ ) {
my $id = $key =~ /(\d+)/ ? $1 : 'new';
if ( $keeper->{users}->_phone_format( $val ) ) {
$struct{$id}{orig} = $val;
$struct{$id}{name} = $keeper->{users}->_phone_reduction($val);
$struct{$id}{format} = $keeper->{users}->_phone_format($val);
$struct{$id}{id} = $id;
}
}
$template = $name.'_active_';
if ( $key =~ /^$template/ ) {
my $id = $key =~ /(\d+)/ ? $1 : 'new';
if ( $val ) {
$struct{$id}{status} = 1;
$struct{$id}{id} = $id;
}
}
}
if ( exists $SETS->{$name.'.delete'} ) {
if ( ref $SETS->{$name.'.delete'} eq 'ARRAY' ) {
map { $struct{$_}{delete} = 1 } @{$SETS->{$name.'.delete'}};
} elsif ( $SETS->{$name.'.delete'} ) {
$struct{$SETS->{$name.'.delete'}}{delete} = 1;
}
}
if ( exists $SETS->{$name.'.main'} && $SETS->{$name.'.main'} && exists $struct{$SETS->{$name.'.main'}} && !exists $struct{$SETS->{$name.'.main'}}{delete} ) {
$struct{$SETS->{$name.'.main'}}{main} = 1;
} elsif ( exists $struct{new} ) {
$struct{new}{main} = 1;
} else {
my @main = grep { exists $_->{name} && exists $_->{main} && $_->{main} && !exists $_->{delete} } values %struct;
unless ( @main ) {
my @valid = grep { exists $_->{name} && !exists $_->{delete} } values %struct;
if ( @valid ) {
$valid[0]->{main} = 1;
}
}
}
my @delete_ids = map { $_->{id} } grep { $_->{id} && exists $_->{delete} } values %struct;
if ( @delete_ids ) {
my $sql = $keeper->SQL->prepare('delete from profile_credentials where class = ? and uid = ? and id in ('.join(',', map {'?'} @delete_ids).')');
$sql->execute( 'users::Phone', $object->id, @delete_ids );
$sql->finish;
}
my @credentials = $keeper->get_documents(
class => 'users::Phone',
uid => $object->id,
order_by => 'main desc, name',
);
foreach my $cred ( @credentials ) {
my $check = exists $struct{$cred->id} ? $struct{$cred->id} : undef;
my $store = 0;
if ( ref $check && exists $check->{name} && ($cred->name ne $check->{name} || $cred->name_orig ne $check->{orig}) ) {
my $exists_foreign = $keeper->get_documents( class => 'users::Phone', name => $check->{name}, uid_not => $object->id, count => 1 );
unless ( $exists_foreign ) {
$cred->name( $check->{name} );
$cred->name_orig( $check->{orig} );
$cred->name_format( $check->{format} );
$store = 1;
}
}
if ( ref $check && int($check->{main}) != int($cred->main) ) {
$cred->main( int($check->{main}) );
$store = 1;
}
if ( ref $check && int($check->{status}) != int($cred->status) ) {
$cred->status( int($check->{status}) );
$store = 1;
}
if ( $store ) {
$cred->store;
}
}
if ( exists $struct{new} && exists $struct{new}{name} ) {
my @found = grep { $_->name eq $struct{new}{name} } @credentials;
unless ( @found ) {
my $check = $struct{new};
my $exists_foreign = $keeper->get_documents( class => 'users::Phone', name => $check->{name}, count => 1 );
unless ( $exists_foreign ) {
my $cred = $object->create_credential( phone => $check->{orig}, main => $check->{main}, status => ($check->{status} || 0) );
push @credentials, $cred if ref $cred;
}
}
}
my ($main) = grep { $_->main } @credentials;
$object->{$name.'s'} = \@credentials;
return $main;
} else {
return $keeper->{users}->_phone_format( $SETS->{$name} );
}
</%init>
Небольшая справка по веткам
cnddist – контейнер, в котором хранятся все дистрибутивы всех библиотек и программных пакетов, которые использовались при построении различных версий Contenido. Если какой-то библиотеки в данном хранилище нет, инсталлятор сделает попытку "подтянуть" ее с веба (например, с CPAN). Если библиотека слишком старая, есть очень большая вероятность, что ее там уже нет. Поэтому мы храним весь хлам от всех сборок. Если какой-то дистрибутив вдруг отсутствует в cnddist - напишите нам, мы положим его туда.
koi8 – отмирающая ветка, чей код, выдача и все внутренние библиотеки заточены на кодировку KOI8-R. Вносятся только те дополнения, которые касаются внешнего вида и функционала админки, баги ядра, обязательные обновления портов и мелочи, которые легко скопипастить. В дальнейшем планируется полная остановка поддержки по данной ветке.
utf8 – актуальная ветка, заточенная под UTF-8.
Внутри каждой ветки: core – исходники ядра; install – скрипт установки инсталляции; plugins – плагины; samples – "готовые к употреблению" проекты, которые можно поставить, запустить и посмотреть, как они работают.