16 Ekim 2008 Perşembe

Oto Galeri Otomasyonu (Programı)

(Satın almak için: http://www.galera.com.tr/oto-galeri-programi-otomasyonu.html )



Oto Galeri Otomasyonunu (programını) tamamlamış bulunmaktayım.
Geliştirdiğim bu programı satın almak ve diğer özelliklerini öğrenmek için Galera Yazılım'ın sayfasını ziyaret edebilirsiniz:
http://www.galera.com.tr/oto-galeri-programi-otomasyonu.html

Bu blog yazım bu programım hakkında ön bilgi vermek amaçlı.

Neden böyle bir yazılım geliştirdim ?

Bu yazılımı babamın iş ortağının ricası üzerine geliştirdim. Babam 1996 yılından beri ortaklarıyla beraber oto alım-satım işiyle meşgul (www.batuklar.com)
Benzer bir yazılımı bir yazılım firmasından talep ettiler ve ciddi anlamda yüksek bir ücret teklifi aldılar yazılım için.
Aman hiç bulaşmayın dedim ben daha iyisini yapayım size hem de ücretsiz :)
Onlar için böyle bir yazılım geliştirerek çorbada bir tuzum olsun istedim.

Piyasada daha önceden oto galeriler için geliştirilmiş yazılımlar var ama bu yazılımlar, karmaşık muhasebe programlarından farklı değil. Bu yüzden program kullanmayı çoğunlukla bilmeyen ve muhasebe terimlerine yabancı olan oto galeri esnafı karmaşık programları kullanamıyor.

Bu yazılım, oto galerinin alış satışını yaptığı araçlara yönelik ödeme, masraf, vekalet bilgisi ve satış devri bilgisi gibi sürecin her aşamasını programın sunduğu basit ve anlaşılır web arayüzüyle kolayca takip edebilmesini sağlıyor ve maliye ve denetlenme korkusunu ortadan kaldırıyor. Nasıl mı? Çünkü tüm kayıtları sadece USB bellekte depolayabilme özelliğine sahip.

Programdan Örnek Bir Araç Sayfası:


Benzeri Yok: Temel özellikleri neler ?
- Basit web arayüzü ile çok kolay kullanım sağlayarak iş takibini hızlandırması ve şık ve sade tasarımı. Kullanıcının internetten haber okuyacak kadar bilgisayar kullanmayı bilmesi yeterli. Sadece 15 dakikasını ayırarak tüm detaylarını öğrenebilir ve programı kolaylıkla kullanabilir.
- USB bellekten çalışıyor ve böylelikle tüm özel verilerini kullanıcı cebinde taşıyabiliyor. Maliye ve denetlenme korkusu olmadan gönül rahatlığıyla kullanılabiliyor, çünkü program tüm veritabanı kayıtlarını USB bellekte saklıyor. İster evden ister işyerinden kullanıcı gittiği heryerde programını kullanabiliyor. Yani "Tak ve Çalıştır" özelliği!
Tabi bu kullanıcının isteğine bağlı. Kullanıcı isterse kurulum sırasında "Kayıtlarımı bilgisayarımda depola" seçeneğini seçerek USB bellek bağımlılığı olmadan da programı kullanabiliyor.
- Gelişmiş araç raporlama ile
  • Herhangi bir araç modelinden kaç adet sattım ?
  • Bu araç modelini ortalama ne kadar sürede sattım ?
  • Bu modelin bana olan toplam karı ve birim karı nedir ?
  • Ve bu modeli daha çok hangi aylarda sattım ?
  • Ay satış dağılımım toplamda ne ?
bilgisini galericinin karşısına rapor olarak sunması ve böylelikle galerinin ileriye yönelik iş planına yön vermesine yardımcı olması

- Özel sözleşme ve senet modülü ile
Alış-Satış sözleşmesinin ve satılan araca ait tüm senetlerin A4 boyutundaki özel senet kağıdı ile tüm yazıcılara uyumlu bir şekilde kolayca yazdırılabilmesi (Bir A4 kğıdına 2 senet yazdırır)
- Akıllı yedekleme ile tüm veritabanının yedeğini alıp yedek dosyasını kullanıcıya mail olarak göndermesi ve böylelikle bilgi güvenliğini en üst düzeyde sağlaması.
Kullanıcının bilgisayarı bozulsa da ya da USB belleğini kaybetse de mail adresine tıklaması yeterli.
(Mail adresinden yedek dosyası indirildikten sonra, tüm kayıtları geri yüklemek kullanıcının sadece 30 saniyesini alıyor)
- Ve son olarak kullandığı web teknolojisinin desteğiyle bir programdan öte kurumsal bir çözüm paketi şeklinde kullanılabiliyor. Sadece bir bilgisayara kuruluyor (ana bilgisayar) ve yerel ağdaki diğer bilgisayarlarda kuruluma gerek kalmadan kullanılabiliyor.
(Diğer bilgisayarlar ana bilgisayara kurulan Apache Tomcat sunucusuna modem üzerinden bağlanarak hizmet alıyorlar)

Ek Modüller:
- Şirket Masraf Takip Modülü :


Oto galerinin şirket masraflarını belli masraf tipleri tanımlayarak başlıklar altında takip edebildiği ve raporlayabildiği modüldür.
- Ek Ödeme Takip Modülü :
Oto galerinin araç dışı farklı şahıs veya kurumlara alacak ve borç takibini belli iş tanımları ekleyerek takip edebildiği modüldür.

Teknik Bilgi:

- Dil: java, jsp (20.000 satırdan fazla JAVA/JSP kodu, 67 ekran görüntüsü (JSP dosyası))
- Uygulama Sunucusu: Tomcat 6.0
- Veritabanı: PostgreSQL 8.3
(27 ilişkisel veritabanı tablosu)
- Geliştirilme Ortamı: Eclipse WTP (web tool platform for J2EE)
- Kullanılan uygulama çatıları (framework): Struts 2, Hibernate 3
- Kurulum nasıl gerçekleşiyor ? :

Kurulum için bir batch file çalıştırılıyor. Bu batch file sırasıyla uygulama sunucusu olan Tomcat 6 ve PostgreSQL kurulum işlemlerini tamamlayip OTO veritabanını, tabloları ve relation ları oluşturuyor. Galeri.war dosyasını da Tomcat'in webapps klasörünün altına kopyaliyor. Ve programın kısayolunu da kullanıcının masaüstüne kopyaladıktan sonra kurulumu tamamlanmış oluyor.

Veritabanını oluşturan PostgreSQL komutları sırasıyla şöyle:

OTO veritabanını oluşturan komut :

createdb -W -U postgres OTO

Tabloları ve relation ları oluşturan komut :

psql -W -U postgres -d OTO -f db.sql
- Masaüstündeki programın kısa yolu uygulamayı nasıl başlatıyor ? :
Program aslında bir web uygulaması ve calışması için öncelikle uygulama sunucusu olan Tomcat'in başlatılması gerekiyor. Masaüstündeki programın kısayolu yine bir batch file ın kısayolu. Kullanıcı masaüstündeki program icon'una tıkladığında bir batch file çalıştırılıyor. Bu batch file öncelikle Tomcat i çalıştırıyor ve daha sonra Internet Explorer'ı şu url ile açıyor : http://localhost:8080/Galeri

Bu batch file'da çalışan komutlar şöyle :

start tomcat6

start iexplore "http://localhost:8080/OtoGaleri"

Böylelikle kullanıcı masaüstündeki icon a tıklayarak Tomcat i çalıştırmış oluyor ve daha sonra bir Internet Explorer penceresini karşısında buluyor. Internet Explorer da verilen URL ile açılan pencere, programın giriş ekranı.
Yani şu:



Geliştirdiğim bu programı satın almak ve diğer özelliklerini öğrenmek için Galera Yazılım'ın sayfasını ziyaret edebilirsiniz:
http://www.galera.com.tr/oto-galeri-programi-otomasyonu.html
.

12 Haziran 2008 Perşembe

Proje Yönetim Sistemi Otomasyonu

2007-2008 bahar doneminde Yazılım Mühendisliği Laboratuvari dersi kapsaminda gelistirdigim bu proje hakkindaki temel bilgileri bu yazida vermeye calisacagim.

Projenin
- SRS (System Requierement Specification)
- SDD (Software Design Descriptiom) belgeleri ve
- ER diagrami ile
- Veritabani scriptini incelemek isterseniz bana e-mail yoluyla ulaşabilirsiniz. (fatih_batuk [at] yahoo.com)

Gelistirilme Ortami : Eclipse WTP (web tool platform for JEE)
Dil : jsp, java
kütüphaneler
: Struts2, Hibernate
Veritabani : PostGreSql 8.2

Projenin Kısa Tanımı :

Sistem birden çok projenin yürütüldüğü bi firmanın proje ve kaynak yönetimi ihtiyacını karşılayacak biçimde düşünülmüştür. Sistemde projeler, proje modülleri ve alt modüller tanımlıdır. Her proje birden fazla proje modülünden oluşabilir. Her proje modülü de birden fazla alt modülden oluşabilir.

Sistemde proje yöneticiler, takım liderleri ve calışanlar tanımlıdır. Bir projeye ait kaynaklar, o projedeki proje yöneticisi, takım liderleri ve çalışanları ifade etmektedir. Her proje bir proje yöneticisi tarafından yönetilir. Bir proje yönetici birden fazla projeyi yönetebilir.

Sistemde takımlar tanımlıdır. Her takımın bir lideri vardır ve her takım lideri yalnızca bir takıma liderlik edebilir. Bir takımda istenildiği kadar çalışan olabilir.

Sistemde görevler tanımlıdır. Sistemdeki proje alt modüllerine birden fazla görev atanabilir. Bir görev yalnızca bir proje alt modülü için tanımlıdır. Bir görev yalnızca bir takıma aittir. Ve her takıma bir görev verilebilir. Görevlerin başlangıç ve bitiş süreleri vardır.

Sistemde, sistem kullanıcıları için roller tanımlıdır. Her kişinin bir rolü vardır. Sisteme girdiğinde, ait olduğu role ait izin verilen işlemleri gerçekleştirebilmelidir. Yeni roller eklenebilmelidir. Temel roller süper kullanıcı, proje yöneticisi, takım lideri ve çalışan dır.

Proje’de karşılanan temel İşlevlerden bazıları :

  • Sisteme süper kullanıcı tarafından yeni proje yöneticisi, takım lideri ya da çalışan eklenebilir, var olanlar değiştirilebilirö silinebilir.
  • Sisteme süper kullanıcı tarafından yeni projeler, proje modülleri ve alt modüller eklenebilir ve var olanlar değiştirilebilir, silinebilir.
  • Sisteme süper kullanıcı veya proje yöneticisi tarafından yeni görevler ve takımlar eklenebilir ve var olanlar değiştirilebilir, silinebilir.
  • Bir projedeki tüm kaynaklar(işgücü), projedeki takımların yüklendiği görevler ve o takımdaki çalışanlar tüm roller tarafından listelenebilir.
  • Bir modülün tamamlanma oranı ayrılan iş gücüne göre hesaplanarak süper kullanıcı veya proje yöneticisi tarafından raporlanabilir.

Projenin ER Çizeneği (Entity-Relationship Diagram):




Projenin bazı ekran görüntüleri :

1.

2.



3.



Öğrenci Okul Servisi Otomasyonu

2007-2008 guz doneminde Veritabani Laboratuvari dersi kapsaminda gelistirdigim bu proje hakkindaki temel bilgileri bu yazida vermeye calisacagim

Gelistirilme Ortami : .NET 2005
Veritabani : Oracle 10g
Dil : aspx, C#

Projenin Kısa Tanımı :

Sistem farkli okullara servis hizmeti veren bir servis sirketinin ihtiyacini karsilayacak bicimde duzenlenecektir. Sirketin filosindaki araclarla farkli okullara eszamanli hizmet verebildigi dusunulmustur. Sistemde okullar kayitlidir. Okullarin mudurleri tanimlidir ve servis sirketi okul ile ilgili organizasyon meselerini okul muduru ille irtibata gecerek yapmaktadir.

Sistemde soforler ve araclar tanimlidir. Okullara servis atamalari yapilmaktadir. Bir okula atanan servisler ogretim yilinin sonuna kadar sabittir. Bir servis araci birden fazla okulun servis aginda eszamanli olmamak kaydiyla bulunabilir. Bir servis bir okul icin sadece bir guzergaha atanabilir. Bir servis araci birden cok servis soforu tarafindan kullanilabilir ve bir servis soforu birden fazla araca atanabilir.

Sistemde rehberler tanimlidir. Rehber ilkogretim okuluna hizmet verildiginde servis sirketi tarafindan soforle birlikte araca atanmaktadir. Rehber ilkogretim ogrencilerini aractan indirip guvenli bir yere birakmak ile gorevlidir. Rehber tasiyan araclarin kapasitesine rehberin oturma yeri dahildir. Rehber de bir yolcu olarak algilanip kapasite dolduracaktir. Ilkogretim ustu duzeyindeki okullar icin servislerde rehber bulunmayacaktir.

Sistemde iller tanimlidir Bir ilde birden cok okula hizmet verilebilir. Sistemde bolgeler, mahalleler, duraklar ve guzergahlar tanimlidir. Ogrenciler ilgili guzergahin ilgili duragindan servise binerler. Bir bolgede birden fazla mahalle bulunabilir. Bir mahallede birden fazla durak olabilir. Guzergahlar duraklarla tanimlidir. Bir duraktan birden fazla guzergah da gecebilir. Bir okul servis aginda birden fazla guzergah tanimlanabilir.

Sistemde ogrenciler tanimlidir. Ogrenciler okullarina atanan guzergahlardan birini secip kendilerine en yakin duraktan servise binerler. Ihtiyaca gore guzergaha duraklar eklenip cikarilabilir. Ogrenci icin bindigi duraktan ucretlendirme yapilir. Ogrencinin taksitleri bindigi duraga gore tanimlidir.

Sistemde yoneticiler tanimlidir. Yoneticiler servis sirketinin personelidir ve onay islemlerini yuruten sistem yoneticileridir. Yoneticiler bölge-güzergah-servis-sürücü işlemlerini yönetebilir, güzergahlara yerleşmek isteyen öğrencileri onaylayip sisteme kaydedebilirler.

Proje’de karşılanan temel işlevlerden bazıları :

  • Sisteme yeni il, bolge, mahalle, okul, okul turu, arac, sofor, rehber, ogrenci, yönetici ve müdür eklenebilir, var olanlar listelenebilir, duzenlenebilir ve silinebiir
  • Sistem yoneticileri okullara servis atayabilir, guzergahlari ve duraklari tanimlayabilir, soforlerin ve gerekliyse rehberin servise atanmasini gerceklestirebilir.
  • Guzergahlara durak eklenip çıkartılabilir. Yeni guzergahlar tanimlanabilir.
  • Ögrenci taksitleri yonetici duzeyinde kontrol edilip listelenebilir ve odeme girisi yapılıp düzenlenebilir.


Projenin ER Çizeneği (Entity-Relationship Diagram):



Projenin sorgu ekranları için Oracle'da gerçekleştirimi yapılan faydalı olabilecek bazı SQL sorgu örnekleri :

1.
Taksidi ödenmemiş öğrencilere 3 taksit için %10, 4 taksit için %15, 5 taksit için %20, 6 taksit için %25 faiz ekleyerek, öğrencinin TC nosu, adı, soyadı ve toplam borcunu listele

SELECT OGRENCITAKSIT.TCNO, KISI.KISIAD, KISI.KISISOYAD,

CASE COUNT(*)
WHEN 3 THEN SUM(MIKTAR)*1.1
WHEN 4 THEN SUM(MIKTAR)*1.15
WHEN 5 THEN SUM(MIKTAR)*1.2
WHEN 6 THEN SUM(MIKTAR)*1.25
ELSE SUM(MIKTAR)
END AS TOPLAM_BORC

FROM OGRENCITAKSIT

INNER JOIN OGRENCI ON OGRENCI.TCNO = OGRENCITAKSIT.TCNO

INNER JOIN KISI ON OGRENCI.TCNO = KISI.TCNO

WHERE OGRENCITAKSIT.ODENDI = 0

GROUP BY OGRENCITAKSIT.TCNO, KISI.KISIAD, KISI.KISISOYAD


2. Her araçtaki mevcut öğrenci miktarı ile araç kapasitesini listele

SELECT ACIKLAMA, plaka, COUNT(*) AS MEVCUT, KAPASITE FROM OGRENCI

INNER JOIN GUZERGAHDURAK ON
OGRENCI.GUZERGAHDURAK_PK = GUZERGAHDURAK.GUZERGAHDURAK_PK

INNER JOIN GUZERGAH ON GUZERGAHDURAK.GUZERGAHNO = GUZERGAH.GUZERGAHNO

INNER JOIN ARAC ON GUZERGAH.ARACNO = ARAC.ARACNO

GROUP BY ACIKLAMA, plaka, KAPASITE



3. Girilen minimum bolge sayisina 'VE/VEYA' minimum okul sayisina sahip illeri listele

SELECT ILAD FROM IL WHERE ILNO IN

( ( SELECT ILNO FROM BOLGE GROUP BY ILNO HAVING COUNT(*) > :BOLGENO )

INTERSECT ('VEYA' için INTERSECT yerine 'UNION' yazılmalı)

( SELECT ILNO FROM OKUL GROUP BY ILNO HAVING COUNT(*) > :OKULNO ) )


4.

SELECT SOFORARAC.SOFORARAC_PK, SOFORARAC.TCNO, SOFORARAC.ARACNO, SOFORARAC.BASLANGICSAATI, SOFORARAC.BITISSAATI,
SOFORARAC.GUNU, SOFORARAC.BASLANGICTARIHI, SOFORARAC.BITISTARIHI, SOFORARAC.TCNOREHBER,
KISI.KISIAD || ' ' || KISI.KISISOYAD AS SOFORISIM, KISI_1.KISIAD || ' ' || KISI_1.KISISOYAD AS REHBERISIM, ARAC.PLAKA

FROM SOFORARAC

INNER JOIN ARAC ON SOFORARAC.ARACNO = ARAC.ARACNO

LEFT OUTER JOIN KISI ON SOFORARAC.TCNO = KISI.TCNO

LEFT OUTER JOIN KISI KISI_1 ON SOFORARAC.TCNOREHBER = KISI_1.TCNO


Projenin ekran goruntulerine de vaktim olursa burda yer vermeye calisacagim.

26 Mart 2008 Çarşamba

Java Asn1 Compiler (open source)

(download link : http://sourceforge.net/projects/jac-asn1/)

JAC, is an open source asn1 compiler that I have completed in 2 months during my internship at Turkcell Technology. It was the last 2 months of my internship (July-August, 2007).

JAC (Java Asn.1 Compiler)
is a tool to parse the asn.1 file, create .java classes of defined asn.1 data types and do encoding/decoding of instances of the generated java classes.
It is used in the end-to-end communications due to the asn.1 principles.

Before starting to develop the project I have searched and examined lots of open source compilers but a good free java asn.1 compiler that supports BER encoding was not available on the net. There were lots of open source compilers but they were not sufficient for our needs.

In the end of the internship, we gave my project the name "JAC (Java Asn1 Compiler)".
And I have hosted it on sourceforge.net as an open source project after getting the permission from Trukcell Technology.
The link of my project for download is here :

http://sourceforge.net/projects/jac-asn1/

More About JAC - Java Asn.1 Compiler



JAC (Java Asn.1 Compiler)
is a tool for you if you want to
(1) parse your asn.1 file
(2) create .java classes of data types defined in your asn.1 file and
(3) do encoding/decoding of instances of your generated classes.
BER, CER and DER are all supported. Just download and start using immediately.
Just forget all asn1 byte streams, and take the advantage of OOP!

All generated java classes by JAC, have the followings inside:

Public member data variable(s) to hold data of the generated type.
Constructor(s) to initialize the object.
Set(..) Method to set the variables of the object.
• An encode(..) method to create asn.1 byte stream which is the output to send.
• A decode(..) method to create the java object from the received encoded input stream.
• A print(..) method to print the contents of the object.

So, JAC gives the opportunity to user working with Java objects instead of playing with complex asn.1 byte streams.
During encoding JAC writes a Java object to an output byte stream which is the encoded output before sending, and when decoding creates a Java object from the received byte stream which is the received encoded input, due to the principles of asn1 standards.

There are clear examples under the download package of my project about the term "asn.1" and asn.1 files.
In the Power Point document "JAC (Java ASN1 Compiler).ppt" there are good examples of how to create .java classes from asn.1 files and do encoding/decoding by use of JAC.
In this power point slide show you can find all features and capabilities of JAC.

And also note that, each new version information is specified in the file "Version.txt" file under the download package.

JAC class extension hierharchy is shown briefly on the figure below :



modified W.Woody's asn.1 library package




JAC's package




Created .java classes by JAC



Please feel free to contact me about the project (JAC - Java Asn1 Compiler).
Any questions, suggestions or comments will be welcomed.