Blogmani’de puanlarınız nasıl hesaplanıyor?
Şu an yazacak vaktim yok. Kod çok basit; biraz bakarsanız hemen anlayacaksınız.
function google_puan()
{
// PAGERANK’i 1500′le çarp ve link sayısını ekle
global $pagerank,$linkcount;
global $google_puan;
$pagerank=$pagerank*1500;
$google_puan=$pagerank+$linkcount;
return $google_puan;
}
function alexa_puan()
{
global $alexa_rank,$alexa_reach,$alexa_links,$alexa_delta,$alexa_puan_ok;
if ($alexa_delta<0)
{
$negatif=”Y”;
$alexa_delta=abs($alexa_delta);
}
switch ($alexa_rank)
{
case ($alexa_rank>1 AND $alexa_rank<=10000):
$alexa_puan=1000;
break;
case ($alexa_rank>10000 AND $alexa_rank<=40000):
$alexa_puan=700;
break;
case ($alexa_rank>40000 AND $alexa_rank<=60000):
$alexa_puan=500;
break;
case ($alexa_rank>60000 AND $alexa_rank<=100000):
$alexa_puan=200;
break;
case ($alexa_rank>100000 AND $alexa_rank<=300000):
$alexa_puan=50;
break;
default:
$alexa_puan=0;
}
switch ($alexa_delta)
{
case ($alexa_delta>10 AND $alexa_delta<=1000):
$alexa_puan2=25;
break;
case ($alexa_delta>1000 AND $alexa_delta<=5000):
$alexa_puan2=50;
break;
case ($alexa_delta>5000 AND $alexa_delta<=10000):
$alexa_puan2=100;
break;
case ($alexa_delta>10000 AND $alexa_delta<=15000):
$alexa_puan2=150;
default:
$alexa_puan2=200;
break;
}
if ($negatif==”Y”)
{
$alexa_puan2=0-$alexa_puan2;
}
$alexa_puan3=$alexa_links*10;
$alexa_puan_ok=$alexa_puan+$alexa_puan2+$alexa_puan3;
return $alexa_puan_ok;
}
function technorati_puan()
{
global $inboundblogs,$inboundlinks,$rank,$technorati_puan;
$technorati_puan1=$inboundblogs*50;
$technorati_puan2=$inboundlinks*10;
switch ($rank)
{
case ($rank>2 AND $rank<=10000):
$technorati_puan3=8000;
break;
case ($rank>10000 AND $rank<=20000):
$technorati_puan3=7000;
break;
case ($rank>20000 AND $rank<=30000):
$technorati_puan3=6000;
break;
case ($rank>30000 AND $rank<=45000):
$technorati_puan3=5000;
break;
case ($rank>45000 AND $rank<=80000):
$technorati_puan3=4500;
break;
case ($rank>80000 AND $rank<=130000):
$technorati_puan3=4000;
break;
case ($rank>130000 AND $rank<=200000):
$technorati_puan3=3500;
break;
case ($rank>200000 AND $rank<=300000):
$technorati_puan3=2500;
break;
case ($rank>300000 AND $rank<=500000):
$technorati_puan3=1500;
break;
default:
$technorati_puan3=0;
}
// BURADA DÜZELTME YAP!
// EN YÜKSEK INBOUNDBLOG ALMIŞ 1 VE 2.BLOGU BOL -İLK SIRADA BİRDEN FAZLA BLOG VARSA,%10 FARKLI OLARAK BİRİNCİ
// OLARAK GRUPLA: 1. ve 2.ler arasındaki fark belli bir yüzdenin üzerinde ise, birincileri cezalandır
$technorati_puan=$technorati_puan1+$technorati_puan2+$technorati_puan3;
return $technorati_puan;
}
Umuyorum Cuma akşamına kadar Blogmani’nin “deneysel” sürümünün kodlaması bitecek.
Deneysel’den kastım; bunun bir Proof of Concept (“işte böyle çalışıyor” mukabili bir söz) çalışma olması. Temel fonksiyonlar çalışacak. Yani en basit haliyle. Bundan sonra, motivasyona bağlı olarak(!) projede tasarladığımız pek çok yenilik var. Motivasyon ise, elbette projenin sağlayacağı başarı ile doğru orantılı. Ne kadar çok katılım olursa, bu bizi o kadar çok motive eder. Açıkçası, ilk haliyle göreceğiniz blogmani, oldukça basit olacak. Bunun nedeni, elbette ki zaman kıtlığı. Bu tip projeler para getirmediği için, kendinizi böylesine yoğun bir çabaya tamamen adamanız mümkün değil.
Blograzzi deneyiminden en azından ben, ders aldım. Blograzzi, hergün biraz daha iyiye giden bir proje, üstelik insanları dinleyen birileri tarafından sürdürülüyor. Şu an Blograzzi’de tek yanlış bulduğum şey, puanlama algoritmasının “gizemini koruması”.
Bunu neden gizlediklerini bilmiyorum; ne de olsa ne Blograzzi’de Leibniz çalışıyor, ne de diferansiyel denklemlerin bile bilinmediği dönemlerde yaşıyoruz. Üstelik, kalıbımı basarım gayet basit bir matematiksel formülü var (diferansiyel denklem filan kullanmadıklarına yemin edebilirim!)
Bu konu daima şaibe kaynağı oldu ve açıklanmadıkça da olmaya devam edecek.
Onun için, blogmani’nin puan hesaplama sistemi şeffaf ve öyle de kalacak.
Abartıp, bunu hesaplayan PHP kodunu da sayfaya koyuyorum.
Hemen ekleyeyim; herşey doğru çalışıyor ama sistemin ne kadar adil olduğu üzerinde düşünme fırsatım olmadı. Ivır zıvırlar, zorunlu sıkıcı işler -Technorati API’si kullanmak, Alexa ve Google sayfalarını Reg Ex ile parse etmek, veritabanı işlemleri vs..- yüzünden, maalesef hesaplamalarımın ne kadar adil ve gerçeği yansıttığını zamana yayıp, bu süre içinde daha akılcı bir algoritma geliştireceğim. Bu süreçte, fikirlerinizi almak çok faydalı olacak.
Bu arada, potansiyel puanınızı test edebileceğiniz sayfa şurada:
Bir ekleme yapayım: Blogmani içinde blog girdisi yazıp, diğer girdilere yorum yapabileceksiniz. Bu da, puanlarınıza ciddi bir katkı yapacak. Burada amaç, sayısal olarak nerede olduğunuzu değil, ne kadar “yazar” olduğunuzu ölçmek. Aradaki fark, Akademi ödülleri ile Sundance gibi; biz popülariteyi değil, yazarlığınızı ölçmek niyetindeyiz.
Birisi, “blograzzi varken neden uğraşıyorsun?” dedi.
Güzel soru; itiraf edeyim, Serhan fikri ortaya attığında aynısını söylemiş ve ilgilenmemiştim.
Gelgelelim; bu sistem Blograzzi’den farklı çalışıyor. Blogmani, ratingden çok, yazı ve yazar merkezli bir sistem.
Bu birinci neden; bir yenilik getiriyoruz.
İkinci neden, WordPress’in komünite sistemi olmamasını farkedip, bundan rahatsız olmuş olmam. İleride projeyi belli bir noktaya getirip, GPL lisansıyla dağıtabilirim.
Üçüncü neden, “gizli” puanlama sisteminden rahatsız olmam. Blogmani, belli bir yere gelirse, Blograzzi’yi bu konuda açık olmaya itebilir. Açıkçası, Blograzzi’yi önemli buluyorum; ama gizli bir puan sistemiyle desteklemiyorum.
Dördüncü neden, rekabet yaratmak. Bunu daha önce Pozitif PC e-dergi ile yaptık. O zamanlar yeterince farkında değildik ama, zaman içinde Pozitif PC’nin birçok taşı yerinden oynattığını, e-dergi furyası başlatıp olanlarında kalitesini yükselttiğini farkettik. Blogmani ile de böyle bir etki yaratmak istiyoruz. Umuyorum başarılı oluruz; kendi açımdan değil. Zira, ben rating başarılarına prim veren biri değilim. Benim için Blogmani’nin başarısı, daha fazla kişisel yayıncı kazanmak, olanları da teşvik etmektir.
Daha önce, Technorati verilerini, Technorati API’si kullanarak çektiğimi söylemiştim.
Aynı şeyi, Alexa için yapamadım-miktar ne olursa olsun, Alexa API’lerini kullanmak için para ödemek zorundasınız.
Bu durumda, geriye iki seçenek kalıyordu: PHP’nin CURL fonksiyonları, ya da sayfaya soket açıp, sayfa içeriğini işlemek.
CURL kullanmanızı tavsiye etmem: aslında harika çalışıyor; ancak makinaya minimal bir Apache kurduktan sonra, CURL fonksiyonlarının çalışmadığını farkettim. Standart Apache kurulumu ile gelmeyen çoğu kütüphaneyi kullanmak risklidir – sunucunuzda da o fonksiyonlar olamayabileceğinden, bilgisayarınızdaki web sunucusunda güzel güzel çalışan projeniz, hostunuz üzerinde patlayabilir.
O zaman, ben de soket açarım dedim ve fsockopen’ı bol bol kullandım!
fsockopen ile açtığınız sayfalardan spesifik bir bilgiyi alabilmek için, Regular Expressions’ın kucağına düşüyorsunuz. Eğer çok iyi düzeyde Reg Ex bilginiz yoksa -benim gibi!- ve problemi hızlı çözmek zorundaysanız, bildiğiniz kadar Reg Ex ile, sprintf (ve türevleri) ile birlikte, PHP’nin katar işleme fonksiyonlarını kombine kullanın. 15 sene önce olsa farklı konuşurdum; artık yazılım geliştirmek kolay ama zaman çok kısıtlı. Günümüzde en kıymetli kodcu, hızlı olan. Bilgisayarlarda çok hızlı olduğundan, genelde yazabileceğiniz en kötü kod bile, aletlere ter attıramıyor. (Simulatör, 3D oyun, ya da genetik alanında kullanılan tarzda karmaşık programlar yazmadığınızı varsayıyorum!)
Alexa sorununu nispeten kolay çözdüm; zira verilerin düzenli bir XML formatında geldiği bir sayfaya çengel atmayı başarabildim!
Google API’leri günde 1000 sorguya izin verdiği ve sonuçları hala parse etmeniz gerektiği için, yine API kullanmama kararı aldım.
Google ile işim, kolay görünmesine rağmen, biraz maceralı geçti. Pagerank’i alan kodu Internet’ten 10 dakika içinde çalıp(!) neredeyse aynen kullandım. Gelgelelim, arama sonuçlarını veren bir kod bulamadım. Bulduğum üç örneğin ikisi CURL’e dayandığı için, daha ilk anda çalışmadılar. Üçüncü, soket kullanan örnek ise, yazılan yanlış Reg Ex ifadeleri yüzünden çalışmıyordu.
Kolları sıvayarak 2-3 saat içinde, link sayısını veren Google kodunu yazdım. Aslında, uzamanın nedeni, yine bir Reg Ex-PHP azizliğiydi…
Benim kullandığım Apache+PHP sunucusunda, Unicode’dan (UTF-8), ISO tabanlı dil kodlamalarına çeviri yapan fonksiyonlar çalışmıyor. (Açıkcası, hala geliştirilme aşamasında ve PHP’yi ICU desteği ile derlemeniz gerek). Sorun şu; sayfadan Türkçe karakterler geliyor ve Reg Ex, Unicode anlıyor olması gerektiği halde, anlamıyor ve unicode karakterleri bulamıyor. Çözüm? Unicode harfler yerine, Reg Ex’in (.) -nokta- güzelliğini kullanmak! Böylece, katarınız içindeki unicode karakterlerini “her ne gelirse” diye geçiştiriyorsunuz. Harika bir çözüm değil ama her koşulda işe yarıyor. En azından, insanlar php.net’te ve forumlarda “reg ex ile unicode işleyemiyoruz” diye ağlaşırken, siz geminizi yürütüyorsunuz.
Sonuç olarak, Google Pagerank, link sayısı ve Alexa verileri gibi bilgileri de çekmeyi başardım. Technorati işini de dün çözdüğüm için, geriye birkaç iş kaldı.
Bunlardan biri, çektiğim verileri veritabanına yazmak. Bu, en kolay iş.
İkincisi, bu sitelere ulaşılamadığında, scriptimin neler yapacağına karar verecek ek fonksiyonları yazmak. Örneğin, Technorati’den veri gelmezse, tekrar deneme yapılacak mı? Kaç kere denenecek?
Bu tip detaylar…
Üçüncüsü, bu modülü ne zaman ve nasıl çalıştıracağıma karar vermek. Bunun içinde sunucu üzerinde bazı denemeler yapmak gerekiyor. Örneğin, bana üzerinde cron çalıştırmak için izin veriyor mu? Şayet cron iznim yoksa, scripti manuel çalıştırmak gerek.
Son olarak, iş puanlama algoritmasını çıkarmaya kalıyor. Bu iş aslında son derece basit. Tek bir zorluğu var; o da adil ama rekabetçi bir algoritma çıkarmak.
Umuyorum, bir ve iki numaralı maddeleri Pazar ve Pazartesi günü hallederim.
Blogmani projemden daha önce bahsetmiştim.
İki gündür, projeyi kendi bilgisayarıma aldığım için hızlı ilerleyebiliyorum. Yaklaşık 20 gündür, sunucu üzerinde değişiklik yapıp, sonuçları bekleyerek boşu boşuna debelendim. Yarım saatlik bir emekten sonra, çok daha hızlı çalışabilmeye başladım. Her kodcunun bazı komik tembellikleri vardır; benimkisi de, çalışma hızı ve rahatlığını artıracak basit işlemlerden sürekli kaçınıyor olmak.
Şu an, basit bir komünite sistemi için “yeterli” olan bazı geliştirmeleri tamamladım. Umuyorum, gece server’a upload edeceğim. Şu haliyle site feci görünüyor ve bazı şeyler darmadağınık. Puanlama sistemini de halledince, Serhan’la birlikte tema gibi konulara da eğileceğiz ve biraz biraz kullanılabilir bir altyapı çıkacak ortaya.
Zamanımın çoğu, WordPress’in bazı saçmalıklarıyla debelenmekle geçiyor. Bunlardan bir tanesi, usermeta isimli veritabanı tablosu. Nedense, bilinen tüm veritabanı tasarım kurallarına karşı gelerek, kullanıcı bilgilerinin tutulduğu tuhaf bir tablo hazırlamışlar. WordPress, kullanıcı adı ve şifre gibi temel bilgileri users tablosunda tutarken, isim,soyad gibi bilgileri usersmeta isimli bir başka tabloda tutuyor. Bazı durumlarda, kullanıcı bilgilerini çekmek, deveye hendek atlatmaktan beter. Mümkün değil demiyorum; ama öylesine “çakma” çözümler geliştirmek zorundasınız ki, site büyüdüğünde (özellikle ziyaretçi sayısı arttığında) verdiğiniz yanlış kararların altında ezilmeniz işten bile değil. Bu yüzden, usersmeta’yı olduğu gibi bırakarak -çünkü bazı eklentiler ve iç fonksiyonlar onu kullanıyor ve hepsini değiştirmeye kalkmak, sistemi yeni baştan yazmaktan daha zor-, kritik alanları users tablosuna taşıdım.
Neyse ki, şu an için sorun yok. Aslında, kontrol panelinin tasarımı da ciddi zorlayıcı etkenlerden biri. Buna daha sonra geleceğim; sistem tamamlandıktan sonra, şayet kullanıcı sayısı artarsa, oraya da el atacağım.
Az önce, puanlama sistemine başladım.
Blograzzi’nin izinden gideceğim: Google, Technorati verilerini çekip, bunu başka parametrelerle birlikte kullanıp, puanlama sistemini yazacağım. Daha önce de bahsettiğim gibi, puanlama sır filan olmayacak. En sonunda algoritmayı açıklayacağım; bununla oturup kendi puanınızı kendiniz hesaplayabileceksiniz.
İlk olarak, Technorati verilerini çekmeye karar verdim…hatta çektim de. (Resmi büyütün).

Verileri çekerken izleyebileceğim birkaç metod vardı.
1.Kullanıcının sayfasını technorati içinden açıp, gelen HTML sayfayı parse ederek istediğim alanları çekmek. Bu daha önce yapmadığım iş değil. Hala birileri farkında olmasa da, PHP, RegEx (Regular Expressions – Düzenli İfadeler) konusunda neredeyse PERL kadar iyi; üstelik POSIX ya da PERL uyumlu Reg Ex kullanabiliyorsunuz.
Bunu yapmadım. Çünkü Technorati API’nin varlığından haberdarım ve daha önce bahsettiğim gibi, “uydurma” işleri sevmiyorum (mecbur değilsem, vaktim varsa)
2.Blograzzi’den verileri “çalabilirdim”. Bunu da doğal olarak yapmadım. Birincisi, özellikle veri, fikir ve bilgi hırsızlığına karşıyım. İkincisi, pragmatik bir çözüm olmasına rağmen, bu bir klon site değil. Aslında amacım bir yandan, daha önce Pozitif Linux’ta ve Pozitif PC’de yaptığım gibi, insanları teşvik etmek; birşeylerin sanıldığından çok daha kolay olduğunu göstermek.
3.Son olarak, Technorati API’yi kullanabilirdim ve bunu yaptım.
Gelgelelim, bunun bazı sakıncaları var.
Eğer para ödemezseniz, Technorati, API’si üzerinden, günde 500 query yapmanıza olanak tanıyor. Bunun anlamı şu: sonuçları günlük güncelleyeceksem, üye sayım 500′ü geçemez. Ya da para ödemem gerek, ama para kazanmadan doğal olarak Technorati’ye para verecek halim yok(!).
Birkaç API key almak da bir başka çözüm; kodda minik bir oynamaya bakar;)
Aslında API key’i limitsiz kullanabilsem, Blogmani içine çok çok daha kullanışlı bir dizi fonksiyon ilave edebilirdim. Öte yandan, buna zamanım ve isteğim de yok. Eminim, bir gün projeyi açarsam, birsürü insan bu tür siteler yapacaktır.
Technorati API’lerini kullanmak kolay olsa da, kod hamallığından kaçınmak için hazır bir kütüphane buldum. Duck Soup, bu işi hakkıyla yapıyor. Kodu inci gibi yazılmış. Gelgelelim, Technorati sunucuları pek hızlı sayılmaz; böylece Blograzzi’nin neden sonuçları anlık değilde günlük güncellediğini de keşfetmiş oldum.
Bundan sonra yapacağım şu: bir tablo açıp, Technorati’den çektiğim verileri günlük olarak buraya kaydedeceğim. Bunu da, günün “ölü saatlerinde” yapmam gerek ki, sunucum isyan etmesin. Bu arada, Linux tabanlı sunucumun Cron hakkında bana ne gibi haklar tanıdığını da öğrenmem gerek. Aslında, sunucu elimde olsa, yapacağım iş çok basit: cron.daily içine bir script atacağım; bu da PHP ile yazdığım, verileri toplayıp veritabanına giren PHP kodunu çalıştaracak (komut satırından, ya da shell script içinden, “php phpscriptim.php” şeklinde PHP kodu çalıştırabilirsiniz). Elbette, bu kadar hakkın, paylaşımlı bir sunucu içinde bana tanınmış olacağını sanmıyorum; ama birkaç saat içinde çözebileceğim, basit bir problem bu…