<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>printf(&#34; SaltwaterC &#34;); &#187; Linux</title>
	<atom:link href="http://www.saltwaterc.net/category/linux/feed" rel="self" type="application/rss+xml" />
	<link>http://www.saltwaterc.net</link>
	<description>Developer blog</description>
	<lastBuildDate>Thu, 18 Feb 2010 12:43:20 +0000</lastBuildDate>
	<generator>http://wordpress.org/?v=2.9.2</generator>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<item>
		<title>Firebug 1.5 + Firefox 3.5.7 + Ubuntu Hardy amd64</title>
		<link>http://www.saltwaterc.net/rant/firebug-15-firefox-357-ubuntu-hardy-amd64.html</link>
		<comments>http://www.saltwaterc.net/rant/firebug-15-firefox-357-ubuntu-hardy-amd64.html#comments</comments>
		<pubDate>Fri, 29 Jan 2010 08:34:57 +0000</pubDate>
		<dc:creator>SaltwaterC</dc:creator>
				<category><![CDATA[Linux]]></category>
		<category><![CDATA[Programare]]></category>
		<category><![CDATA[Rant]]></category>

		<guid isPermaLink="false">http://saltwaterc.net/rant/firebug-15-firefox-357-ubuntu-hardy-amd64.html</guid>
		<description><![CDATA[Firebug este o unealtă indispensabilă activităților de dezvoltare web pe care le execut. Din păcate, actualizările se lasă cu urmări câteodată. Precum zice în titlu, am încercat combinația nefericită de mai sus. Buba stă în Firebug: 64 bit Firefox on Linux crashes with Firebug 1.5.0. Am mers pe firul epic al poveștii de pe issue [...]]]></description>
			<content:encoded><![CDATA[<p>Firebug este o unealtă indispensabilă activităților de dezvoltare web pe care le execut. Din păcate, actualizările se lasă cu urmări câteodată. Precum zice în titlu, am încercat combinația nefericită de mai sus. Buba stă în Firebug: <a href="http://blog.getfirebug.com/2010/01/19/64-bit-firefox-on-linux-crashes-with-firebug-1-5-0/" title="64 bit Firefox on Linux crashes with Firebug 1.5.0" target="_blank">64 bit Firefox on Linux crashes with Firebug 1.5.0</a>. Am mers pe firul epic al poveștii de pe issue tracker și mi-am resetat preferințele. Crash-ul reapare atunci când se reactivează tab-ul Net sau Console. Din nefericire, echipa Firebug aruncă vina către Ubuntu, desi eu mi-am făcut propriul build personalizat de Firefox, deci problema cred că zace undeva prin ceva bibliotecă livrată cu Ubuntu din moment ce versiunea de Firefox îmi aparține.</p>
<p>Soluția de moment: downgrade la Firebug 1.4: <a href="http://getfirebug.com/releases/firebug/1.4/" title="Firebug 1.4" target="_blank">http://getfirebug.com/releases/firebug/1.4/ </a></p>
<p>PS: Firefox 3.6 sub Hardy amd64 este probabil cea mai instabilă versiune lansată vreodată. Am avut versiuni de Firefox Alpha sau Beta ce erau mai stabile de atât.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.saltwaterc.net/rant/firebug-15-firefox-357-ubuntu-hardy-amd64.html/feed</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>Actualizare de Virtualbox. Acum ce? Management de procese? Reboot!</title>
		<link>http://www.saltwaterc.net/windows/actualizare-de-virtualbox-acum-ce-management-de-procese-reboot.html</link>
		<comments>http://www.saltwaterc.net/windows/actualizare-de-virtualbox-acum-ce-management-de-procese-reboot.html#comments</comments>
		<pubDate>Sat, 28 Nov 2009 10:53:44 +0000</pubDate>
		<dc:creator>SaltwaterC</dc:creator>
				<category><![CDATA[Linux]]></category>
		<category><![CDATA[Virtualizare]]></category>
		<category><![CDATA[Windows]]></category>

		<guid isPermaLink="false">http://saltwaterc.net/windows/actualizare-de-virtualbox-acum-ce-management-de-procese-reboot.html</guid>
		<description><![CDATA[Băieții aceștia faini de la Sun Microsystems au &#8216;ghiara&#8217; pe VirtualBox de la băieții de la Innotek. Vremuri istorice tulburi cu un produs mediocru. Între timp Sun-ul a băgat camionul de dolari în proiect și a început să se distingă din mulțime printr-un backend foarte puternic. Pe subsemnatul l-a convins să renunțe la VMware Server [...]]]></description>
			<content:encoded><![CDATA[<p>Băieții aceștia faini de la Sun Microsystems au &#8216;ghiara&#8217; pe VirtualBox de la băieții de la Innotek. Vremuri istorice tulburi cu un produs mediocru. Între timp Sun-ul a băgat camionul de dolari în proiect și a început să se distingă din mulțime printr-un backend foarte puternic. Pe subsemnatul l-a convins să renunțe la VMware Server pentru acele &#8217;server consolidation deployment&#8217; ce mai apărea prin rețelele locale pe unde operez. Tot istoric vorbind, pentru Windows se distribuiau două pachete, unul pentru x86 și unul pentru x86-64. În prezent se distribuie unul singur ce se instalează în funcție de contextul platformei.</p>
<p>Bun. La partea cu instalarea îmi doream să ajung. Mai bine zis la partea cu actualizarea. De regulă pe un Ubuntu Server ce mai rulează servicii mici/medii VirtualBox are bunul simț să ruleze în background ca daemon printr-un simplu init script. În concluzie actualizările le fac atunci când îmi mai aduc aminte să deschid interfața grafică. Sub Windows în schimb este o jucărie unde mai testez ultimele apariții în domeniul OS. Dar aici mă lovesc suficient de des de acea fereastră ce mă anunță faptul că a apărut o nouă versiune. Click &#8211; download  &#8211; next, next, next &#8230; gata. În teorie era gata. În practică 3.0.12, adică ultima versiune, refuză să adauge orice fel de HDD virtual nou și am o mică bănuială despre imposibilitatea de a adăuga noi mașini virtuale.</p>
<p>Mă apuc să lucrez în calculator să văd ce se întâmplă (doctore). Cretinătatea aceea de installer nu a închis VBoxSVC înainte de instalare. Adică acel serviciu ad-hoc din arhitectura VirtualBox ce se ocupă de mașinile virtuale atâta timp cât rulează cel puțin una. În mod normal stă închis acel proces. Ridicolul merge mai departe. Acel proces, VBoxSVC dă un &#8216;lock&#8217; exclusiv pe fișierele de configurare astfel încât să nu apară chestia aceea numită &#8216;race condition&#8217; în geek language. Iar acel proces nu mai vrea să moară. Task Manager-ul e inutil ca de obicei la omorât procese încăpățânate. Am scos artileria grea: <a href="http://diamondcs.com.au/advancedseries/apt.php" title="Advanced Process Termination" target="_blank">Advanced Process Termination</a> (APT). Pe lângă o duzină de metode de kill, știe două metode de kernel kill și încă două de crash kill. Kernel kill pe Windows 7 x64 nu are suport. Nu mi-am spart capul cu hack-ul de OS. Din păcate metodele din user mode au dat greș. Windows încă e copil mic și udă patul atunci când vine vorba de procese încăpățânate. Sistemele UNIX-like (ex: Linux, FreeBSD) rămân în situația penibilă de mai sus atunci când un proces rămâne blocat în &#8216;<a href="http://en.wikipedia.org/wiki/Uninterruptible_sleep" title="IO wait" target="_blank">IO wait state</a> &amp; friends&#8217;. Soluția este evidentă: reboot. Dar m-am cam săturat să rămân cu procese blocate pentru ca Windows e rebut la management-ul lor din &#8216;user mode&#8217;. Iar VirtualBox e rebut la actualizare și nu își știe închide serviciul înainte de un nou &#8216;deploy&#8217;. În mod curios, procesul blocat nu apare în APT. Dar APT are o jucărie numită &#8216;Custom PID&#8217; pentru a da kill după kill.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.saltwaterc.net/windows/actualizare-de-virtualbox-acum-ce-management-de-procese-reboot.html/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Problema mail() din Zend Server Community Edition &#8211; Debian Repository</title>
		<link>http://www.saltwaterc.net/rant/problema-mail-din-zend-server-community-edition-debian-repository.html</link>
		<comments>http://www.saltwaterc.net/rant/problema-mail-din-zend-server-community-edition-debian-repository.html#comments</comments>
		<pubDate>Sun, 04 Oct 2009 19:53:07 +0000</pubDate>
		<dc:creator>SaltwaterC</dc:creator>
				<category><![CDATA[Linux]]></category>
		<category><![CDATA[Rant]]></category>

		<guid isPermaLink="false">http://saltwaterc.net/rant/problema-mail-din-zend-server-community-edition-debian-repository.html</guid>
		<description><![CDATA[Din plictiseală sau datorită faptului că în mod repetitiv m-am tot lovit de Zend Server CE printre plimbările mele pe Web, m-am decis să renunț la versiunea implicită ce vine în reopository-ul sistemului de operare de pe mașina de dezvoltare (Ubuntu Hardy) și să pun în schimb Zend Server. Zis și făcut. Țac, țac, țac [...]]]></description>
			<content:encoded><![CDATA[<p>Din plictiseală sau datorită faptului că în mod repetitiv m-am tot lovit de Zend Server CE printre plimbările mele pe Web, m-am decis să renunț la versiunea implicită ce vine în reopository-ul sistemului de operare de pe mașina de dezvoltare (Ubuntu Hardy) și să pun în schimb Zend Server. Zis și făcut. Țac, țac, țac &#8211; zgomot de taste &#8211; instalarea a mers ca unsă.</p>
<p>Din păcate, ocazional, dezvolt și aplicații ce au nevoie de acces la funcția mail(), funcție ce altceva înafară de FALSE aka FAIL nu știa să returneze. Verific Postfix-ul &#8211; rula de zor. Deci nu era bubă de MTA. NU, nu suport Sendmail. Iau o porție de copypasta de pe php.net, pun totul întrun fișier php, rulez în shell &#8211; surpriză:</p>
<p>sh: -t: not found</p>
<p>Mă scarpin cu o mână în cap și cu cealaltă în dos. Ceva îmi pute &#8211; și nu era de la a doua mână. Încep să sap pentru a afla ce pește prăjt au făcut cei de la Zend cu php.ini de încearcă să ruleze aplicația &#8216;-t&#8217;. Crăp un output de phpinfo() in Firefox și mă luminez:</p>
<p>sendmail_path Local Value: -t -i Master Value:  -t -i</p>
<p>Erm, WTF Zend? Casc vinovatul (/usr/local/zend/etc/php.ini) și caut linia cu pricina ce bine mersi era comentată. Cică în mod implicit ar trebui să fie &#8217;sendmail -t -i&#8217;, dar se pare că opțiunea nu este hardcodată ca atare. Soluția e la mintea cocoșului:</p>
<p>sendmail_path = sendmail -t -i</p>
<p>Restart la Apache2. Merge? Merge. Shell-ul este fericit deasemenea.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.saltwaterc.net/rant/problema-mail-din-zend-server-community-edition-debian-repository.html/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Gnome History</title>
		<link>http://www.saltwaterc.net/linux/gnome-history.html</link>
		<comments>http://www.saltwaterc.net/linux/gnome-history.html#comments</comments>
		<pubDate>Tue, 21 Apr 2009 10:08:05 +0000</pubDate>
		<dc:creator>SaltwaterC</dc:creator>
				<category><![CDATA[Linux]]></category>

		<guid isPermaLink="false">http://saltwaterc.net/tech/gnome-history.html</guid>
		<description><![CDATA[Acesta este inca unul dintre acele posturi despre intalnitele &#8220;OS annoyances&#8220;. Desi primele 3 rezultate din Google Search-ul de mai sus fac referire la Windows OS, de data aceasta Gnome in implementarea Debian/Ubuntu iese la rampa. Posibil si sub alte distributii pentru ca imi miroase a problema din upstream in loc sa fie o problema [...]]]></description>
			<content:encoded><![CDATA[<p>Acesta este inca unul dintre acele posturi despre intalnitele &#8220;OS <a href="http://www.google.com/search?hl=en&amp;q=annoyances&amp;btnG=Google+Search&amp;aq=f&amp;oq=" title="annoyances" target="_blank">annoyances</a>&#8220;. Desi primele 3 rezultate din Google Search-ul de mai sus fac referire la Windows OS, de data aceasta Gnome in implementarea Debian/Ubuntu iese la rampa. Posibil si sub alte distributii pentru ca imi miroase a problema din upstream in loc sa fie o problema a Debian+derivatii.</p>
<p>M-am trezit inca de dimineata cu gand rau impotriva Gnome History. Din pacate gandul meu a fost mai slab decat implementarea incapatanata a celor ce au <em>gandit</em> Gnome-ul din acest punct de vedere si n-au pus pe undeva o optiune pentru dezactivarea acestei functii, optiune ce sa fie demna de &#8216;Captain Obvious&#8217;, altfel spus, la mintea cocosului. Daca in trecut istoricul se tinea in fisierul ~/.recently-used iar un simplu:</p>
<pre>chmod -c 400 ~/.recently-used</pre>
<p>era suficient pentru a opri atrocitatea, in prezent (de la Gutsy si pana in prezent daca nu ma insel) lucrurile sunt sensibil mai diferite. Numele fisierului s-a schimbat intre timp in .recently-used.xbel. Nu aceasta ar fi problema esentiala daca metodele clasice ar functiona. Am incercat schimbarea ACL-urilor precum am pus mai sus: ceva le restaureaza. Am pus symlink catre /dev/null &#8230; ceva sterge link-ul si restaureaza fisierul. L-am creat de sub root si l-am lasat asa &#8230; ceva ii restaureaza ACL-urile si le pune iarasi pe contul meu. Parca era un film de acela prost cu Greuceanu ce omoara balauri alimentati cu baterii Duracell ce tot primesc resurect. Din fericire acesta a fost balaur pe 2 biti (4 capete). Cine stie bancul cu balaurul pe 8 biti, pricepe.</p>
<p>Metode exista, si sunt doua la numar. Prima desi functioneaza, este trista pentru ca are prostul obicei de a genera erori GTK in shell:</p>
<pre>rm ~/.recently-used.xbel ; mkdir ~/.recently-used.xbel</pre>
<p>Se pare ca e o piatra prea tare de rumegat pentru implementarea incapatanata prezentata mai sus.</p>
<p>Dar are dezavantajul erorilor din shell. Fericitii (ca mine) ce folosesc ext3 pe post de filesystem (nu cunosc utilitare echivalente pentru reiser, xfs, jfs &#8211; nu dati cu pietre) pot apela la o smecherie ce marcheaza fisierul ca immutable iar la incercarea de a face ceva, o sa se loveasca de un raspuns mai incapatanat de la Sfantul Kernel:</p>
<pre>sudo chattr +i ~/.recently-used.xbel</pre>
<p>Chestia asta il va opri pe mucos sa mai salveze istoricul, ba mai mult, scuteste shell-ul de erori neinteresante.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.saltwaterc.net/linux/gnome-history.html/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Determinarea corecta a MIME Type in PHP 5</title>
		<link>http://www.saltwaterc.net/linux/determinarea-corecta-a-mime-type-in-php-5.html</link>
		<comments>http://www.saltwaterc.net/linux/determinarea-corecta-a-mime-type-in-php-5.html#comments</comments>
		<pubDate>Tue, 19 Aug 2008 11:46:07 +0000</pubDate>
		<dc:creator>SaltwaterC</dc:creator>
				<category><![CDATA[Linux]]></category>
		<category><![CDATA[Programare]]></category>

		<guid isPermaLink="false">http://saltwaterc.net/tech/linux/determinarea-corecta-a-mime-type-in-php-5.html</guid>
		<description><![CDATA[Din start mentionez ca acest mic tutorial este dedicat fisierelor ce au ca directie un host *nix, iar functionalitatea implicita este satisfacuta pentru Ubuntu/Debian. Se poate aplica cu modificarile de rigoare si sub alte distributii. O sa il structurez pe pasi pentru o aplicare mai usoara. Nu am incercat pentru PHP 4, desi majoritatea pasilor [...]]]></description>
			<content:encoded><![CDATA[<p>Din start mentionez ca acest mic tutorial este dedicat fisierelor ce au ca directie un host *nix, iar functionalitatea implicita este satisfacuta pentru Ubuntu/Debian. Se poate aplica cu modificarile de rigoare si sub alte distributii. O sa il structurez pe pasi pentru o aplicare mai usoara. Nu am incercat pentru PHP 4, desi majoritatea pasilor s-ar putea sa fie valabili.</p>
<p><strong>Introducere</strong></p>
<p>Determinarea MIME Type-ului corect pentru un fisier este o problema esentiala. Nu o sa explic si de ce &#8230; daca nu stii de ce, atunci tutorialul acesta iti depaseste nivelul cunostintelor. Atunci cand se face upload la un fisier printr-un form, sau se doreste import-ul unui fisier, se poate intampla ca extensia fisierului sa nu reflecte realitatea sau ca aceasta sa lipseasca cu desavarsire, fapt ce va duce la varii probleme. Array-ul $_FILES ce ia valori in functie de continutul unui form ce are specificat in mod explicit enctype=&#8221;multipart/form-data&#8221; se prea poate sa nu contina valoarea corecta a mime type-ului pentru $_FILES['file_input_name']['type'] deoarece detectia mime-ului cade pe spinarea browserului iar in majoritatea cazurilor acesta se foloseste de extensia fisierului deci va esua in cazurile descrise mai sus. Este nevoie ca informatia sa fie interpretata citind headerele fisierului si folosindu-ne de mime magic.</p>
<p><strong>PECL si fileinfo</strong></p>
<p>Nu o sa imi pierd timpul sa explic ce e PECL. Google este de mare ajutor. Din pacate in repository-urile Ubuntu/Debian, extensia fileinfo nu este disponibila in mod implicit. Din fericire este disponibila prin intermediul PECL. Acum incepe treaba sa fie paroasa.</p>
<p>In primul rand, este nevoie de una bucata compilator. Exista un pachet ce le face pe toate, deci:</p>
<blockquote><p>sudo apt-get install build-essential</p></blockquote>
<p>Bun. Avem compilator, avem PECL (presupun, daca n-ai HTTP server si PHP &#8211; citesti degeaba). Pentru build-ul fileinfo mai este nevoie de pachete de development, deci:</p>
<blockquote><p>sudo apt-get install libmagic-dev php5-dev</p></blockquote>
<p>ce va instala headerele de development pentru libmagic, phpize si alte chestii. Faceti acum, sau regretati mai tarziu. Acum este timpul sa compilam extensia fileinfo folosind pecl:</p>
<blockquote><p>sudo pecl install fileinfo</p></blockquote>
<p>Daca maraie vreo eroare la configure, instalati pachetul de development aferent (pentru cei somnorosi, are sufixul -dev). Daca maraie vreo eroare la compile, imi pare rau, nu va pot ajuta. Pe masina de devel a functionat fara probleme. Daca nu maraie nici o eroare, ar trebui sa indice faptul ca extensia a fost instalata cu succes. Ar trebui sa fie ceva de genul:</p>
<blockquote><p>Build process completed successfully<br />
Installing &#8216;/usr/lib/php5/20060613+lfs/fileinfo.so&#8217;<br />
install ok: channel://<a href="http://pear.php.net/Fileinfo-1.0.4" class="linkification-ext" title="Linkification: http://pear.php.net/Fileinfo-1.0.4">pear.php.net/Fileinfo-1.0.4</a></p></blockquote>
<p>Daca ati ajuns pana aici, mai este putin si usor. Extensiile instalate prin intermediul PECL nu sunt incarcate in mod automat, spre deosebire de cele instalate din repository-urile Ubuntu/Debian folosind apt-get sau alternativa (cu mici exceptii, spre exemplu mcrypt.so trebuie incarcat in mod explicit &#8211; nenea maintainer a fost cascat). Pentru a mentine ideea si spiritul Debian, incarcarea modulului se va face folosind directorul de fisiere alternative de configurare pentru PHP. Tastati urmatoarele chestii intr-un terminal (da stiu, copy-paste e mai comod):</p>
<blockquote><p>cd /etc/php5/conf.d/; sudo touch fileinfo.ini; sudo nano fileinfo.ini</p></blockquote>
<p>Bagati urmatoarea linie in acel fisier:</p>
<blockquote><p>extension=fileinfo.so</p></blockquote>
<p>dupa care salvati cu Ctrl+O. Inchideti editorul text folosind Ctrl+X. Nu, nu sunt vim maniac, sa nu aud de el. Acum este timpul sa se dea restart la HTTP server pentru a incarca noua configuratie. Ar trebui sa fie valabil si pentru cei cu GCI/FastCGI (eventual alt HTTP server gen lighttpd), desi subsemnatul e de ala cu Apache 2+PHP5 handler, deci in cazul meu (si al majoritatii):</p>
<blockquote><p>sudo /etc/init.d/apache2  reload</p></blockquote>
<p>ce va duce la un graceful restart (aka restart fara downtime) urmat de incarcarea noilor fisiere de configurare. Daca totul e ok, noul modul de PHP ar trebui sa fie incarcat. phpinfo(); ar trebui sa indice acest fapt, atat in lista de fisiere de configurare alternative (cele din /etc/php5/conf.d) cat si prin faptul ca ar trebui sa indice pe undeva in mod explicit faptul ca fileinfo este incarcata.</p>
<p><strong>Utilizarea fileinfo pentru a afla MIME Type</strong></p>
<p>Acum sa trecem la lucruri grele. fileinfo contine niste functii smechere asemanatoare cu fopen. Pentru ubergeeks exista modul orientat obiect de lucru cu ele (<a href="http://www.php.net/finfo_open" title="finfo_open manual" target="_blank">php.net/finfo_open</a> explica), dar subsemnatul se multumeste cu trei apeluri procedurale din moment ce nu exista nici un avantaj real in cazul de fata pentru a defini un obiect si a-l distruge dupa ce se afla mime-ul. Pentru cei dornici sa isi implementeze o clasa proprie &#8230; este alta poveste. Eu mi-am facut o functie custom ce am inclus-o in API-ul central ce primeste ca parametru calea fisierului si imi returneaza mime-ul in caz de succes sau un cod de eroare pentru debug in caz de esuare. Miezul problemei sta in:</p>

<div class="wp_syntax"><div class="code"><pre class="php" style="font-family:monospace;"><span style="color: #000088;">$finfo</span><span style="color: #339933;">=</span><span style="color: #990000;">finfo_open</span><span style="color: #009900;">&#40;</span>FILEINFO_MIME<span style="color: #339933;">,</span> <span style="color: #0000ff;">&quot;/usr/share/misc/magic&quot;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #b1b100;">if</span><span style="color: #009900;">&#40;</span><span style="color: #339933;">!</span><span style="color: #000088;">$finfo</span><span style="color: #009900;">&#41;</span>
	<span style="color: #990000;">die</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">&quot;Can't open the fileinfo database.&quot;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #000088;">$mime</span><span style="color: #339933;">=</span><span style="color: #990000;">finfo_file</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$finfo</span><span style="color: #339933;">,</span> <span style="color: #000088;">$fileName</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #990000;">finfo_close</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$finfo</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span></pre></div></div>

<p>Si cam atat. Succes si spor la treaba.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.saltwaterc.net/linux/determinarea-corecta-a-mime-type-in-php-5.html/feed</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>Blacklist pentru module sub Ubuntu</title>
		<link>http://www.saltwaterc.net/linux/blacklist-pentru-module-sub-ubuntu.html</link>
		<comments>http://www.saltwaterc.net/linux/blacklist-pentru-module-sub-ubuntu.html#comments</comments>
		<pubDate>Mon, 30 Jun 2008 18:23:23 +0000</pubDate>
		<dc:creator>SaltwaterC</dc:creator>
				<category><![CDATA[Linux]]></category>

		<guid isPermaLink="false">http://saltwaterc.net/tech/blacklist-pentru-module-sub-ubuntu.html</guid>
		<description><![CDATA[Pentru ca sunt cascat si uit procedura, am hotarat sa scap vreo cateva linii aici. Povestea sta cam asa: solutia cea mai simpla pentru problemele mele maricele sub Ubuntu atunci cand folosesc notebook-ul este blacklist-ul. De ce? Pentru ca oricat as configura la ALSA, driverul tot cretin este si nu imi ia ca default dupa [...]]]></description>
			<content:encoded><![CDATA[<p>Pentru ca sunt cascat si uit procedura, am hotarat sa scap vreo cateva linii aici. Povestea sta cam asa: solutia cea mai simpla pentru problemele mele maricele sub Ubuntu atunci cand folosesc notebook-ul este blacklist-ul. De ce? Pentru ca oricat as configura la ALSA, driverul tot cretin este si nu imi ia ca default dupa fiecare reboot ce placa de sunet vreau EU. Se prea poate sa ma trezesc cu ID-urile inversate. Asa ca pun blacklist pe modulul placii onboard. Cealalta problema tine de faptul ca devii Ubuntu au comis o faza de cartea rebuturilor in ceea ce priveste interfata mea de retea ce este o Realtek. In loc sa incarce modulul corect, adica r8168 (ce nici macar nu exista in pachet, desi nenii de la Realtek au sursele pe FTP), sa zicem ca prostul imi incarca r8169 &#8211; ce functioneaza doar cand vrea pll nu cand vrea plm, iar chestia aceasta ma irita. Teribil. Deci iar intervine ideea de blacklist.</p>
<p>echo &#8220;blacklist mod_name&#8221; &gt;&gt; /etc/modprobe.d/blacklist<br />
sudo update-initramfs -u</p>
<p>Voila &#8230; sintaxa pentru blacklisting &#8230;</p>
]]></content:encoded>
			<wfw:commentRss>http://www.saltwaterc.net/linux/blacklist-pentru-module-sub-ubuntu.html/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>The Website is down</title>
		<link>http://www.saltwaterc.net/windows/the-website-is-down.html</link>
		<comments>http://www.saltwaterc.net/windows/the-website-is-down.html#comments</comments>
		<pubDate>Thu, 26 Jun 2008 16:02:58 +0000</pubDate>
		<dc:creator>SaltwaterC</dc:creator>
				<category><![CDATA[Linux]]></category>
		<category><![CDATA[Mac OS X]]></category>
		<category><![CDATA[Windows]]></category>

		<guid isPermaLink="false">http://saltwaterc.net/videos/the-website-is-down.html</guid>
		<description><![CDATA[O chestie criminala cu adresa la suportul tehnic si cei ce il cer. Enjoy.
http://www.thewebsiteisdown.com/
]]></description>
			<content:encoded><![CDATA[<p>O chestie criminala cu adresa la suportul tehnic si cei ce il cer. Enjoy.</p>
<p><a href="http://www.thewebsiteisdown.com/" title="The Website is down" target="_blank">http://www.thewebsiteisdown.com/</a></p>
]]></content:encoded>
			<wfw:commentRss>http://www.saltwaterc.net/windows/the-website-is-down.html/feed</wfw:commentRss>
		<slash:comments>1</slash:comments>
<enclosure url="http://s6.video2.blip.tv/0600000044297/Joshw-SalesGuyVsWebDude782.flv" length="128762180" type="video/x-flv" />
		</item>
		<item>
		<title>FreeBSD</title>
		<link>http://www.saltwaterc.net/linux/freebsd.html</link>
		<comments>http://www.saltwaterc.net/linux/freebsd.html#comments</comments>
		<pubDate>Fri, 29 Feb 2008 08:45:47 +0000</pubDate>
		<dc:creator>SaltwaterC</dc:creator>
				<category><![CDATA[FreeBSD]]></category>
		<category><![CDATA[Linux]]></category>

		<guid isPermaLink="false">http://saltwaterc.net/tech/freebsd.html</guid>
		<description><![CDATA[Vin imediat 3 saptamani de cand am ras Linux de pe notebook si am pus un FreeBSD in dual boot cu XP. Motivul este: majoritatea distributiilor care stateau pe langa XP Home au avut prostul obicei sa se muste cu hardware-ul. Ubuntu imi placea, dar crapa. De fapt asta este motivul pentru care l-am schimbat. [...]]]></description>
			<content:encoded><![CDATA[<p>Vin imediat 3 saptamani de cand am ras Linux de pe notebook si am pus un FreeBSD in dual boot cu XP. Motivul este: majoritatea distributiilor care stateau pe langa XP Home au avut prostul obicei sa se muste cu hardware-ul. Ubuntu imi placea, dar crapa. De fapt asta este motivul pentru care l-am schimbat. De fapt crapa orice din familia Debian. openSUSE e prea puturos si package managerul (YaST2) e dezastru in linie de comanda. Nu suport managerele grafice &#8230; imi ia prea mult timp pana gasesc si instalez un pachet pe care il vreau. In rest, de RPM nu prea mai vreau sa aud din motive ce tin de trecut. Dintr-un motiv pe care inca nu am reusit sa il explic, Arch nu ma atrage (inca?). Gentoo nu voiam sa pun pentru ca sincer nu am timp de RTFM prea gros pentru a instala un sistem. Deci mi-am pus FreeBSD. Nu ca ar fi si asta floare la ureche la instalare, mai ales pe un HDD plin, dar m-a ajutat <a href="http://www.linuxsoft.ro/forum/index.php/topic,1296.0.html" title="FreeBSD pentru incepatori - tutorial (de la Consola la CompizFusion)" target="_blank">tutorialul lui steelheart</a>, si pe alocuri cel al lui skaarj (acelasi thread, pagina 2) &#8211; iar pe alocuri am improvizat, nu pentru ca am vrut sa tai colturi in procesul de instalare, ci pentru ca anumite chestii nu au mers dupa cum zicea pe foaie.</p>
<p>In fine, nu ma apuc sa detaliez chestii. Important este ca din punctul de vedere al resurselor ocupate sta foarte bine (si zic asta de bine, nu de rau), este rapid, n-am avut probleme nici cu stabilitatea. Mi-am pus si Compiz-Fusion (evident, dooh) pentru ca am mai declarat pe undeva urmatoarele: dupa perioada OS X nu am mai putut sa privesc un desktop non-3D cu aceeasi ochi. Desi este cel mai bun sistem pentru servere (daca maine ar fi sa imi trec file serverul de pe Ubuntu Server pe FreeBSD &#8211; as face-o, dar imi trebuie niste timp pe care nu il am) sa zicem ca face o figura frumoasa si pe desktop. Ce-i drept, are lipsurile lui, despre care cred ca o sa ma apuc sa scriu la un moment dat.</p>
<p>Din punctul de vedere al hardware-ului, singura chestie care imi lipseste enorm este un driver care sa imi suporte placa de sunet care o am ca add-on, si anume o Audigy 2 ZS Notebook. Ce-i drept, n-am incercat Open Sound System care vine cu propriile module. Este o idee. Driverul snd_emu10kx care suporta Audigy si Audigy 2 nu vrea sa stie de placa mea, ba mai mult, cand l-am instalat si am uitat sa il scot din lista de boot (s-a pus automat acolo), FreeBSD a refuzat sa mai boot-eze pana nu am eliminat fizic placa din sistem. Acu pe partea de multumiri din punctul de vedere al hardware-ului este faptul ca se pupa bine cu el, ba mai mult, a rezolvat o problema pe care nu au reusit sa o rezolve nici driverele de sub Windows si nici cele de sub Linux: placa de retea &#8211; pe care o suspectez de o oarecare defectiune care se manifesta la 100Mbps. Chiar am facut teste de transfer prin SFTP, MikeS este martor. I-a picat si lui fata la testul de doua fisiere peste 1GB &#8211; nu a cazut nici unul sub 5MB/s, media a fost undeva de 11MB/s. Culmea, la 1Gbps prin conexiune directa cu serverul merge &#8220;flawless&#8221; sub Windows si Linux. Am umplut vreo 3 threaduri pe varii forumuri de specialitate in cautarea unei solutii. N-am gasit nici in prezent. Sub Windows/Linux tot ca un cur imi merge reteaua daca nu o pun pe 10Mbps &#8211; iar la 10Mbps ma apuca Sfantul Asteapta pana iau ceva de pe severul propriu care este in acelasi LAN &#8211; limitat la 100Mbps de router, un ASUS WL500g Premium. Cica in ultimele lui ore de viata, Linuxul in linie de comanda cu Midnight Commander si serverul montat prin SSHFS nu a mai cazut la trasfer (si am facut un backup masiv, vreo 30j de gigi de date). Dar este singura situatie in care a functionat corect &#8230; in rest a fost praf.</p>
<p>Oricum, articolul care mi-a dat multe idei si m-a facut sa imi pun FreeBSD in defavoarea Linux a fost acesta:</p>
<p><a href="http://www.over-yonder.net/%7Efullermd/rants/bsd4linux/bsd4linux1.php" title="BSD for Linux users" target="_blank">http://www.over-yonder.net/%7Efullermd/rants/bsd4linux/bsd4linux1.php</a></p>
<p>Iar daca ar fi sa apreciez ceva la FreeBSD este faptul ca fisierele de configurate tipice sunt foarte logice ca denumite, ca pozitionare in file system, precum si inca alte cateva chestii. Deasemenea ma bucur ca nu exista haosul din lipsa de organizare a Linuxului in ceea ce priveste anumite chestii dat fiind faptul ca un standard este greu de impus cand fiecare incearca sa traga foc la oala lui. Inchei &#8230;</p>
]]></content:encoded>
			<wfw:commentRss>http://www.saltwaterc.net/linux/freebsd.html/feed</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>Pidgin file transfer cu Yahoo! sub Ubuntu</title>
		<link>http://www.saltwaterc.net/linux/pidgin-file-transfer-cu-yahoo-sub-ubuntu.html</link>
		<comments>http://www.saltwaterc.net/linux/pidgin-file-transfer-cu-yahoo-sub-ubuntu.html#comments</comments>
		<pubDate>Tue, 26 Feb 2008 14:11:10 +0000</pubDate>
		<dc:creator>SaltwaterC</dc:creator>
				<category><![CDATA[Linux]]></category>

		<guid isPermaLink="false">http://saltwaterc.net/tech/linux/pidgin-file-transfer-cu-yahoo-sub-ubuntu.html</guid>
		<description><![CDATA[Una din problemele de care se plang multi din utilizatorii de Yahoo! Messenger (si nu ma refer la acei kiddies care in conjuga pe sh de zici ca discuta despre shell-uri UNIX) este faza cu transferul care pute. De trimis puteam sa trimit, dar cam atat. Azi am incercat sa ii trimit lista mea de [...]]]></description>
			<content:encoded><![CDATA[<p>Una din problemele de care se plang multi din utilizatorii de Yahoo! Messenger (si nu ma refer la acei kiddies care in conjuga pe sh de zici ca discuta despre shell-uri UNIX) este faza cu transferul care pute. De trimis puteam sa trimit, dar cam atat. Azi am incercat sa ii trimit lista mea de repositories (<a href="http://saltwaterc.net/wp-download/sources.list" title="sources.list" target="_blank">sources.list</a>) lui <a href="http://neo1984.haipa.ro/" title="The Matrix has you.." target="_blank">neo,</a> dar praf &#8230; nu voia. Deci am pus patch-ul pe care intentionam sa il pun, dar uitasem complet de el. De data aceasta meritul ii revine lui <a href="http://wonder.rodp.net/" title="blogul lui wonder" target="_blank">wonder</a> care a avut buna vointa sa acorde niste timp patchuirii surselor si punerea la download a pachetelor care rezolva problema.</p>
<p>Sursa: <a href="http://wonder.rodp.net/2008/02/pidgin.html" title="Pidgin file transfer" target="_blank">http://wonder.rodp.net/2008/02/pidgin.html</a></p>
]]></content:encoded>
			<wfw:commentRss>http://www.saltwaterc.net/linux/pidgin-file-transfer-cu-yahoo-sub-ubuntu.html/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>KDE 4</title>
		<link>http://www.saltwaterc.net/windows/kde-4.html</link>
		<comments>http://www.saltwaterc.net/windows/kde-4.html#comments</comments>
		<pubDate>Sun, 27 Jan 2008 17:10:13 +0000</pubDate>
		<dc:creator>SaltwaterC</dc:creator>
				<category><![CDATA[Linux]]></category>
		<category><![CDATA[Mac OS X]]></category>
		<category><![CDATA[Windows]]></category>

		<guid isPermaLink="false">http://saltwaterc.net/tech/kde-4.html</guid>
		<description><![CDATA[A venit momentul sa scriu si cateva cuvinte despre noul si mult asteptatul KDE 4. Sub OS X nu l-am incercat din lipsa de material de teste pentru moment, si oricum, mi-am cam tras concluziile.
KDE 4, asa cum a fost promis, ruleaza nativ sub Linux, Windows, OS X, mai pe scurt, sub orice platforma sub [...]]]></description>
			<content:encoded><![CDATA[<p>A venit momentul sa scriu si cateva cuvinte despre noul si mult asteptatul KDE 4. Sub OS X nu l-am incercat din lipsa de material de teste pentru moment, si oricum, mi-am cam tras concluziile.</p>
<p>KDE 4, asa cum a fost promis, ruleaza nativ sub Linux, Windows, OS X, mai pe scurt, sub orice platforma sub care este suportat <a href="http://en.wikipedia.org/wiki/Qt_(toolkit)" title="Qt - Wikipedia" target="_blank">Qt</a>-ul celor de la <a href="http://trolltech.com/products/qt" title="Qt - Trolltech" target="_blank">Trolltech</a>. Inainte sa apara eram destul de entuziasmat de vestea aparitiei KDE 4. Tin minte ca din intamplare citisem despre planurile ce tin de KDE 4 inca de acum 2 ani. Eram entuziasmat pentru faptul ca la vremea cand asteptam KDE 4, inca eram user de KDE 3 sub Linux. Faptul ca a fost promis nativ sub Windows/OS X nu a facut decat sa imi creasca entuziasmul.</p>
<p>O mica notificare ar fi faptul ca sub OS X rula KDE 3 si o buna parte a aplicatiilor ce tin de acest desktop environment, dar modul de rulare nu era nativ ci rula sub implementarea Apple a <a href="http://www.xfree86.org/" title="Xfree86" target="_blank">XFree86</a>. Chiar am fost curios sa vad cum arata o mana de aplicatii KDE sub OS X si au iesit momente horror &#8230; aratau ca nuca in perete si faptul ca nu rulau nativ era destul de nasol la consistenta. Acum cica s-a rezolvat problema &#8230; astept sa vad cum arata treaba in teren.</p>
<p>Sub Windows lucrurile stateau putin diferit datorita anumitor restrictii ce tin de licentierea Qt 3. Da, KDE 4 respecta numerotarea versiunii majore de Qt sub care au fost dezvoltate &#8230; KDE 3 a fost dezvoltat sub Qt 3, KDE 4 sub Qt4. Nimic nou sub Soare. Odata ce problemele s-au rezolvat incepand cu v4 a Qt, acest fapt a permis portarea aplicatiilor si sub Windows.</p>
<p>Alaltaseara mi-am pus KDE 4 sub Windows. Installer-ul desi e grafic, cel mai probabil va pune probleme celor nefamiliarizati cu lumea *nix. Mi-e mi-a adus a installer de <a href="http://www.cygwin.com/" title="cygwin" target="_blank">cygwin</a>, deci concluzia rapida a fost ca baietii de la KDE nu au dorit sa reinventeze roata. Setup-ul a inceput in mod &#8220;uzual&#8221; &#8211; downloadarea pachetelor necesare din repository (uzual &#8211; cum ziceam mai sus, precum cygwin). Instalarea nu a decurs fara probleme. La anumite pachete setupul (v0.8.5 &#8211; cea mai recenta) claca fara drept de apel. Spre exemplu am dat sa instaleze toate tool-urile de development. Desi rar am avut nevoie de <a href="http://en.wikipedia.org/wiki/Concurrent_Versions_System" title="CVS" target="_blank">CVS</a> cand de regula gaseam sursele gata arhivate, am dat sa instaleze si TortoiseCVS. Asta a fost OK. A crapat la instalarea TortoiseSVN pe care il aveam instalat deja din moment ce sunt <a href="http://en.wikipedia.org/wiki/Subversion_%28software%29" title="SVN" target="_blank">SVN</a> user, ce-i drept aveam o versiune mai veche. Clacatul se traduce prin 100% load si apasarea butonului de &#8216;Cancel&#8217; se traducea prin proces care continua sa ruleze in background, dar nu facea nimic. Multumesc cerului ca setup-ul nu stie multi-core, deci sistemul nu a fost afectat substantial la viteza, sistemul mutandu-si chestiile pe core-ul celalalt al procesorului. Ar mai fi si alte pachete la care am intampinat probleme, si culmea, pachetele respective nu erau instalate anterior precum TortoiseSVN.</p>
<p>Utilizarea este de-a dreptul seaca. In primul rand trebuie rulate in terminal doua comenzi de configurare &#8230; nu am nimic impotriva, dar in documentatie caile erau indicate complet aiurea. Le-am dibut si am rezolvat. A urmat rularea aplicatiilor propriu zise. Practic installer-ul pune executabilele si dll-urile in directorul <em>bin</em> care se gaseste in directorul de instalare al KDE 4. Cum ziceam la un moment dat, poate fi putin ciudat pentru un user nefamiliarizat cu *nix. Pentru mine a fost OK, atata ca in <em>bin</em> este un haos de nedescris. Am dibuit niste chestii cunoscute, le-am rulat, a fost relativ OK. Prima executie a fost mai dureroasa in sensul ca tre sa isi faca in prealabil o chestie care ruleaza in background, dupa care nu mai sunt probleme. Aplicatiile se integreaza bine ca aspect printre celelalte. Inafara de cateva butoane si alte chestii tipice KDE, aplicatiile arata bine. M-am jucat cateva jocuri ce vin in pachet, am editat niste fisiere text folosind Kate si Kwrite, m-am dat pe net cu Konqueror. Desi am fost incantat, inca nu am vreun gand de inlocuire a unor aplicatii ce le folosesc deja sub Windows, exemplu Windows Explorer-ul pimpuit sa il dau la o parte pentru Konqueror din motive de varii instabilitati, feature-uri care nu functioneaza sau nu functioneaza corect, etc. Poate cel putin nu pentru moment. Mai este de lucru &#8230; atat la stabilitate cat si la uzabilitate. Oricum, KDE 4 sub Windows inseamna o mana de aplicatii, si nicidecum un full desktop environment, ceea ce lasa un gust semi-amar in gura.</p>
<p>Sub Linux totul a fost destul de scurt &#8230; dupa aproximativ 15 secunde de gugălit am gasit un repository neoficial in care sa fie KDE 4 pentru ubuntu. L-am instalat usor pentru ca package managementul si-a facut treaba. Mici probleme au fost la anumite aplicatii specifice, desi in general treaba a mers OK. Desktopul plasma arata bine, pare o revolutie peste KDE 3, desi mie inca nu mi-a sters impresia ca Vista Sidebar cu ale lui gadgets s-au mutat si s-au intins pe tot desktop-ul. La un moment dat a inceput chiar sa ma enerveze acest aspect. Interfata este mult mai bine lucrata din punctul de vedere al consistentei fata de KDE 3, multe chestii seamana, dar la anumite optiuni de configurare nu s-au eliminat dialogurile interminabile si putin uzabile. Am incercat sa schimb stilul ferestrelor de pe Oxygen (cel implicit si fresh pentru KDE 4) pe alte stiluri tipice KDE 3, dar a dus la scaderea caliatii vizuale. Oricum, la nivel de interfata, vizual vorbind, KDE 4 este peste KDE 3, desi inca nu s-au reparat unele din pacatele trecutului. Ce am apreciat a fost faptul ca s-a implementat meniul tabular care are motor de cautare pe care il stiu de sub openSUSE.</p>
<p>Aplicatii nu am prea testat pentru ca sincer nu ma interesau aplicatiile in sine, ci desktop environment-ul. Oricum, aplicatiile tipice KDE le rulez cu succes si sub Gnome, si chiar daca arata putin ciudat, tot raman in sfera acceptabilului. Desi de aproximativ 4 luni am trecut de la KDE 3 la Gnome, sincer sa fiu, nu m-as mai intoarce nici pentru KDE 4. In plus, desi initial erau o mana de chestii care in KDE le gaseam imediat si sub Gnome sapam dupa ele, cu timpul situatia s-a inversat. Exact aceasta a fost senzatia cand am trecut acum din sesiunea de Gnome in cea de KDE 4. Au inceput imediat sa imi lipseasca chestii, sa ma enerveze alte chestii, sa imi lipseasca <a href="http://www.compiz-fusion.org/" title="Compiz-Fusion" target="_blank">Compiz-Fusion</a> (da, dupa un an si ceva de OS X &#8211; am ramas fan al desktop-urilor 3D).</p>
<p>Pe total KDE 4 a fost pentru mine o semi-dezamagire, sau poate ca asteptarile mi-au fost prea mari. Vom vedea ce vor aduce versiunile mai noi, pentru ca desi e release, mie inca nu imi sterge impresia de preview release.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.saltwaterc.net/windows/kde-4.html/feed</wfw:commentRss>
		<slash:comments>5</slash:comments>
		</item>
		<item>
		<title>Sun Microsystems a anuntat cumpararea MySQL</title>
		<link>http://www.saltwaterc.net/windows/sun-microsystems-a-anuntat-cumpararea-mysql.html</link>
		<comments>http://www.saltwaterc.net/windows/sun-microsystems-a-anuntat-cumpararea-mysql.html#comments</comments>
		<pubDate>Wed, 16 Jan 2008 21:54:09 +0000</pubDate>
		<dc:creator>SaltwaterC</dc:creator>
				<category><![CDATA[Linux]]></category>
		<category><![CDATA[Mac OS X]]></category>
		<category><![CDATA[Windows]]></category>

		<guid isPermaLink="false">http://saltwaterc.net/tech/sun-microsystems-a-anuntat-cumpararea-mysql.html</guid>
		<description><![CDATA[O stire care personal m-a luat prin surprindere: cumpararea MySQL de catre Sun pentru nu mai putin de 1 miliard de dolari, adica 800 milioane in cash, iar restul de 200 milioane urmand a intra in buzunar prin actiuni. Tranzactia care este una de mare anvergura urmeaza a se finaliza undeva in jurul Q3/Q4 al [...]]]></description>
			<content:encoded><![CDATA[<p>O stire care personal m-a luat prin surprindere: cumpararea MySQL de catre Sun pentru nu mai putin de 1 miliard de dolari, adica 800 milioane in cash, iar restul de 200 milioane urmand a intra in buzunar prin actiuni. Tranzactia care este una de mare anvergura urmeaza a se finaliza undeva in jurul Q3/Q4 al anului fiscal 2008.</p>
<blockquote><p>Chiar si Google, YouTube, Yahoo sau Wikipedia, FaceBook, Nokia folosesc platforma MySQL. Este nu doar o platforma open source, ci si foarte buna, stabila, usor de instalat, administat sau upgradat ulterior. Sun Microsystems vrea sa transforme solutia MySQL intr-o plartforma pentru companii.</p></blockquote>
<p>Serverul de baze de date MySQL produs de compania MySQL ocupa aproximativ 80% din piata serverelor Web, un fapt bine cunoscut de altfel. Sun se asteapta sa dea lovitura cumparand MySQL prin integrarea serverului de baze de date in solutiile oferite de acestia, marind in acelasi timp canalele de distributie MySQL.</p>
<p>Avand in vedere cota de piata MySQL, se poate spune cu usurinta faptul ca aceasta tranzactie va schimba fata Internetului prin prisma impactului pe care il va avea aceasta tranzactie.</p>
<blockquote><p>&#8220;Cumparam astazi o solutie pentru baze de date care a fost aleasa de clientii din toata lumea cu o viteza extraordinara&#8221;, a spus Schwartz. &#8220;Titanii web-ului folosesc toti MySQL, banci, companii auto, toate firmele din Fortune 500 folosesc MySQL&#8221;, a adaugat el.</p></blockquote>
<p>Chiar nu mai am nimic de adaugat &#8230; speechless &#8230;</p>
<p><a href="http://www.mysql.com/news-and-events/sun-to-acquire-mysql.html" title="Sun to Acquire MySQL" target="_blank">Sursa 1</a> <a href="http://www.sun.com/aboutsun/pr/2008-01/sunflash.20080116.1.xml" title="Sun Microsystems Announces Agreement to Acquire MySQL, Developer of the World's Most Popular Open Source Database" target="_blank">Sursa 2</a> &#8211; oficiale</p>
<p><a href="http://www.bloombiz.ro/article--IT_C-Internet-Sun_a_cumparat_MySQL%3A_1_miliard_de_dolari--1336629.html" title="Sun a cumparat MySQL: 1 miliard de dolari" target="_blank">Sursa 3</a> &#8211; neoficiala</p>
]]></content:encoded>
			<wfw:commentRss>http://www.saltwaterc.net/windows/sun-microsystems-a-anuntat-cumpararea-mysql.html/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Cea mai urata companie IT</title>
		<link>http://www.saltwaterc.net/tech/cea-mai-urata-companie-it.html</link>
		<comments>http://www.saltwaterc.net/tech/cea-mai-urata-companie-it.html#comments</comments>
		<pubDate>Sun, 06 Jan 2008 14:17:13 +0000</pubDate>
		<dc:creator>SaltwaterC</dc:creator>
				<category><![CDATA[Linux]]></category>
		<category><![CDATA[Tech]]></category>

		<guid isPermaLink="false">http://saltwaterc.net/tech/compania-it-asupra-careia-se-indreapta-cea-mai-multa-ura.html</guid>
		<description><![CDATA[Sa fie Microsoft? Sa fie Apple? NU. Raspunsul l-am gasit fara sa vreau in timp ce imi savuram ceaiul de la ora 4 (si nu pentru ca as fi mare bautor de ceai, ci pentru ca sunt cobza) &#8230; in timp ce mana libera baga scroalle pe Linux Soft. Desi sunt un sustinator al acestui [...]]]></description>
			<content:encoded><![CDATA[<p>Sa fie Microsoft? Sa fie Apple? NU. Raspunsul l-am gasit fara sa vreau in timp ce imi savuram ceaiul de la ora 4 (si nu pentru ca as fi mare bautor de ceai, ci pentru ca sunt cobza) &#8230; in timp ce mana libera baga scroalle pe Linux Soft. Desi sunt un sustinator al acestui brand (minus placi video si recenta mea mobo care e o abit), sa zicem ca am fost luat prin surprindere cand am aflat ca aceasta companie este AsusTek pe care majoritatea o stim sub numele de ASUS. N-a pacatuit prea mult &#8230; doar s-a bagat pe o nisa cu preturi agresive, a evitat Microsoft, si a iesit Eee PC. Restul incepe sa devina istorie.</p>
<p><a href="http://itmanagement.earthweb.com/columns/executive_tech/article.php/3719776" title="The Most Hated Company In the PC Industry" target="_blank">Sursa</a></p>
]]></content:encoded>
			<wfw:commentRss>http://www.saltwaterc.net/tech/cea-mai-urata-companie-it.html/feed</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>Rularea aplicatiilor in mod protejat accesului fizic</title>
		<link>http://www.saltwaterc.net/windows/rularea-aplicatiilor-in-mod-protejat-accesului-fizic.html</link>
		<comments>http://www.saltwaterc.net/windows/rularea-aplicatiilor-in-mod-protejat-accesului-fizic.html#comments</comments>
		<pubDate>Tue, 11 Dec 2007 17:04:01 +0000</pubDate>
		<dc:creator>SaltwaterC</dc:creator>
				<category><![CDATA[Linux]]></category>
		<category><![CDATA[Mac OS X]]></category>
		<category><![CDATA[Windows]]></category>

		<guid isPermaLink="false">http://saltwaterc.net/tech/rularea-aplicatiilor-in-mod-protejat-accesului-fizic.html</guid>
		<description><![CDATA[Stiu &#8230; stiu &#8230; nu am mai scris de o tona de vreme. De cand am schimbat jobul, in sensul ca acum sunt programator &#8230; sa zicem ca am avut mult mai putin timp la dispozitie in general, deci implicit a trebuit sa tai de unde se poate &#8230; din pacate si din actiunea de [...]]]></description>
			<content:encoded><![CDATA[<p>Stiu &#8230; stiu &#8230; nu am mai scris de o tona de vreme. De cand am schimbat jobul, in sensul ca acum sunt programator &#8230; sa zicem ca am avut mult mai putin timp la dispozitie in general, deci implicit a trebuit sa tai de unde se poate &#8230; din pacate si din actiunea de a posta pe blog. Cred ca am gasit balaria aia de directie spre care ma indreptam, deci o sa mai scot din mine niste balarii tehnice.<span id="more-296"></span></p>
<p>Stateam si ma gandeam zilele acestea la o metoda de a proteja anumite aplicatii de accesul neautorizat in ceea ce priveste accesul fizic la o masina. Problema sta cam asa: un sistem securizat priveste utilizatorul ca un potential risc &#8230; deci nu este o entitate in care se pune incredere (si bine face, dar despre asta in episodul urmator). Chiar daca utilizez deja sistemul sub un cont de user dupa cum va povesteam <a href="http://saltwaterc.net/tech/de-ce-user-si-nu-admin.html" title="De ce USER si NU admin" target="_blank">aici</a>, browserul, clientul de mail au master password care cripteaza parolele stocate in managerele proprii &#8230; sistemul prezinta o vulnerabilitate asupra accesului direct &#8230;</p>
<p>Se intampla sa vina prieteni pe la mine (din care unii evident &#8211; impart ocupatii asemanatoare), si cum nu am o masina dedicata pentru fiecare chestie in parte, sa zicem ca muzica canta de pe aceeasi masina de pe care fac development, browsing, si alte chestii. Momentan mi s-a pus pata pe cookie-uri, desi exista si alte date confidentiale care ar trebui sa ramana pe disk-urile proprii si numai acolo. Daca eu, ca detinator al sistemului &#8230; folosesc un model de securitate prin care eu nu sunt crezut fara autentificare ca superuser &#8230; de ce ar fi altii crezuti? Simplu &#8230; ei nu ar trebui sa fie, dar sunt. Browserul isi stocheaza profilul in directorul de &#8220;user data&#8221;. Chestia asta e valabila si sub *nix &#8230; deci vorbesc la cazul general, indiferent ca e vorba de /home/{user_name} sau de %systemroot%\Documents and Settings\{user_name}\Application Data (pe scurt %appdata%). Din moment ce browserul ruleaza sub un anume user &#8230; drepturile din &#8220;user data&#8221; sunt drepturile complete ale aceluiasi user. Simplu ca buna ziua. De ce nu mi-as crede proprii prieteni? Hmm &#8230; nu stiu &#8230; cred ca de cand am inceput sa citesc documentatie despre securitate &#8230; am devenit paranoic. In fine, sa continuia asupra ideei lansate.</p>
<p>Morala este simpla &#8230; se creeaza un utilizator cu acces limitat. Sub Windows (prin modelul prezentat in articolul anterior dedicat acestui fapt) este obligatoriu ca acesta sa aiba parola diferita de o parola nula pentru a permite utilizarea runas. Sub *nix este necesara prezenta loginului daca nu exista sudo, in caz contrar un <em>sudo su {user_name}</em> &#8211; ar loga un utilizator fara drept de login. Smecheria asta cu sudo am descoperit-o cand ma chinuiam sa dau drepturi de acces unui server HTTP (Apache 2) la un director SSH montat ca local prin sshfs. Solutia a fost sa montez directorul ruland comanda de mount de sub userul serverului &#8230; dupa ce in prealabil am dar acces mai larg la montare.</p>
<p>Dupa ce utilizatorul este creat &#8230; se muta user data-ul in directorul userului nou, se interzic drepturile de acces (citire) in ceea ce priveste fisierele utilizatorului (in cazul in care grupul/others au acces de citire la fisiere), iar aplicatia care se doreste a fi rulata protejat, se ruleaza folosind noul utilizator &#8230; astfel in momentul in care aplicatia este inchisa &#8230; datele sunt in siguranta. Ideea este simpla &#8230; punerea in aplicatie cere niste consum de taste in plus.</p>
<p>Apropo de paranoia care o ziceam mai sus &#8230; nu e 100% absurda. Au existat cazuri (da, la plural) cand din vina prietenilor mei, primeam acces la datele lor fara sa fac efort &#8230; mi se oferea un authentication_id (o metoda stupida de a autentifica calculand un hash obosit pentru a scuti utilizatorii unui site de actiunea de a tasta user+pass &#8211; si care ramane constant daca se schimba parola &#8211; deci algoritmul de generare este prost pentru ca nu stie de modificari, securitatea este precara datorita faptului ca un URL de acest gen este trimis in mod plain text prin retea), sau o usa de acces la chestii din sistem &#8211; si evident &#8211; nu ratam ocazia unui prank de zile mari. Motivul pentru care mi s-a pus pata pe cookie-uri care ar putea fi folosite pentru un prank la adresa proprie &#8230; motivul pentru care am varsat literele de mai sus &#8230; cu un singur catch &#8230; aplicatia nu trebuie sa ruleze ca utilzatorul respectiv in momentul in care se primesc vizite dupa modelul celui de mai sus (si chiar in general).</p>
<h1><a href="http://saltwaterc.net/disclaimer/"><span style="color: #000000">Disclaimer</span></a></h1>
]]></content:encoded>
			<wfw:commentRss>http://www.saltwaterc.net/windows/rularea-aplicatiilor-in-mod-protejat-accesului-fizic.html/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>
