Mudanças entre as edições de "Wiki"

De Instituto de Física - UFRGS
Linha 4: Linha 4:
 
* [[Requisitos servidor]]
 
* [[Requisitos servidor]]
  
Baixar mediawiki no diretório /var/www/wikis/
+
a) Baixar mediawiki no diretório /var/www/wikis/
 
     cd /var/www/wikis
 
     cd /var/www/wikis
  
 
     wget http://releases.wikimedia.org/mediawiki/1.25/mediawiki-1.25.2.tar.gz
 
     wget http://releases.wikimedia.org/mediawiki/1.25/mediawiki-1.25.2.tar.gz
  
- Descompactar e alterar nome
+
b) Descompactar e alterar nome
 
     tar -zxf mediawiki-1.25.2.tar.gz
 
     tar -zxf mediawiki-1.25.2.tar.gz
  
Linha 15: Linha 15:
 
     cp -r mediawiki-1.25.2 nome_da_wiki_ssl
 
     cp -r mediawiki-1.25.2 nome_da_wiki_ssl
  
- Alterar permissões
+
c) Alterar permissões
 
<!--    chown -R www-data:www-data /var/www/wikis/nome_da_wiki_80 -->
 
<!--    chown -R www-data:www-data /var/www/wikis/nome_da_wiki_80 -->
 
     chown -R www-data:www-data /var/www/wikis/nome_da_wiki_ssl
 
     chown -R www-data:www-data /var/www/wikis/nome_da_wiki_ssl
Linha 22: Linha 22:
  
 
<!-- - Editar httpd.conf
 
<!-- - Editar httpd.conf
 
 
     vi /etc/apache2/httpd.conf
 
     vi /etc/apache2/httpd.conf
 
 
incluir linha:
 
incluir linha:
 
 
     NameVirtualHost nome_da_wiki.if.ufrgs.br:80
 
     NameVirtualHost nome_da_wiki.if.ufrgs.br:80
 
-->
 
-->
  
- Criar arquivo
+
  cd /etc/apache2/sites-available/
  
    cd /etc/apache2/sites-available/
+
d) Criar arquivos
  
-- http
+
 
 +
d.1) http
  
 
     nano nome_da_wiki_80
 
     nano nome_da_wiki_80
Linha 50: Linha 48:
 
           CustomLog /var/log/apache2/'''nome_da_wiki'''-access.log combined
 
           CustomLog /var/log/apache2/'''nome_da_wiki'''-access.log combined
 
         </VirtualHost>
 
         </VirtualHost>
-- https
+
 
 +
d.2) https
 +
 
 
     nano nome_da_wiki_ssl
 
     nano nome_da_wiki_ssl
 +
 
Incluir:
 
Incluir:
  
Linha 74: Linha 75:
  
  
- Criar link
+
e) Criar link
 
       cd /etc/apache2/sites-enabled
 
       cd /etc/apache2/sites-enabled
 
       ln -s  ../sites-available/'''nome_da_wiki_ssl''' '''nome_da_wiki'''
 
       ln -s  ../sites-available/'''nome_da_wiki_ssl''' '''nome_da_wiki'''
 
       ln -s  ../sites-available/'''nome_da_wiki_80''' '''nome_da_wiki_80'''
 
       ln -s  ../sites-available/'''nome_da_wiki_80''' '''nome_da_wiki_80'''
  
- Reiniciar Serviço
+
f) Reiniciar Serviço
 
       /etc/init.d/apache2 restart
 
       /etc/init.d/apache2 restart
 +
  
 
== Etapa 2 (Gaya) ==
 
== Etapa 2 (Gaya) ==
Linha 248: Linha 250:
  
 
  chmod go-rw LocalSettings.php
 
  chmod go-rw LocalSettings.php
 +
  
 
'''Alterar wiki para Login seguro'''
 
'''Alterar wiki para Login seguro'''
 +
 +
a) Alterar as seguintes variáveis em "includes/DefaultSettings.php"
 +
 +
$wgServer          = "//wiki.if.ufrgs.br";
 +
 +
$wgSecureLogin      = true;
 +
 +
b) Em LocalSetting.php, comentar a linha
 +
 +
$wgServer = "http://nome_wiki.if.ufrgs.br";     
 +
 +
 +
Utilizando-se este método não é necessário dois folders com o código fonte da mediawiki como "nome_da_wiki_80" e "nome_da_wiki_ssl".
 +
 +
 +
'''Forma antiga de alterar wiki para Login seguro'''
  
 
languages/messages/MessagesPt_br.php
 
languages/messages/MessagesPt_br.php
Linha 273: Linha 292:
  
 
Comentar linhas 36 a 42, 43 a 50, 57 a 65 e 68 a 77
 
Comentar linhas 36 a 42, 43 a 50, 57 a 65 e 68 a 77
 
 
'''Segunda forma de alterar wiki para Login seguro'''
 
 
a) Alterar as seguintes variáveis em "includes/DefaultSettings.php"
 
 
$wgServer          = "//wiki.if.ufrgs.br";
 
 
$wgSecureLogin      = true;
 
 
b) Em LocalSetting.php, comentar a linha
 
 
$wgServer = "http://nome_wiki.if.ufrgs.br";     
 
 
 
Utilizando-se este método não é necessário dois folders com o código fonte da mediawiki como "nome_da_wiki_80" e "nome_da_wiki_ssl".
 

Edição das 10h27min de 27 de janeiro de 2016

Como criar wikis

Etapa 1 (Helsinque)

a) Baixar mediawiki no diretório /var/www/wikis/

    cd /var/www/wikis
    wget http://releases.wikimedia.org/mediawiki/1.25/mediawiki-1.25.2.tar.gz

b) Descompactar e alterar nome

    tar -zxf mediawiki-1.25.2.tar.gz
    cp -r mediawiki-1.25.2 nome_da_wiki_ssl

c) Alterar permissões

    chown -R www-data:www-data /var/www/wikis/nome_da_wiki_ssl

APACHE


  cd /etc/apache2/sites-available/

d) Criar arquivos


d.1) http

    nano nome_da_wiki_80

Incluir:

       <VirtualHost nome_da_wiki.if.ufrgs.br:80>
           ServerAdmin webadmin@if.ufrgs.br
           DocumentRoot /var/www/wikis/nome_da_wiki_ssl
          <Directory /var/www/wikis/nome_da_wiki_ssl>
               Options Indexes FollowSymLinks
               AllowOverride None
          </Directory>
          ErrorLog /var/log/apache2/nome_da_wiki-error.log
          LogLevel warn
          CustomLog /var/log/apache2/nome_da_wiki-access.log combined
       </VirtualHost>

d.2) https

    nano nome_da_wiki_ssl

Incluir:

     <VirtualHost nome_da_wiki.if.ufrgs.br:443>
       ServerAdmin webadmin@if.ufrgs.br
       DocumentRoot /var/www/wikis/nome_da_wiki_ssl
               ServerName helsinque.if.ufrgs.br
               SSLEngine on
               RewriteEngine On
               SSLCertificateFile \
               /etc/ssl/cominf.if.ufrgs.br.cert
               SSLCertificateKeyFile \
               /etc/ssl/helsinque.if.ufrgs.br.key.unsecurity
       <Directory /var/www/wikis/nome_da_wiki_ssl>
               Options Indexes FollowSymLinks
               AllowOverride None
       </Directory>
       ErrorLog /var/log/apache2/nome_da_wiki-error.log
       LogLevel warn
       CustomLog /var/log/apache2/nome_da_wiki-access.log combined
     </VirtualHost>


e) Criar link

     cd /etc/apache2/sites-enabled
     ln -s  ../sites-available/nome_da_wiki_ssl nome_da_wiki
     ln -s  ../sites-available/nome_da_wiki_80 nome_da_wiki_80

f) Reiniciar Serviço

     /etc/init.d/apache2 restart


Etapa 2 (Gaya)

DNS

- Editar dns

    cd /etc/bind/
    vi cnames.txt

Incluir:

      Nome_da_wiki CNAME helsinque (ou servidor de wikis atual)

- Reiniciar serviço

    cd ..
    ./dns-update.sh

BANCO DE DADOS -

- Acessar banco

     mysql -p
     (colocar senha do banco de dados)

- Criar Banco de dados

     mysql>show databases;
     mysql>create database wiki_nome_da_wiki;

- Dar acesso ao usuário wiki_user ao banco criado

     mysql> GRANT SELECT,INSERT,UPDATE,DELETE,CREATE,DROP,INDEX,ALTER ON wiki_nome_da_wiki.* TO wiki_user@143.54.40.45;

- reiniciar serviço

     /etc/init.d/mysql restart

Etapa 3 (Rosen)

- Incluir arquivo na base LDAP com pessoas autorizadas a modificar a wiki. Ou seja, incluir um novo "entry" na árvore da base de dados do LDAP. Isto pode ser feito através do programa lbe.sh.

dn: cn=w_nome_da_wiki,ou=grupos,ou=dominio, dc=if
gidNumber: número (cada novo entry deve ter um novo gidNumber)
memberUid: User
userPassword:: e2NyeXB0fSo=
objectClass: posixGroup
objectClass: top
cn: w_nome_da_wiki

ATENÇÃO:

1)Colocar primeira letra em maiúscula no nome do usuário.

2)Isto não é necessário na wiki.if.ufrgs.br, pois ela está utilizando uma nova versão da extensão LDAP Authentication ( >2.0 tem um LDAPLowercaseUsernameScheme).

  • No browser

- Abrir o site da wiki feita para fazer a configuração

http://nome_da_wiki.if.ufrgs.br

- Algumas configurações:

wiki name: NOME DA WIKI
contact e-mail webadmin@if.ufrgs.br
Admin username: wiki_user
Password:
Object caching: No caching
Database type: MySQL
Database host: 143.54.40.2
Database name: wiki_nome_da_wiki
DB username: wiki_user
DB password (senha do usuário do banco de dados)
Database table prefix: mw_

Etapa 4 (Helsique)

- Após a finalização das configurações, um arquivo chamado LocalSettings.php será criado em /var/www/wikis/nome_da_wiki/config. Mover um diretório acima:

mv /var/www/wikis/nome_da_wiki/config/LocalSettings.php  /var/www/wikis/nome_da_wiki/

- Incluir as linhas abaixo no arquivo LocalSettings.php com caminho do LDAP correto:

#################################################################
$wgGroupPermissions['*']['edit'] = false;
$wgGroupPermissions['*']['createaccount'] = false;
require_once( 'includes/LdapAuthentication.php' );
$wgAuth = new LdapAuthenticationPlugin();
#$wgLDAPUseLocal = true;
$wgLDAPDomainNames = array(
 'IF'
);
$wgLDAPServerNames = array(
 'IF' => '143.54.40.8'
);
$wgLDAPSearchStrings = array(
 'IF' => 'uid=USER-NAME,ou=usuarios,ou=dominio,dc=if'
);
$wgLDAPEncryptionType = array(
 'IF' => 'clear'
);
#######################
$wgLDAPRequiredGroups = array( "IF"=>array("cn=w_nome_da_wiki,ou=grupos,ou=dominio,dc=if") );
$wgLDAPGroupUseFullDN = array( "IF"=>false );
$wgLDAPGroupObjectclass = array( "IF"=>"posixgroup" );
$wgLDAPGroupAttribute = array( "IF"=>"memberuid" );
$wgLDAPGroupSearchNestedGroups = array( "IF"=>false );
$wgLDAPGroupNameAttribute = array( "IF"=>"cn" );
$wgLDAPBaseDNs = array( "IF"=>"ou=dominio,dc=if" );
#######################
$wgMinimalPasswordLength = 1;
$wgLDAPDebug = 3;
$wgDebugLogGroups["ldap"] = "/tmp/debug.log" ;
#################################################################

- Copiar o arquivo LdapAuthentication.php:

cp /root/LdapAuthentication.php /var/www/wikis/nome_da_wiki_ssl/includes/

- Criar diretório /schema/

mkdir /var/www/wikis/nome_da_wiki_ssl/includes/schema

- Criar arquivos nesse novo diretorio

cd /var/www/wikis/nome_da_wiki_ssl/includes/schema

- mysql

nano ldap-mysql.sql

- Incluir:

CREATE TABLE /*_*/ldap_domains (
        -- IF for domain
        domain_id int not null primary key auto_increment,

        -- domain itself
        domain varchar(255) binary not null,

        -- User to which this domain belongs
        user_id int not null

) /*$wgDBTableOptions*/;

CREATE INDEX /*i*/user_id on /*_*/ldap_domains (user_id);

- postgres

nano ldap-postgres.sql

Incluir:

CREATE TABLE ldap_domains (
        -- IF for domain
        domain_id serial PRIMARY KEY,

        -- domain itself
        domain varchar(255) not null,

        -- User to which this domain belongs
        user_id integer not null

) /*$wgDBTableOptions*/;

CREATE INDEX user_id on ldap_domains (user_id);

- Alterar permissões

chown -R www-data.www-data /var/www/wikis/nome_da_wiki
chmod go-rw LocalSettings.php


Alterar wiki para Login seguro

a) Alterar as seguintes variáveis em "includes/DefaultSettings.php"

$wgServer = "//wiki.if.ufrgs.br";

$wgSecureLogin = true;

b) Em LocalSetting.php, comentar a linha

$wgServer = "http://nome_wiki.if.ufrgs.br";


Utilizando-se este método não é necessário dois folders com o código fonte da mediawiki como "nome_da_wiki_80" e "nome_da_wiki_ssl".


Forma antiga de alterar wiki para Login seguro

languages/messages/MessagesPt_br.php linha 555

'loginprompt' => 'É necessário estar com os cookies ativados para poder autenticar-se na Instituto de Física - UFRGS.',

para

'loginprompt' => 'Direcionando para login seguro. Por favor, aguarde...                                                   ',

includes/templates/Userlogin.php

Na primeira linha:

<meta HTTP-EQUIV="REFRESH" content="0; url=https://pagina.if.ufrgs.br/index.php?title=Especial:Entrar&returnto=Especial:Entrar">

Ou (versão 1.23.4)

<meta HTTP-EQUIV="REFRESH" content="0; url=https://wiki.if.ufrgs.br/index.php?title=Especial:Autenticar-se&returnto=P%C3%A1gina+principal">

Isto pode variar de acordo com a versão da wiki.

Comentar linhas 36 a 42, 43 a 50, 57 a 65 e 68 a 77