воскресенье, 18 декабря 2011 г.

суббота, 17 декабря 2011 г.

Установка svn сервера в Ubuntu


Для начала установим SVN.
sudo apt-get install subversion
Создадим репозитаий
svnadmin create /var/svn
Создадим новую группу пользователей svn и добавим в неё пользователя svn

groupadd -g 56 svn && useradd -c "SVN Owner" -d /home/svn -m -g svn -s /bin/false -u 56 svn

Сменим группу владельца у репозитария
chown -R svn:svn /var/svn
Установим доступ
chmod -R ug+rw /var/svn
Мы настроили защищенный доступ к репозитарию для людей из группы svn. Чтобы был сетевой доступ, нам необходимо запустить svnserve. Для этого создадим задачу в init.d

#! /bin/sh
### BEGIN INIT INFO
# Provides:          svnserve
# Required-Start:    $local_fs $syslog $remote_fs
# Required-Stop:     $local_fs $syslog $remote_fs
# Default-Start:     2 3 4 5
# Default-Stop:      0 1 6
# Short-Description: Start svnserve
### END INIT INFO


PATH=/sbin:/usr/sbin:/bin:/usr/bin
DESC="svnserve"
NAME=svnserve
DAEMON=/usr/bin/$NAME
DAEMON_ARGS="-d -r /var/svn"
PIDFILE=/var/run/$NAME.pid
SCRIPTNAME=/etc/init.d/$NAME


[ -x "$DAEMON" ] || exit 0


[ -r /etc/default/$NAME ] && . /etc/default/$NAME


. /lib/init/vars.sh


. /lib/lsb/init-functions


do_start()
{
start-stop-daemon --start --quiet --pidfile $PIDFILE --chuid svn:svn --exec $DAEMON --test > /dev/null \
|| return 1
start-stop-daemon --start --quiet --pidfile $PIDFILE --chuid svn:svn --exec $DAEMON -- \
$DAEMON_ARGS \
|| return 2
}


do_stop()
{
start-stop-daemon --stop --quiet --retry=TERM/30/KILL/5 --pidfile $PIDFILE --name $NAME
RETVAL="$?"
[ "$RETVAL" = 2 ] && return 2
start-stop-daemon --stop --quiet --oknodo --retry=0/30/KILL/5 --exec $DAEMON
[ "$?" = 2 ] && return 2
rm -f $PIDFILE
return "$RETVAL"
}


case "$1" in
  start)
[ "$VERBOSE" != no ] && log_daemon_msg "Starting $DESC" "$NAME"
do_start
case "$?" in
0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
esac
;;
  stop)
[ "$VERBOSE" != no ] && log_daemon_msg "Stopping $DESC" "$NAME"
do_stop
case "$?" in
0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
esac
;;
  restart|force-reload)
log_daemon_msg "Restarting $DESC" "$NAME"
do_stop
case "$?" in
 0|1)
do_start
case "$?" in
0) log_end_msg 0 ;;
1) log_end_msg 1 ;; # Old process is still running
*) log_end_msg 1 ;; # Failed to start
esac
;;
 *)
  # Failed to stop
log_end_msg 1
;;
esac
;;
  *)
echo "Usage: $SCRIPTNAME {start|stop|restart|force-reload}" >&2
exit 3
;;
esac


exit 0

Теперь добавляем автозагрузку при старте
update-rc.d svnserve defaults
и запускаем
sudo /etc/init.d/svnserve start


правим файлы конфиги /var/svn/conf/*

четверг, 14 июля 2011 г.

array function array_unique in postgresql

CREATE FUNCTION array_unique(anyarray)
  RETURNS anyarray
  language sql
as $FUNCTION$
    SELECT ARRAY(
SELECT id FROM (
SELECT UNNEST($1) as id
) t
GROUP BY id
ORDER BY count(*) desc
    );
$FUNCTION$;

array function array_size in postgresql

CREATE OR REPLACE FUNCTION array_size(anyarray)
  RETURNS bigint
  language sql
as $FUNCTION$
    SELECT count(*) FROM (
        SELECT UNNEST($1)
    ) t;
$FUNCTION$;

среда, 13 июля 2011 г.

array function array_diff in postgresql

CREATE OR REPLACE FUNCTION array_diff(anyarray, anyarray)
  RETURNS anyarray
  language sql
as $FUNCTION$
    SELECT ARRAY(
        SELECT * FROM (SELECT UNNEST($1) as element) t WHERE element not in (SELECT UNNEST($2))
    );
$FUNCTION$;

array aggregate and function array_union like union all in postgresql

CREATE FUNCTION array_union(anyarray, anyarray)
  RETURNS anyarray
  language sql
as $FUNCTION$
    SELECT ARRAY(
        SELECT UNNEST($1)
        UNION ALL
        SELECT UNNEST($2)
    );
$FUNCTION$;


CREATE AGGREGATE array_union (anyarray)
(
sfunc = array_union,
stype = anyarray,
initcond = '{}'
);

array function array_intersect in postgresql

CREATE FUNCTION array_intersect(anyarray, anyarray)
  RETURNS anyarray
  language sql
as $FUNCTION$
    SELECT ARRAY(
        SELECT UNNEST($1)
        INTERSECT
        SELECT UNNEST($2)
    );
$FUNCTION$;