Escrito por Helio Loureiro
Categoria:

Eu me sinto bastante solidário com as pessoas que investiram no TelexFree e acho muito injusto que saiam com tal prejuízo financeiro.  Como fizeram um investimento em tecnologia sem o conhecimento necessário sobre a mesma, ou até sobre o retorno do investimento, acho que vale a pena sugerir alguns negócios melhores que TelexFree.

Com certeza que são tecnologias que abrirão muitas portas para todo esse pessoal esquecido do norte do país, principalmente do estado do Acre.

Se não investiu em TelexFree e mesmo assim quiser experimentar os serviços abaixo, garanto que não se decepcionará.  São todos GRÁTIS!  Totalmente grátis!  Fácil assim.  Apenas criar uma conta e usar.  Não há investimento melhor.

Depois não digam que não ajudei.

https://one.ubuntu.com/referrals/referee/2899421/

https://db.tt/bl7SOkV

http://prezi.com/recommend/helioloureiro/

Escrito por Helio Loureiro
Categoria:

Recentemente participei de um opencast do Ivan, Ubunterobr, sobre Debian.  

O objetivo era explicar um pouco sobre o Debian, sua história, suas versões e, principalmente, como experimentar.  E também um pouco sobre comunidade, que é a parte mais importante pra nós usuários comuns.

 

Maiores informações de Debian:

Escrito por Helio Loureiro
Categoria:

Depois de uma longa batalha pra atualizar meu PC, consegui deixar tudo redondo pra jogar L4D2 (Left for Dead 2) com o pessoal.  E sobre o Ubuntu.

Um dos empecilhos era em relação às configurações de controle do jogo, que por padrão usa o mouse e o teclado.  Eu até tentei usar no início, mas estou acostumado com os consoles, xbox360 e ps3, e com seus respectivos controles.  Então era um sofrimento jogar.

Tentei utilizar os controles dos dois no Linux, mas vi na Internet que o melhor controle é o do xbox, mas não o wireless, o cabeado.  Sem problemas.  Sai caçando um e comprei na loja xing-ling de origem questionável mais próxima (na av. Paulista).

Quando fui jogar, nova decepção: não mapeava corretamente os movimentos.  Mas uma alma caridosa conseguiu fazer o mapeamento usando um driver através do programa xboxdrv (tem pra Ubuntu).

Criei então os seguinte script pra mapear o controle e jogar com os amigos:

#! /bin/sh
# Name: xbox360controler_setup.sh
# Source http://ubuntuforums.org/showthread.php?t=2002622

case `whoami` in
        root) echo "Running as root";;
        *) echo "You must run it as root.  Using sudo for that."
           sudo $0
           exit 0
esac

rmmod xpad
modprobe uinput
modprobe joydev
rmmod xpad

xboxdrv \
        -s \
        --type xbox360 \
        --deadzone 9000 \
        --dpad-as-button \
        --trigger-as-button \
        --ui-axismap "x2=REL_X:10,y2=REL_Y:10,x1=KEY_A:KEY_D,y1=KEY_W:KEY_S" \
        --ui-buttonmap "tl=KEY_LEFTSHIFT,tr=KEY_LEFTCTRL" \
        --ui-buttonmap "a=KEY_SPACE,b=KEY_C,x=KEY_1,y=KEY_R" \
        --ui-buttonmap "lb=KEY_Q,rb=KEY_E" \
        --ui-buttonmap "lt=BTN_RIGHT,rt=BTN_LEFT" \
        --ui-buttonmap "dl=KEY_LEFT,dr=KEY_RIGHT,du=KEY_UP,dd=KEY_DOWN" \
        --ui-buttonmap "back=KEY_ESC,start=KEY_ENTER"

Boa jogatina e lembre-se: se for jogar, pode me chamar.  Não garanto lá um desempenho muito bom, mas a diversão é garantida.

Escrito por Helio Loureiro
Categoria:

Dia desses eu redescobri as imagens da minha webcam.  Tirei vários screenshots usando o aplicativo cheese, desde que minha mais nova nasceu. E nem lembrava disso.

Consegui criar uma videozinho com elas, o que foi bem legal, mostrando o crescimento dela (e minha barba ficando cada vez mais branca).

 

A idéia inicial era gerar um gif animado, mas o mesmo ficou em 85 MB de tamanho.  E sem som.

Então resolvi fazer 2 coisas:

  • Um script pra ficar pegando imagens da webcam sem precisar de um aplicativo gráfico.
  • Gerar via linha de comando o gif animado.

A captura do screenshot, eu consegui fazer utilizando pygame.  O módulo já inclui vários binding pra realizar ações como capturar da webcam e salvar a imagem.  O script ficou assim:

#! /usr/bin/python -u

"""
Not only Obamas _is_ watching you...
Based in: http://stackoverflow.com/questions/15870619/python-webcam-http-streaming-and-image-capture
"""

SAVEDIR = "/home/helio/Pictures/Webcam"

import pygame, sys
import pygame.camera
import time, random

pygame.init()
pygame.camera.init()
cam = pygame.camera.Camera("/dev/video0", (640,480))

while True:
   print "Taking a shot:",
   cam.start()
   image = cam.get_image()
   cam.stop()
   
   timestamp = time.strftime("%Y-%m-%d_%H%M%S", time.localtime())
   filename = "%s/%s.jpg" % (SAVEDIR, timestamp)
   print "saving into %s" % filename
   
   pygame.image.save(image, filename)
   time.sleep(random.randrange(10) * 60)

Chamei de obamawatch.py em homenagem à espionagem da NSA nas nossas vidas, e que o presidente Obama não fez esforço nenhum pra diminuir ou mesmo evitar.  É um script super intrusivo, pois tira fotos de tempos em tempos, podendo pegar situações que... humm... não o faça se sentir muito orgulhoso.  Então é bom rodar de vez em quando.  

Pra juntar as imagens JPEG geradas em um GIF animado, usei o imagemagick com o mogrify.  Com o mogrify, na verdade, eu diminui as imagens pra 320x240 pixels, pra diminuir o tamanho.  Então usei o imagemagick pra gera o GIF.

mogrify -resize 320x240 *jpg

gm convert -delay 20 2013-09-07_1* animated-2013-09-07.gif

Com isso consegui o resultado abaixo.  Bem divertido. 

 

 

Escrito por Helio Loureiro
Categoria:

Às vezes eu escrevo programas.  Entre esse programas, alguns são daemons.
Que erro maldito!

Além da confusão com demônios, o que são daemons?

Daemons são os programas que rodam em background no sistema, não precisando de um terminal (console) anexado.  E qualquer tipo de programa pode ser um daemon, pra qualquer finalidade.

Em geral daemons seguem as seguintes regras pra se tornarem daemons:

  1. Mudar pro diretório raiz ("/").
  2. Realizar um fork().
  3. Finalizar o processo pai, ficando somente o filho, criado no fork().
  4. Realizar outro fork().
  5. Finalizar o primeiro processo filho, deixando somente o segundo, criado no segundo fork().

O segundo fork() é feito para garantir que o programa, através do segundo processo filho, seja "herdado" pelo processo init do sistema.

Em Python, sempre incluo uma função como essa:

   def Daemonize(self):
      """
      Fork to became a daemon.
      """
      
      if not self.isDaemon:
         try:
            self.run()
         except KeyboardInterrupt:
            sys.exit(0)
         return
      
      os.chdir("/")
      pid = os.fork()
      
      if (pid > 0):
         sys.exit(os.EX_OK)
      else:
         pid = os.fork()
         
         if (pid > 0):
            sys.exit(os.EX_OK)
         else:
            self.run()

Esse é parte de um método, mas poderia ser uma função.  A idéia é usar o getopt() para verificar as opções passadas e entrar no modo de daemon ou não, dependendo da opção passada, que modifica a variável booleana self.isDaemon.

Mas um dos meus programs começou a apresentar o seguinte erro:

helio@goosfraba:~$ connect_TSP.py ccn
IP already setup... skipping root access
Running as daemon
daemonized...
close failed in file object destructor:
IOError: [Errno 10] No child processes
Error in sys.excepthook:
Traceback (most recent call last):
  File "/usr/lib/python2.7/dist-packages/apport_python_hook.py", line 66, in apport_excepthook
    from apport.fileutils import likely_packaged, get_recent_crashes
RuntimeError: sys.meta_path must be a list of import hooks

Original exception was:
IOError: [Errno 10] No child processes

Inicialmente achei que era problema no "apport" com meu programa, que usa python-expect.  Mesmo com tal erro, o programa funcionava perfeitamente em background, como daemon.  Várias fontes na Internet, principalmente no Launchpad, o sistema de bug report do Ubuntu, várias pessoas reclamavam de tal erro como sendo problema do apport.

Após muito buscar a origem do problema, não no Ubuntu, mas no python, descobri que alguns file descriptors estavam causando esse erro, por continuarem abertos quando ocorria o fork().  Corrigi da seguinte forma:

   def Daemonize(self):
      """
      Fork to became a daemon.
      """
      
      if not self.isDaemon:
         try:
            self.run()
         except KeyboardInterrupt:
            sys.exit(0)
         return
      
      os.chdir("/")
      pid = os.fork()
      
      if (pid > 0):
         os.close(sys.stdin.fileno())
         os.close(sys.stout.fileno())
         os.close(sys.stderr.fileno())
         sys.exit(os.EX_OK)
      else:
         pid = os.fork()
         
         if (pid > 0):
            os.close(sys.stdin.fileno())
            os.close(sys.stdout.fileno())
            os.close(sys.stderr.fileno())
            sys.exit(os.EX_OK)
         else:
            self.run()

então bastou fechar os descritores de arquivo do STDIN, STDOU e STDERR pra ter certeza que o daemon não sairia com o erro acima.

Happy hacking :-)

Escrito por Helio Loureiro
Categoria:

Acaba de ser publicada a edição número 52 da revista Espírito Livre.  Uma edição totalmente dedicada ao FISL 14 e... com um artigo meu!!!Revista Espírito Livre n. 52

Nada muito estravagante, apenas uma descrição de como foi o FISL para mim.  E com as fotos que tirei durante todo o evento.

Infelizmente o servidor da revista Espírito Livre parece estar sofrendo o tráfego intenso, então está bastante difícil acessar a revista e baixar.  Mas aos que conseguirem (e com certeza uma hora ou outra conseguirão), espero que gostem.

Revista Espírito Livre - edição 52 - julho de 2013

Escrito por Helio Loureiro
Categoria:

Esse enviei 2 apresentações pra Python Brasil.  Uma falando sobre python-twitter (e como faço pra enviar os #FF de sexta-feira) e outra pra falar sobre python em telecomunicações.

Não tenho nada escrito ainda, e vou aguardar a confirmação do trabalho pra começar.  Se der certo, estarei em Brasília no início de outubro :-)

Escrito por Helio Loureiro
Categoria:

Finalmente resolvi adicionar meu próprio PPA, Personal Package Archive - ou Arquivo de pacote pessoal, no Launchpad do Ubuntu. Isso vai me permitir distribuir facilmente os pacotes que crio. São para uso meu, baseado num Ubuntu LTS 12.04, mas podem ajudar mais pessoas.

Pra começar, fiz um upload do backport do python-twitter 1.0.1, que funciona com a API v1.1.

python-twitter_1.0.1-1_all.deb

Para quem desejar usar meu repositório, deve bastar adicionar o PPA.

sudo add-apt-repository ppa:helioloureiro

Minha chave PGP ainda não foi adicionada, mas isso deve ser corrigido em algum commit do sistema, o que talvez demore 1 dia. Até lá, meu pacote python-twitter não aparecerá como disponível.

Meu próximo upload deve ser dos pf-kernel. Já tenho compilado as versões 3.9.5 e 3.10.0.

Escrito por Helio Loureiro
Categoria:

Quando me perguntam o que faço para trabalhar, em geral explico que atuo com pré-pago. Sem muitos detalhes.

Agora existe um vídeo que explica melhor o que faço, na área de BSS, Businness Support System, que engloba pré-pago e muitas outras coisas. Trabalho com a área de Charging atualmente, ou melhor, Charging System 5, ou ChSys como chamamos por lá (ou escrevemos). Também tenho dado uns pitacos em MBC, Mobile Broadband Charging, que consiste no controle de dados para GPRS, HSPA (3G) e LTE (4G).

Escrito por Helio Loureiro
Categoria:

Mais uma vez consegui peregrinar e me juntar ao grupo de ativistas e programadores que se reúnem uma vez ao ano em Porto Alegre, RS, para o FISL, Fórum Internacional de Software Livre.

Como sempre, foi um evento agradável e cheio de reencontros. Amigos que não via a mais de 10 anos!

Esse ano escolhi uma participação um pouco mais ativa, e fiz 2 oficinas de criação de pacotes. Na verdade a idéia era fazer uma iniciação na criação de pacotes durante a primeira oficina, e continuar com uma hackaton na segunda, mas o público da segunda oficina foi... completamente diferente da primeira! Devo supor que a primeira oficina foi um completo desastre e as pessoas desistiram de vez de fazer pacotes. E tive de re-fazer a parte didática durante a segunda, o que não permitiu corrigir nenhuma pacote oficial. Mas não deixou de ser divertido (ao menos para mim).

Além do encontro especial com os amigos, tive o prazer de participar de um churrasco numa cervejaria artesanal. Helles, ipa, weiss, red ale, pilsen... realmente um evento que deu um *gostinho* a mais ao FISL. E que gostinho bom.

Não bastasse o sabor ímpar das cervejas, descobri que quem tinha organizado a festança era a caravana de Florianópolis, da UFSC! Foi um encontro etílico do "old school" com o "new school". E tinha até o Maddog por lá.

Enfim o FISL foi mais uma vez um espetáculo. Espero ter condições para poder estar por lá no ano que vem novamente.

Escrito por Helio Loureiro
Categoria:

Não fiz muita propaganda por aqui (e devia ter feito), mas participei do FISL 14, em Porto Alegre, RS, com uma oficina de criação de pacotes DEB. Tentei criar uma sinergia de Debian com Ubuntu, sem focar em nenhum dos dois, e mostrando com pacotes pode ser criados para ambos.

Aqui está a apresentação, em prezi, que usei durante o evento.

Escrito por Helio Loureiro
Categoria:

Finalmente chegou o momento em que me rendi novamente ao appeal corporativo e voltei a utilizar um equipamento da empresa, e não mais um laptop meu e pessoal.

Optei por um equipamento que fosse homologado internamente para rodar Linux, e então recebi um considerado "high end laptop": um notebook HP EliteBook 8570w.

Carregando o Ubuntu.

A instalação foi bem tranquila.  Bastou inserir o pendrive e seguir com os passos de instalação do Ubuntu via rede.

Sem mexer em nada, o sistema já saiu funcionando: webcam, wifi, som, etc.  A única coisa que ficou faltando, mas que foi corretamente notificada pelo Ubuntu, foi a placa de vídeo nvidia, e para instalar os drivers proprietários.  E que bela placa de vídeo: NVIDIA GPU Quadro K1000M (GK107GL) com 2 GB de memória dedicada.  Alguns sites não recomendam essa placa para jogos, mas com certeza esse não é o meu objetivo com esse equipamento.

Mas vamos ver um pouco mais do hardware:

  • Processador Intel Core i7-3520M de 2.9 GHz.OK
  • Placa de vídeo NVIDIA GPU Quadro K1000M (GK107GL) com 2 GB de RAM DDR3. OK
  • Placa gigabit ethernet Intel 82579LM. OK
  • Webcam Primax Electronics (ou HP HD Webcam). OK
  • Modem HP hs2350 HSPA+ MobileBroadband (modem 3G+). Não sei
  • Placa wireless Intel Centrino Ultimate-N 6300. OK
  • 3 portas USB. OK
  • 1 porta e-SATA. Não sei
  • 1 saída VGA. OK
  • 1 saída DisplayPort. Não sei
  • 1 unidade de DVD recorder. Não sei
  • 1 leitor de cartão SD/MMC. Não sei
  • 1 porta firewire. Não sei
  • Saída de áudio Intel (interno) e Nvidia (DisplayPort). OK e Não sei
  • HD de 320 GB de 7200 RPM. OK
  • 8 GB de RAM DDR3 de 1600 MHz. OK
  • Tela de 15.6 polegadas com resolução de 1920x1080. OK

Ainda tem uma porção de coisas que não consegui identificar.  Existe no hardware, mas não vejo nas saídas de lspci e lsusb, ou mesmo lshw.  Um bom exemplo é uma porta de modem que tem na parte de trás do laptop.

Modem dialup?

Minha primeira impressão sobre o laptop é... ele é um monstrobook.  É enorme e pesado.  Pesa 3 Kg pela descrição técnica, mas parece que são uns 15 Kg.  É um hardware grande e confortável para digitar, mas tão grande que tem até teclado numérico junto. E deixa isso claro pela informação na traseira, onde se descreve como "Workstation", não um notebook ou laptop. Para quem estava acostumado com um laptop fofucho de 13 polegadas, é uma mudança muito grande.

Tem ainda uma série de botões para uso ou do touchpad ou do pointer que fica no meio do teclado, algo desnecessário.  As teclas são confortáveis, mas poderia ter ao menos iluminação.

Os botões para habilitar/desabilitar wireless e som, que ficam no topo à direita, funcionam sem problemas.  Os outros dois botões que ficam por lá também, para acesso rápido à Internet e para uma... calculadora?  Esses não funcionam para nada.  O de acesso à Internet dá um refresh na página web que se está lendo.

Sobre o botão de bloqueio de som, esse não funcionou _exatamente_ de primeira.  Ele mostrava o bloqueio do som, mas sem efeito concreto disso.  O motivo foi que pulseaudio apontava pra saída do DisplayPort como principal.  Bastou utilizar o aplicativo pavucontrol e modificar o padrão pra saída de som normal que o botão funcionou corretamente.

AntesDepois

O site da HP dá bastantes detalhes sobre o equipamento e seu uso em potencial.

HP EliteBook 8570w Mobile Workstation - Portable Powerhouse

o que chama a atenção é que esse é um hardware certificado para usar Linux.  Acho que nunca tinha usado um laptop que tivesse isso.  Não é certificado para Ubuntu, mas se funcionou com uma distribuição de Linux, funciona com todas.

 

E a HP chegou mesmo a fazer até um vídeo sobre o laptop.

 

É um equipamento legal, parrudo, mas pesado.  O carcaça é de aço escovado, o que dá um certo charme ao conjunto.  Faz falta também uma saída HDMI ao invés de DisplayPort.  E a autonomia da bateria é baixa, entre 2 e 3 horas apenas.  Estou gostando dele e espero que minhas costas se acostumem logo com o peso.  E espero que a próxima geração de laptops homologados pela empresa seja de ultrabooks...

 

Leia mais:Rodando Linux no HP EliteBook 8570w
Escrito por Helio Loureiro
Categoria:

Apesar do Linux hoje ser o "mainstream" dos Unixes¹, eu gosto muito do Solaris e da sua elegância em resolver algumas coisas.  Existe o sistema de arquivo deles, o ZFS - Zeta File System, mas também tem o zoneadm, para criação rápida e fácil de máquinas virtuais.

A maior vantagem é a facilidade mesmo de replicar uma nova máquina dentro do sistema. Invariavelmente preciso fazer testes, e essa possibilidade me permite ter uma máquina guest solaris dentro do próprio solaris em apenas alguns minutos.

É preciso criar o diretório, ou zonas como é chamado pelo Solaris, onde os sistemas hospedados ficarão.  Eu sigo uma receita de bolo da Oracle/Sun e sempre utilizo o diretório "/zones", mas é preciso verificar a possibilidade de espaço antes.

A permissão é sempre 700 para evitar que outros usuários do sistema host possam ver os arquivos dos sistemas guests.

Na criação do sistema, é preciso definir seu caminho, IP e qual interface física conectada.  Eu tentei utilizar a loopback, mas verifiquei que só funciona mesmo com a interface de rede.

Esse são os passos de exemplo pra criação da máquina virtual "fake-solaris":

[root@solaris ~]# mkdir /zones
# chmod 700 /zones
# zonecfg -z fake-solaris
fake-solaris: No such zone configured
Use 'create' to begin configuring a new zone.
zonecfg:fake-solaris> create
zonecfg:fake-solaris> set zonepath=/zones
zonecfg:fake-solaris> set autoboot=true
zonecfg:fake-solaris> add net
zonecfg:fake-solaris:net> set address=192.168.0.1
zonecfg:fake-solaris:net> set physical=lo0
zonecfg:fake-solaris:net> end
zonecfg:fake-solaris> verify
zonecfg:fake-solaris> commit
zonecfg:fake-solaris> exit

Em seguida é preciso usar o zoneadm para máquina virtual recém-criada para instalar o sistema operacional.

[root@solaris ~]# zoneadm -z fake-solaris install
Preparing to install zone .
Creating list of files to copy from the global zone.
Copying  files to the zone.
Leia mais:Criando máquinas virtuais no solaris com zoneadm