Android Tools

adb is part of the adroid development tools and can b found in the directory platform-tools. adb itself must have enough privileges to get a connection to the USB connected android device, so normally it should be started as root.
On an amd64 system the compatibility libs must be installed #

apt-get install ia32-libs

And here is a link to the development platform at google:

http://developer.android.com/sdk/installing.html

OTP – One Time Passwords

After the installation of anyterm on my sheeva I am now working on the integration of One Time Passwords to enable fullaccess to my network even from a compromised workstation in an internet cafe.

I decided to go with OPIE – One-time Passwords In Everything which is using the S/KEY system (http://www.inner.net/opie).  The installation is as easy as:

aptitude install opie-server opie-client

after that the pam module for SSH must be adjusted:

/etc/pam.d/sshd

auth sufficient pam_unix.so
auth sufficient pam_opie.so
auth required pam_deny.so

must be in whereas:

@include common-auth

must be out.

Initialisation is done via:

opiepasswd -c

which gives you back the first password and seed. You need to give a passphrase for the actual account before the command completes.

With the command opiekey the sequence number and the passphrase you can also get the apropriate password or with the option -n <number> a list of usable
passwords for printing.

updating uboot on the dockstar

I copied the installation instructions and files from the wonderful website of Jeff Doozan who made an excellent job at:
http://jeff.doozan.com/debian/uboot/
by copying the installation script and executying.
cd /tmp
wget http://jeff.doozan.com/debian/uboot/install_uboot_mtd0.sh
chmod +x install_uboot_mtd0.sh
./install_uboot_mtd0.sh

install debian on dockstar

I just followed the instructions from http://jeff.doozan.com/debian/ by copying his installation script to a local tmp directory:

cd /tmp
wget http://jeff.doozan.com/debian/dockstar.debian-squeeze.sh
chmod +x dockstar.debian-squeeze.sh
export PATH=$PATH:/usr/sbin:/sbin
./dockstar.debian-squeeze.sh

after this the system is gathering stuff from the internet and is installing it on the attached USB stick. And it succeeded with a newly running debian squeeeze on my dockstar

uboot install on dockstar

-bash-3.2# cd /tmp/
-bash-3.2# wget http://jeff.doozan.com/debian/uboot/install_uboot_mtd0.sh
Connecting to jeff.doozan.com (69.163.187.226:80)
wget: cannot connect to remote host (69.163.187.226): Network is unreachable
-bash-3.2# route add default gw 192.168.4.250
-bash: route: command not found
-bash-3.2# /sbin/route add default gw 192.168.4.250
-bash-3.2# wget http://jeff.doozan.com/debian/uboot/install_uboot_mtd0.sh
Connecting to jeff.doozan.com (69.163.187.226:80)
install_uboot_mtd0.s 100% |******************************************************************************************************************************************| 15859 00:00:00 ETA
-bash-3.2# ls
install_uboot_mtd0.sh resolv.conf var
-bash-3.2# chmod +x install_uboot_mtd0.sh
-bash-3.2# ./install_uboot_mtd0.sh

!!!!!! DANGER DANGER DANGER DANGER DANGER DANGER !!!!!!

If you lose power to your device while running this script,
it could be left in an unusable state.

This script will replace the bootloader on /dev/mtd0.

This installer will only work on a Seagate Dockstar or Pogoplug Pink.
Do not run this installer on any other device.

By typing ok, you agree to assume all liabilities and risks
associated with running this installer.

If you agree, type ‘ok’ and press ENTER to continue: ok

DISABLE POGOPLUG SERVICES

The pogoplug service includes an auto-update feature which could
be used to cripple or disable your device. It is recommended
that you disable this service.

NOTE: The pogoplug service is proprietary software
created by Cloud Engines. It is not available for use
in other distributions and will not be available in
your new linux installation even if you choose not to disable it.

Would you like to disable the pogoplug services? [Y/n] Y
Applying fixes to the pogoplug environment…
Disabling the pogoplug service…
Done fixing pogoplug environment.

# checking for /uboot-original-mtd0.kwb…

# Installing /uboot-original-mtd0.kwb…
Connecting to jeff.doozan.com (69.163.187.226:80)
uboot-original-mtd0. 100% |******************************************************************************************************************************************| 49 –:–:– ETA
Connecting to jeff.doozan.com (69.163.187.226:80)
uboot-original-mtd0. 100% |******************************************************************************************************************************************| 512k 00:00:00 ETA
# Successfully installed /uboot-original-mtd0.kwb.
# checking for /usr/sbin/blparam…

# Installing /usr/sbin/blparam…
Connecting to jeff.doozan.com (69.163.187.226:80)
blparam.md5 100% |******************************************************************************************************************************************| 42 –:–:– ETA
Connecting to jeff.doozan.com (69.163.187.226:80)
blparam 100% |******************************************************************************************************************************************| 14168 00:00:00 ETA
# Successfully installed /usr/sbin/blparam.
# checking for /usr/sbin/nandwrite…

# Installing /usr/sbin/nandwrite…
Connecting to jeff.doozan.com (69.163.187.226:80)
nandwrite.md5 100% |******************************************************************************************************************************************| 44 –:–:– ETA
Connecting to jeff.doozan.com (69.163.187.226:80)
nandwrite 100% |******************************************************************************************************************************************| 11500 –:–:– ETA
# Successfully installed /usr/sbin/nandwrite.
# checking for /usr/sbin/nanddump…

# Installing /usr/sbin/nanddump…
Connecting to jeff.doozan.com (69.163.187.226:80)
nanddump.md5 100% |******************************************************************************************************************************************| 43 –:–:– ETA
Connecting to jeff.doozan.com (69.163.187.226:80)
nanddump 100% |******************************************************************************************************************************************| 21286 –:–:– ETA
# Successfully installed /usr/sbin/nanddump.
# checking for /usr/sbin/flash_erase…

# Installing /usr/sbin/flash_erase…
Connecting to jeff.doozan.com (69.163.187.226:80)
flash_erase.md5 100% |******************************************************************************************************************************************| 46 –:–:– ETA
Connecting to jeff.doozan.com (69.163.187.226:80)
flash_erase 100% |******************************************************************************************************************************************| 12819 –:–:– ETA
# Successfully installed /usr/sbin/flash_erase.
# checking for /usr/sbin/fw_printenv…

# Installing /usr/sbin/fw_printenv…
Connecting to jeff.doozan.com (69.163.187.226:80)
fw_printenv.md5 100% |******************************************************************************************************************************************| 46 –:–:– ETA
Connecting to jeff.doozan.com (69.163.187.226:80)
fw_printenv 100% |******************************************************************************************************************************************| 652k 00:00:00 ETA
# Successfully installed /usr/sbin/fw_printenv.
# checking for /etc/fw_env.config…

# Installing /etc/fw_env.config…
Connecting to jeff.doozan.com (69.163.187.226:80)
fw_env.config.md5 100% |******************************************************************************************************************************************| 48 –:–:– ETA
Connecting to jeff.doozan.com (69.163.187.226:80)
fw_env.config 100% |******************************************************************************************************************************************| 329 –:–:– ETA
# Successfully installed /etc/fw_env.config.

# Attempting to auto-detect your device…Dockstar detected

# Installing uBoot
Connecting to jeff.doozan.com (69.163.187.226:80)
uboot.mtd0.kwb.md5 100% |******************************************************************************************************************************************| 49 –:–:– ETA
Connecting to jeff.doozan.com (69.163.187.226:80)
uboot.mtd0.kwb 100% |******************************************************************************************************************************************| 512k 00:00:00 ETA
Erase Total 4 Units
Performing Flash Erase of length 131072 at offset 0x60000 done
Writing data to block 0 at offset 0x0
Writing data to block 1 at offset 0x20000
Writing data to block 2 at offset 0x40000
Writing data to block 3 at offset 0x60000
Block size 131072, page size 2048, OOB size 64
Dumping data starting at 0x00000000 and ending at 0x00080000…
## Verifying new uBoot…
Connecting to jeff.doozan.com (69.163.187.226:80)
uboot.mtd0.kwb.md5 100% |******************************************************************************************************************************************| 49 –:–:– ETA
# Verified successfully!

# Installing uBoot environment
Warning: Bad CRC, using default environment
## Error: “ethaddr” not defined
Warning: Bad CRC, using default environment
## Error: “rescue_installed” not defined
Warning: Bad CRC, using default environment
## Error: “bootcmd_rescue” not defined
Warning: Bad CRC, using default environment
## Error: “rescue_custom_params” not defined
Warning: Bad CRC, using default environment
## Error: “usb_custom_params” not defined
Warning: Bad CRC, using default environment
## Error: “ubifs_custom_params” not defined
Connecting to jeff.doozan.com (69.163.187.226:80)
uboot.environment.md 100% |******************************************************************************************************************************************| 52 –:–:– ETA
Connecting to jeff.doozan.com (69.163.187.226:80)
uboot.environment 100% |******************************************************************************************************************************************| 128k 00:00:00 ETA
Erase Total 1 Units
Performing Flash Erase of length 131072 at offset 0xc0000 done
Writing data to block 6 at offset 0xc0000

# Verifying uBoot environment
ECC failed: 6
ECC corrected: 0
Number of bad blocks: 0
Number of bbt blocks: 0
Block size 131072, page size 2048, OOB size 64
Dumping data starting at 0x000c0000 and ending at 0x000e0000…
Connecting to jeff.doozan.com (69.163.187.226:80)
uboot.environment.md 100% |******************************************************************************************************************************************| 52 –:–:– ETA

# uBoot installation has completed successfully.
-bash-3.2# /usr/bin/f
fdformat find flash_eraseall fold free ftpget ftpput fuser
-bash-3.2# /usr/sbin/fw_
fw_printenv fw_setenv
-bash-3.2# /usr/sbin/fw_printenv
ethact=egiga0
bootdelay=3
baudrate=115200
arcNumber=2097
mainlineLinux=yes
console=ttyS0,115200
led_init=green blinking
led_exit=green off
led_error=orange blinking
mtdparts=mtdparts=orion_nand:1M(u-boot),4M(uImage),32M(rootfs),-(data)
mtdids=nand0=orion_nand
partition=nand0,2
stdin=serial
stdout=serial
stderr=serial
rescue_installed=0
rescue_set_bootargs=setenv bootargs console=$console ubi.mtd=2 root=ubi0:rootfs ro rootfstype=ubifs $mtdparts $rescue_custom_params
rescue_bootcmd=if test $rescue_installed -eq 1; then run rescue_set_bootargs; nand read.e 0x800000 0x100000 0x400000; bootm 0x800000; else run pogo_bootcmd; fi
pogo_bootcmd=if fsload uboot-original-mtd0.kwb; then go 0x800200; fi
force_rescue=0
force_rescue_bootcmd=if test $force_rescue -eq 1 || ext2load usb 0:1 0x1700000 /rescueme 1 || fatload usb 0:1 0x1700000 /rescueme.txt 1; then run rescue_bootcmd; fi
ubifs_mtd=3
ubifs_set_bootargs=setenv bootargs console=$console ubi.mtd=$ubifs_mtd root=ubi0:rootfs rootfstype=ubifs $mtdparts $ubifs_custom_params
ubifs_bootcmd=run ubifs_set_bootargs; if ubi part data && ubifsmount rootfs && ubifsload 0x800000 /boot/uImage && ubifsload 0x1100000 /boot/uInitrd; then bootm 0x800000 0x1100000; fi
usb_scan=usb_scan_done=0;for scan in $usb_scan_list; do run usb_scan_$scan; if test $usb_scan_done -eq 0 && ext2load usb $usb 0x800000 /boot/uImage 1; then usb_scan_done=1; echo “Found bootable drive on usb $usb”; setenv usb_device $usb; setenv usb_root /dev/$dev; fi; done
usb_scan_list=1 2 3 4
usb_scan_1=usb=0:1 dev=sda1
usb_scan_2=usb=1:1 dev=sdb1
usb_scan_3=usb=2:1 dev=sdc1
usb_scan_4=usb=3:1 dev=sdd1
usb_init=run usb_scan
usb_device=0:1
usb_root=/dev/sda1
usb_rootfstype=ext2
usb_rootdelay=10
usb_set_bootargs=setenv bootargs console=$console root=$usb_root rootdelay=$usb_rootdelay rootfstype=$usb_rootfstype $mtdparts $usb_custom_params
usb_bootcmd=run usb_init; run usb_set_bootargs; run usb_boot
usb_boot=mw 0x800000 0 1; ext2load usb $usb_device 0x800000 /boot/uImage; if ext2load usb $usb_device 0x1100000 /boot/uInitrd; then bootm 0x800000 0x1100000; else bootm 0x800000; fi
bootcmd=usb start; run force_rescue_bootcmd; run ubifs_bootcmd; run usb_bootcmd; usb stop; run rescue_bootcmd; run pogo_bootcmd; reset
ethaddr=00:10:75:1A:D3:B0

anyterm

I just successfully installed anyterm on my homepage hosted on my sheeva plug. The successfull command was:
./anytermd -p 5000 –user olkn –auth null -c “ssh olkn@localhost”
I had several issues with authentication and the correct user to choose but now it is running and I have shell access to my sheeva plug using an SSL encrypted apache page.
The proxy passage for apache is as follows. Of course you need to install mod_proxy first.

# anyterm proxy

ProxyPass http://localhost:5000/
ProxyPassReverse http://localhost:5000/
AuthType Basic
AuthName “anyterm”
AuthUserFile /etc/apache2/htpasswd
Require user olkn

GoldCardTool

GoldCard Tool v0.0.5

Requirements:

* Latest HTC Sync software installed (www.htc.com)
* Spare microSD card
* Windows PC (Tested on Windows7 x64,Vista x86)
* .Net Framework 2.0

Step by step instructions:

* Format the microSD card to FAT32 format.
* Put the microSD card in your device and boot it.
* Launch GoldCard Tool (Right Click and run as Admin if needed)
* Connect Android device to USB (USB Debugging must be enabled on the device)
* Click ‘Get CID’ (If MMC1 fails try MMC0)
* Click the link to open revskills.de, enter the CID number from Goldcard Tool and create your goldcard image, which will be e-mailed to you.
* Enable USB Mass Storage on the device.
* Click ‘Refresh’ and select your microSD card in the drop down menu.
* Click ‘Load GoldCard.img’ and open the .img file you got by email.
* Click ‘Patch MMC’

You now have a goldcard!

[Notes]
HTC Sync is required for drivers only
Android SDK is not required

After a couple of requests I have decided to release the source code.

http://android.modaco.com/content/software/308798/pc-application-goldcardtool/

HTC Desire root

Guide to root using Windows, MAC OS X and Linux

1. !Some people reported that this method needs to have GoldCard(in most cases you won’t need it) even if you have unbranded device, more here
2. You need to have Android SDK and HTC Sync installed(for Windows users)
3. Download following items:
—- If you have a bootloader version 0.75.xxxx or below AND a current ROM of 1.15.xxx.x or below – DOWNLOAD / MIRROR
—- If you have a bootloader version 0.80.xxxx or below AND a current ROM of 1.21.xxx.x or below – DOWNLOAD / MIRROR
4. Unzip the file you downloaded to a directory, then open a command prompt / terminal window at that directory.
5. Turn off your HTC Desire, then turn it back on with the ‘back’ button held down. You’ll see ‘FASTBOOT’ written on the screen in a red box. Connect the phone to the computer.
6. In the command prompt/terminal window, enter either ‘step1-windows.bat'(for windows), ‘./step1-mac.sh'(for mac) or ‘./step1-linux.sh'(for linux)
7. Navigate to the ‘BOOTLOADER’ and then ‘RECOVERY’ option on the menu, using the volume buttons to move and the power button to select.
8. In the command prompt/terminal window, enter either ‘step2-windows.bat’, ‘./step2-mac.sh’ or ‘./step2-linux.sh’ as appropriate.
9. When this has completed, your device should be at the ‘recovery'(“green”) screen. Select Wipe and then press Wipe data/factory reset
10. Once complete you should be back in the main menu. Now select the option Flash zip from sdcard and than choose rootedupdate.zip
11. Once back in the main menu, choose restart the phone – the rooting process is now finished

How to flash ROM

1. Download this
2. Turn off Desire and then turn it on while holding back button to enter bootloader(white screen)
3. Once in “white screen” press power button again to enter bootloader
4. Connect Desire with PC
5. Press Volume Down and than Power to enter Recovery
6. Now the red triangle should show up, go to folder you downloaded file and press recovery-windows.bat, recovery-mac.sh or recovery-linux.sh depending on which OS you have
7. Now you are in recovery mode (green screen), press Wipe and than Wipe data/clear storage, than press optical tracker to confirm it
8. After that press Volume Down to go back to main menu in recovery
9. Navigate to Flash zip from sdcard using optical tracker, select .zip confirm it and wait until process finish, after that press Reboot system and unplug you Desire
10. Enjoy your new ROM