Microsoft Bot Framework Giriş Part-1

Hepinizin farkında olduğu üzere ChatBot‘lar artık tüm sosyal ağlar ve web sitelerde olmazsa olmaz hale gelmiş durumda, gerek QnA yardımcısı gerek sistem tarafından sunulan hizmetlerin erişilebilir olması adına birçok platformda karşımıza çıkıyor.

Ben de Microsoft’un Bot Oluşturmak için sunmuş olduğu Bot Framework’den bahsedeceğim.

Öncelikle belirtmeliyim ki Bot Framework henüz Preview durumda, gelen yenilikleri buradan takip edebilirsiniz.

Nedir bu Bot Framework, bana ne gibi kolaylıklar sunuyor?

Microsoft’un kolay ve hızlı şekilde bot oluşturmak, oluşturduğunuz botları test etmek ve desteklenen platformlara entegre etme kolaylığı sunduğu platformudur.

 

 

Bot framework’ün içinde bulunan hizmetlerden yararlanarak, akıllı, öğrenen, insan dilini algılayan, görsel ve video işleyebilen botlar oluşturabiliriz.

Botlarımızı daha akıllı hale getirebilmek için Cognitive Services den yararlanabiliriz.

Language Understanding 5 hizmet sunuyor.

  1. Language Understanding Intelligent Service (LUIS) : Bot ile konuşma esnasında anlatılmak istenilen Fiil(almak, öğrenmek, sipariş vermek, rezerve etmek vs.),  Nesne(pizza, bilet vs.)  Adet(1 adet, 2kg, 3metre vs.) parametleri  algılayıp aksiyon alabilme imkanı sunuyor senaryoları kendinize göre geliştirebilirsiniz.
  2. Text Analytics APIBir metnin yazıldığı dili, hakim olan duyguyu, en fazla geçen kelimeleri algılayabilirsiniz.
  3. Bing Spell Check APIYazım denetimi yapılmasını sağlar, Argo içerikleri marka adlarını algılayabilir.
  4. Linguistic Analysis APIDoğal dil işleme, konuşma bölümü etiketleme ve ayrıştırma özellikleri sunar.
  5. Web Language Model (WebLM) API : Konuşmadaki kelime yoğunluğunu algılama ve sıradaki kelime tahmini özellikleri sunar.

Knowledge Extraction 5 hizmet sunuyor.

  1. Entity Linking Intelligence Service : Önceki sohbetlerden çıkarım yaparak yeni sohbetlerde sonuca daha hızlı ulaşılmasını sağlar.
  2. Recommendations API : Önceki seçimlerden çıkarım yaparak yeni öneriler sunar. (Bunu isteyenler bunu da istediler gibi)
  3. Knowledge Exploration : Yazılan kelimeleri otomatik algılayarak tamamlayan veya tamamlama önerileri sunar.
  4. Academic Knowledge API : Akademik yazılar, dergiler, makaleler gibi kaynaklarda arama yapılmasını sağlar.
  5. QnA Maker : Kullanıcılarla sohbet diliyle sorularına cevap verebilen servistir, önceden tanımlanan soru cevap setlerine göre soruları algılar ve cevap verir.

Speech Recognition and Conversion 3 hizmet sunuyor.

  1. Bing Speech API : Konuşmayı metne yada metni konuşmaya çeviren servistir.
  2. Custom Recognition Intelligent Service (CRIS) : İnsan sesini yada herhangi bir kaynaktan gelen sesi tanıyarak, aksiyon alınabilen servis.
  3. Speaker Recognition API : Sadece tanıtılan sesler tanıyarak çalışan komutlar oluşturabilirsiniz.
  1.  Web Search API : Webde arama yapabilen servis, resim, video, haber aramaları yapabilir.
  2. Image Search API : Resim arama servisi, filtreler uygulayarak resim aratabilirsiniz (deniz resmi, doğa resmi vs.)
  3. Video Search API : Video arama servisi, filtreler uygulayarak videolar aratabilirsiniz (kedi videosu vs.)
  4. News Search API : Haber arama servisi, filtreler uygulayarak haberler aratabilirsiniz (dünya futbolu, güncel haberler vs.)
  5. Autosuggest API : Otomatik tamamlama servisi. Uygulamanızda kullanarak kullanıcıların aramalarını otomatik tamamlayarak kolaylaştırabilirsiniz.

Image and Video Understanding 4 hizmet sunuyor.

  1. Computer Vision API : Görselleri algılayıp içerikleri hakkında bilgi verebilir. Örn. görselde yer alan metinleri algılayabilir, nesneleri tanıyabilir.
  2. Emotion API : Görseldeki yüzleri algılayarak duygu analizi yapabilir. Örn. 4 kişi var ve mutlu, üzgün, yorgun, sıkılmış vb. bilgiler verebilir.
  3. Face API : Yüz algılama servisidir, yüzleri algılayarak doğrulama yapabilir yada benzer yüzleri gruplayabilir.
  4. Video API : Vidoları analiz edebilir, yüzleri algılayıp takip edebilir, videodaki titremeleri düzeltebilir, haraketleri algılayıp aksiyonlar alınabilir.

Bot’larımızı .Net ve NodeJS ile geliştirebiliyoruz, Microsoft’un iki platform içinde SDK’sı bulunuyor;

NodeJs için buradan, .Net için buradan ulaşabilirsiniz, ayrıca son güncellemelerin yayınladığı blog’a buradan ulaşabilirsiniz.

.NET Core, .NET Standart ve Felsefe Taşı – Part II

Previously on : .NET Core, .NET Standart ve Felsefe Taşı – Part I

“It does not do to dwell on dreams and forget to live.” ― J.K. Rowling, Harry Potter and the Sorcerer’s Stone

J.K. Rowling’in de dediği gibi, hayal dünyasının içerisinde hayat sürüp yaşamayı unutmak pek olmuyor. İşte PCL’ler hayatımıza böyle girmişti fakat, hayal dünyasının içerisinde, yani teoride mantıklı bir yaklaşım, gerçek hayata uyarlandığında pek de tutarlı olmadı, olamadı. Çok mu abarttım? Olabilir. Ama bu ortada çözülmesi gereken bir durumun olduğu gerçeğini değiştirmiyor.

Soruyu tekrar alabilir miyim?

Ha, şu soru. .NET Standart neden var? Ondan öncesinde PCL’ler neden var diye sormamız gerekiyor değil mi? Çözmeye çalıştığı problem aslında yazdığınız kodların farklı .NET proje tiplerinde kullanılabilmesini sağlamak. Peki neler bu proje tipleri ? .NET Framework, Silverlight, Windows 8 (Metro), Windows Phone, Xamarin, Mono, Universal Windows Platform (UWP), XBox 360, liste daha uzuyor.

enter image description here

Evet, tabii, güzel fikir. Bir çok ihtiyacı da karşıladı aslında, bu sebeple tamamen kötülemek doğru olmaz ama bir süre sonra bu yaklaşımın eksikliklerini görmeye başladık.

Nerede benim API’ım ?

dotnet-today

Birinci problem, PCL altyapısı, uygulamayı yazarken kullanabileceğiniz API’ı, desteklemeye çalıştığınız platformların kesişimine göre belirliyor. Bir platformda olan bir API diğer platformda yoksa, o kısım çıkartılıyor. Örneğin Xamarin.iOS, Xamarin.Android ve UWP için yaratayım bir PCL dediğinizde, yapacağınız dosya okuma ve yazma işlemleri artık düşündüğünüz kadar kolay olmuyor. Çünkü bir tarafta System.IO varken, diğer tarafta Windows.Storage var. Kesişimin içerisinde bu iki API da yok. Yani, var da yok. System.IO namespace olarak var ama tanıdık olduğumuz File ve Directory yok mesela. Bu sefer kulağınızı tersten tutmaya ve şuradaki gibi bir guide’ı takip etmeye başlıyorsunuz. Bu da size hayatınızı ve mesleki kararlarınızı sorgulatabiliyor. Halbuki sadece bir dosya okumak istemiştiniz. Bu tür eksiklikleri kapatmak için ortaya PCLStorage gibi paketler çıkıyor ama bu nedense yama hissiyatı yaratıyor. Her kombinasyonda eksik kalan parçalar ve o eksiklikleri kapatmaya çalışan paketler. Sonu gelmez bir döngü.

Ama Cross-Platform oluyor değil mi ?

Aslında tam değil. Yazdığınız kod her platform için ayrı ayrı derleniyor. Evet, bir PCL paketini NuGet üzerinden çekerken bütün desteklenen platformlar için derlenen dosyalar da yanında geliyor. Şimdi, bundan iki yıl sonra başka bir .NET platformu çıksa – ki bu hızda giderse hiç de düşük bir olasılık değil – bu paket o platformda çalışacak mı? Tabii ki hayır. Çünkü paketin, bu platform da eklenerek tekrar derlenmesi gerekiyor. Bu arada kaybedebileceğiniz API’ları da bir yandan düşünseniz iyi olur. Onlara da bir “yama” gerekecek.

.NET Standart

Yani bu iki büyük soru işaretine karşı çözüm olacak yapının, öncelikle stabil bir API sunması gerekiyor. Bu ise, hali hazırdaki platformların bu API’ı implemente etmesi gerektiği anlamına geliyor ki geliştirmek istediğim platformlara göre erişebildiğim API oranı azalmasın. Aynı zamanda, sonrasında geliştirilebilecek diğer platformların da aynı API’ı implemente etmesi sağlanırsa, bu yapı için derlenen paketlerin de gelecek platformda çalışması sağlanabilir.
Buradan ise yapının görevinin, bütün .NET platformları için ortak bir API sunmak ve bunun devamlılığını sağlamak olduğunu söyleyebiliriz ve iki soru işaretimiz de böylece ortadan kalkmış olur.

Sonuç olarak ortaya .NET Standart çıkıyor.

.NET Standart sayesinde artık tek bir API kullanarak, .NET Standart API’ını implemente etmiş olan bütün .NET platformlarını destekleyebiliyoruz. Yakın zamanda 2.0 versiyonu çıkan .NET Standart tarafından desteklenen API setinin içerisinde Networking, IO ve Threading gibi önemli yapı taşları mevcut.

netstandard-apis

Bir süre sonra PCL’ler yerini .NET Standart’a bırakacak. Kişisel kanaatim, .NET Standart’ın çok daha iyi bir yaklaşım olduğu yönünde. Umarım yakın zamanda bir standarta daha ihtiyaç duymayız.

“The truth.” Dumbledore sighed. “It is a beautiful and terrible thing, and should therefore be treated with great caution.” ― J.K. Rowling, Harry Potter and the Sorcerer’s Stone

Bir sonraki yazıda görüşmek üzere.

Hangi Özellikler Aktif Edildiğinde Exchange Enterprise Client Access License (E-CAL) Kullanmak Gerekir

Bu yazımızda lisanslama konusunda sıklıkla soru işareti yaşanan, Exchange Server Enterprise CAL kullanımının gerekli olduğu durumlara açıklık getirmek istedik. Yazı içerisinde bu konulara ilişkin bilgiler verecek ve Enterprise CAL kullanımı konusunda lisans içerikleri ve kullanım yöntemlerini anlatmaya çalışacağız.

Exchange kurulumların da yanlış yapılan aksiyonlar sonucu on-premise kullanımlarda beklenmedik CAL & SERVER lisans maliyeti çıkmaktadır. Office 365 ile birlikte Office uygulamalarına yönelik ihtiyacınızı karşılarken aynı zamanda e-posta hizmetinizi de ek lisans maliyeti düşünmeden BT süreçlerinize çözüm sağlayabilirsiniz.

Exchange İstemci erişim lisansları (CAL) ile ilgili önemli bir noktaya değinmek isterim: Eğer Exchange Standard CAL özelliklerine sahip olmak istiyorsanız sadece Standard CAL almanız yeterli olacaktır. Ancak Exchange Enterprise CAL özelliklerine sahip olmak istiyorsanız hem Exchange Standard CAL hemde Enterprise CAL almanız gerekmektedir.

Aşağıdaki tabloda ve maddelerde Exchange Standart CAL ve Enterprise CAL kapsamında gelen özellikleri inceleyebilirsiniz:

 

Exchange Standard CAL

  • E-posta gönderip alma ve e-postaları kişisel bir posta kutusuna kaydetme, randevuları ve toplantıları planlama ve kişisel takvim oluşturma
  • E-posta ve fiziksel adresleri, telefon numaraları ve diğer kişisel bilgileri içeren bir rehber veritabanını saklama; görevleri zamanlama ve tamamlanma süreçlerini izleme
  • E-posta, takvim, kişiler ve görevler için tarayıcı tabanlı erişim (Outlook Web App üzerinden)
  • Exchange yazılımının kötü amaçlı yazılım ve spam filtreleme özellikleri, virüsleri, casus yazılımları ve istenmeyen iletileri posta yoluyla toplu halde siler.
  • Mobil aygıtın Exchange ActiveSync protokolü aracılığıyla Exchange’e erişmesini sağlayan ve verileri mobil aygıtlarla senkronize eden ve minimum mobil aygıt parolası uzunluğu gibi temel yönetim ilkelerini zorunlu kılacak şekilde temel mobil aygıt yönetimi
  • Bir grup posta kutusuna gönderilen ve bu posta kutularından gönderilen tüm iletileri arşivleyen temel günlük (bazen Günlük Veritabanı Günlüğü olarak da bilinir)
  • Varsayılan klasörlerde bulunan iletilerin ne kadar süre tutulacağı ve bir ileti alıkoyma yaşına ulaştığında sistemin ne yapması gerektiğini denetleyen temel saklama politikaları (bazen Varsayılan Saklama Politikaları olarak adlandırılır)
  • Önceki sürümlerin Çoklu Posta Kutusu Aramasını genişleten ve yetkili personelin (yasal ve uyum görevlileri gibi) e-posta, takvim, görev ve kişi öğelerinde organizasyon çapında arama yapmasını sağlayan yerinde eDiscovery.
  • Site posta kutuları, ekip üyelerinin tek bir kullanıcı arabirimi aracılığıyla bir SharePoint sitesinin belgelerine ve ilişkili e-posta iletilerine erişmesini sağlayan Exchange Server 2013’e yeni bir özellik (ve SharePoint 2013).

Exchange Enterprise CAL

  • Standard CAL tarafından sağlanan özelliklere ek olarak yasal zorunluluklara ve kamusal düzenlemelere uyma yeteneğini geliştirmek için aşağıdaki maddelerde yer alan ek özellikle Enterprise CAL ile beraber gelir. Böylece Exchange Server altyapısında daha kurumsal yetenekler aktif edilebilir.
  • Bir mobil telefonun bir PC için bir modem olarak kullanılmasını önleme gibi Exchange ActiveSync ile daha kapsamlı politika uygulanmasını sağlayan birinci sınıf mobil cihaz yönetimi
  • Günlük kaydı belirli kullanıcılara veya gruplara gönderilen e-postaya sınırlandırarak daha ayrıntılı denetimi ve dolayısıyla daha küçük dergileri sunan birinci sınıf günlük kaydı (bazen Kullanıcı Başına / Dağıtım Listesi Günlüğü olarak da bilinir)
  • Saklama ilkesinin varsayılan olmayan klasörler üzerinde (örneğin, kullanıcılar tarafından oluşturulan klasörler) ayarlanmasına ve kullanıcıların belirlediği saklama parametrelerinden önce gelen tek tek iletiler için bir saklama politikası belirlemesine izin veren, birincil Saklama politikaları (bazen Özel Saklama Politikaları). sistem yöneticisi
  • Sesli postaları metne çeviren (kullanıcılara arayan kişinin mesajının okunabilir bir önizlemesini verir) birleştirilmiş mesajlaşmaya sahip sesli posta, sesli posta ses ve metnini e-posta ve fakslar olarak aynı gelen kutusuna yerleştirir ve birleştirilmiş gelen kutusuna erişim sağlar Sesli komutları kullanarak standart bir telefondan
  • Exchange çevrimiçi koruması, kötü amaçlı yazılım ve spam gönderen e-postaları filtreleyen ve Exchange Enterprise CAL üzerinde Yazılım Güvencesi kapsamını koruyan kuruluşlara ek bir ücret ödemeyen ve Microsoft tarafından barındırılan bir hizmettir.
  • Yetkili personelin diğer tüm bilgi saklama politikalarını (süresiz veya belirli bir süre için) geçersiz kılmasını ve belirtilen posta kutularında önceden saklanan mesajların korunmasını ve bu posta kutularında önceden depolanmış iletilerin korunmasını sağlayan Yerinde Kayıt Olun (önceden Hukuk Mahfazası veya Dava Tutma adı verilir). sonraki tüm gelen ve giden iletiler korunur
  • Kuruluşlara, Outlook kişisel mağaza (PST) dosyalarının aksine yöneticiler tarafından güvenilir bir şekilde yedeklenebilen, kurumsal politika uyarınca korunan bir sunucu tabanlı e-posta arşivleme seçeneği sunan Yerinde Arşiv (önceden Kişisel Arşiv) adı verilen ve gerektiğinde arandı
  • Yöneticilerin kullanıcılara herhangi bir müdahalede bulunmadan iletileri ve ekleri koruyan kuralları tanımlamalarını sağlayan Otomatik İleti Koruması, Windows Rights Management Services’ı kullanıyor (korumalı iletileri gönderen veya alan her istemci de bir Windows Rights Management Services CAL’ıyla lisanslanmalıdır)
  • İleti içeriğini kişisel tanımlanabilir bilgiler gibi hassas bilgileri analiz eden ve iletileri filtrelemek veya sonuçları izlemek için ilkeler yapılandırmasına izin veren Veri Kaybını Önleme

    Sunucu tarafındaki lisanlama kapsamı için aşağıda güncel Exchange Server 2016 Lisanslamasını inceleyebilmeniz adına paylaşıyorum.

Exchange Server 2016 Lisanslaması

Sunucu lisansları

İki sunucu sürümü vardır

  • Standart: Küçük ve orta ölçekli kuruluşların posta kutusu ihtiyaçları için tasarlanmıştır. Ayrıca daha büyük bir Exchange dağıtımında posta kutusu olmayan roller için de uygundur. Bu sürüm 1’den 5’e kadar posta kutusu veritabanlarını destekler.
  • Kullanıcı Basına Exchange Standard Cal ile lisanslanmış olması gerekmektedir.
  • Enterprise: daha büyük sayıda posta kutusu veritabanları gerektirebilecek daha büyük kuruluşlar için tasarlanmıştır. Bu sürüm 1’den 100’e kadar posta kutusu veritabanını desteklemektedir.Enterprise CAL özelliklerini etkinleştirebilmek için kullanıcı başına Standard CAL’a ek olarak bir de Enterprise CAL ile alması gerekmektedir.


Exchange Server Standard & Enterprise özellikleri aşağıdaki gibidir
Sunucu ve Kullanıcı için Standart ya da Enterprise lisanslama yaklaşımı, tablolara ve maddelediğimiz listelerde yer alan özellikler göz önünde bulundurularak kurumsal ihtiyaçlara yönelik geliştirilmelidir.
Başka bir yazıda görüşmek dileğiyle.
 

Microsoft ile Data Science (Veri Bilimi)

Microsoft Professional Program bünyesinde takip ettiğim Data Science (Veri Bilimi) başlıklı edX kurslarına paralel olarak bu yazı dizisini kaleme alıyorum. Seri, genel olarak veri bilimine ilgi duyan; ancak daha önce bilgisi olmayanlara yönelik. Yazılarda değinilen teknolojiler içerisinde Spark, R ve Python gibi Microsoft dışı yöntemler bulunmasına rağmen, ağırlıklı olarak Microsoft teknolojileri ile data science uygulamaları anlatılmaktadır.

Bu yazı, bütün alt başlıklara ait yazıların indekslendiği bir ana giriş yazısıdır.

Ek bir not olarak SQL bildiğini varsayarak ilerliyorum; buna göre SQL konusunda eksiğin olduğunu düşünüyorsan önce bunu tamamlayıp ardından bu yazıları okumanı tavsiye ederim.

Data Science

Microsoft ile Data Science konusunu şu alt başlıklarla ele almak mümkün :

Data Science Giriş

Data Scientist rolüne sahip birinin ne iş yaptığını tanımlayarak başlıyoruz. Görsel, analitik ve istatistiksel tekniklerle veri ile nasıl çalışılır ve keşfedilir, bu konuları irdeliyoruz. Bu konuyla ilgili mevcut yazılar şunlar :

 

Veriyi Analiz Etmek ve Görselleştirmek
Excel ve Power BI ile farklı veri kaynaklarından nasıl data alınacağını ve birleştirileceğini, nasıl analiz yapılacağını, verilerin nasıl görselleştirileceğini, hazırlanan dashboard’ların iş kullanıcıları ile mobil ve web platformunda nasıl paylaşılacağını inceliyoruz.

 

İstatistik Bilimini Anlamak

Giriş seviyesinde istatistik ve olasılık öğreneceksin. Bunları veri analizi ve veri bilimi temelleri üzerine Excel kullanarak gerçekleştiriyoruz.

 

Kod ile Veriyi Keşfetmek : Veri Bilimi için R’a ve Python’a Giriş

Data Science profesyonellerinin tercihi olan istatistiksel programlama dili R dilini öğreneceksin. Söz dizimi temellerini, değişkenleri, basit işlemleri, veri yapılarının (vektörler, matrisler, veri çerçeveleri, listeler vb.) nasıl ele alınacağını keşfedeceksin.

Basit aritmetik işlemler, değişkenler ve veri yapıları olmak üzere Python’un temellerini öğreneceksin. Python fonksiyonları ile akış kontrollerini keşfedip, gerçek zamanlı veri ile kendi görsel raporlarını oluşturacaksın.

 

Temel Data Science Konseptlerini Anlamak

İstatistiksel analiz, veri temizliği ve dönüşümü, R ve Python ile verinin görselleştirilmesi ve Microsoft Azure Machine Learning dahil olmak üzere veri bilimi ile uğraşırken işine yarayacak önemli konsept ve teknikleri öğreneceksin.

 

Machine Learning’i Anlamak

Sınıflandırma, regresyon, kümeleme ve tahminleme gibi makine öğrenmesi modellerini nasıl geliştireceğini, ölçeceğini ve optimize edeceğini öğreneceksin.

 

Kod ile Veriyi İşlemek ve Modellemek : R ve Python ile Data Science için Programlama

R ile programlamayı biraz ilerletiyoruz. R veri yapılarını ve söz dizimlerini keşfederek lokal bir dosyadan ya da bulutta bir veri tabanından nasıl veri okuyup yazılacağını, veri ile nasıl çalışılacağını, nasıl özet veriler elde edileceğini ve ihtiyacına göre veriyi nasıl dönüştüreceğimizi öğreneceksin.

Verinin içinde saklı olan desenleri ortaya çıkarmak için efektif ve iyi bilinen madencilik modellerini uygulayacak şekilde Python’ı nasıl kullanacağını öğreneceksin. Veri görselleştirmesi, niteliklerin seçimi (feature selection), boyutların azaltılması, kümeleme, sınıflandırmayı keşfedeceksin.

 

Uygulamalı Makine Öğrenmesi

Metin analitiği, konumsal veri analizi, imaj işleme ve zaman serileri tahminlemesi gibi predictive (kestirimci) problemleri çözmek için makine öğrenmesini nasıl uygulayacağını öğreneceksin.

 

HDInsight içinde Spark ile Predictive (Kestirimci) Çözümler Uygulamak

Kestirimci analizler ve makine öğrenmesi çözümleri üretmek için Microsoft Azure HDInsight içinde Spark’ı nasıl kullanacağını öğreneceksin. Apache Spark ile Python, Scala, R kullanarak veriyi nasıl temizleyip dönüştüreceğini, makine öğrenmesi modellerini nasıl oluşturacağını ve gerçek zamanlı makine öğrenmesi çözümlerini nasıl hayata geçireceğini öğreneceksin.

 

Microsoft R Server ile Büyük Veriyi Analiz Etmek

En güçlü programlama dillerinden biri olan R kullanarak Microsoft R Server ile büyük veri setlerinin nasıl analiz edileceğini öğreneceksin.

PeakUp Blog içinde yer alan bütün Data Science kategorisindeki yazılara ulaşmak için bu linki kullanabilirsin.

Data Scientist (Veri Bilimci) Olmanın Keyifli Yanları Neler?

Data Scientist olma yoluna girmeden önce bu mesleğin keyifli yanlarına göz atalım. Microsoft Corp’da çalışan gerçek profesyonellerin görüşlerinden derlediğim bu liste sana ilham verecek :

 

Problem çözmenin verdiği haz
İş kullanıcılarından çok sayıda kompleks problem gelir. Bir şeyler tahmin etmenizi isterler, ellerindeki verilerin, işlerini nasıl geliştireceğini anlamak isterler.

 

Mevcut verinin iş süreçlerine gerçekten değer katmak için, nasıl oyunun içerisine sokulacağını çözmeye çalışmak
Veriyle oynamak, veriyi farklı formatlara sokmak her an seni şaşırtabilir.

 

Data Scientist olmanın en keyifli yanlarından biri de meydan okumaktır.
Verilerin hikayesini araştırırken, neredeyse araştırmacı gazeteci olmakla eşdeğer bir hissiyat oluşur. Yeni bir veri seti ile uğraşırken, bir sonraki adımda ne keşfedeceğini hiçbir zaman bilemezsin.

 

Ürünle ilgili yeni bir bilgi elde etmek için gerekli soruları çözmek ve puzzle’ın parçalarını birleştirerek ilerlemek.
Bazen hiç bitmeyecek bir puzzle’ı tamamlamaya çalıştığını düşünürsün. Görünürde anlamsız olan terabyte’larca veri üzerinde çalışırsın; ama daha derinlere indikçe verinin içinde çözüm için çok önemli etkiye sahip bazı desenler ve anlamlar bulursun. Eğer veriyi dikkatlice dinlersen veri konuşur, sana hikayeler anlatır.

 

Farklı geçmişe sahip insanlarla birlikte çalışmak.
Bir veri bilimci kimya, biyoloji, psikoloji,  ekonomi ya da finans geçmişine sahip olabilir. Bu kadar çeşitliliğe sahip farklı insanlarla, farklı sektörlere yönelik farklı problemleri çözmek için farklı fikirleri bir araya getirmek çok zevklidir.

 

Veri bilimci olmak için ekstra heyecanlı bir dönemden geçiyoruz.
Dünyada şimdiye kadar biriken bütün verilerin toplamı, artık her birkaç yılda 2 katına çıkıyor. Bu, altına girdiğin işin zorluğunu gösterirken; sonuç gördüğünde alacağın keyfi garanti ediyor.

 

Microsoft Professional Program bünyesinde takip ettiğim Data Science (Veri Bilimi) başlıklı edX kurslarına paralel olarak bu yazı dizisini kaleme alıyorum. Seri, genel olarak veri bilimine ilgi duyan; ancak daha önce bilgisi olmayanlara yönelik. Yazılarda değinilen teknolojiler içerisinde Spark, R ve Python gibi Microsoft dışı yöntemler bulunmasına rağmen, ağırlıklı olarak Microsoft teknolojileri ile data science uygulamaları anlatılmaktadır.

Diğer makaleleri bulabileceğin serinin indekslendiği giriş yazısına erişmek için bu linki kullanabilirsin.

Excel Veritabanı Fonksiyonları (Database Functions)

Bu yazımızda sizlerle Excel Veritabanı Fonksiyonları’na İngilizce ifadesiyle Database Functions uygulamalarına ilişkin örnekler üzerinde çalışma yapacağız.

Veritabanı fonksiyonları İleri Excel eğitimlerinin en önemli konularından biridir.

Microsoft’a göre veritabanı fonksiyonunun tanımı:

Listede veya veritabanında bulunan bir kayıt alanında (sütunda), belirttiğiniz koşulları karşılayan sayılar içeren hücreleri hesaplar.

Yukardaki tanımın anlaşılması biraz zor gibi ama veritabanı fonksiyonları aksine çok kolay bir fonksiyon yapısıdır. Veritabanı fonksiyonları Excel’in çok işlevsel fonksiyonları olmalarına rağmen çok bilinmeyen fonksiyonlardır. Sql mantığından yola çıkarak tablolar üzerinden formül ile istenilen değerlerin bulunması yarar. Mantıksal fonksiyonlar olan Etopla, Eğersay, Eğerortalama, Çoketopla, Çokeğerortalama, Çokeğersay gibi fonksiyonlar ile yapacağımız işlemleri çok daha pratik ve kısa formüller ile yapmamızı sağlar. Veritabanı fonksiyonlarında normal Excel tabloları veritabanı kabul edilir. Ayrıca ölçüt tablosu oluşturmamız gerekir. Bu konuyu bir örnek üzerinden anlattığımızda daha anlaşılır olacaktır.

Aşağıdaki gibi bir tablomuz var ve bu tablodan bir değer bulmak istiyoruz.

 

Bunun için sorumuz ise şöyle: Ali isimli satış temsilcilerinin 15 Ağustos 2009 tarihinden önce Adana’da yapmış oldukları Satış tutarının toplamı nedir?

Evet yukarıdaki soruyu görenlerin ilk aklına gelecek şeyler şunlardır;

  1. Veriyi filtrelerim sonra en son elimde kalan veriden toplamı bulurum.Bu şekilde bir çözüme gidebilirsiniz ama soruda birkaç değişiklik yaptığınızda hemen filtreleri tekrar düzenlemek zorunda kalacaksınız ki eğer o tablolar farklı işlemler için kullanılıyorsa tümden bir karmaşaya sebebiyet verir.
  2. ÇokEtopla kullanırım. En çok kullanılan çözümlerden biridir ama bu çözümde de performansta düşme söz konusu olacaktır. Ayrıca her ölçüt için formül içine 2 parametre daha girmek gerekir ve formüller uzar gider haliyle hata yapma ihtimali de çok yükselir.
  3. Veritabanı fonksiyonlarını kullanırım. En sağlıklı çözüm yöntemi veritabanı fonksiyonlarını kullanmaktır. DSum ya da Türkçesi ile VSeçTopla kullanırım diyebilirsiniz.

Avantajları:

Hızlıdır, Formüller diğerlerine göre çok kısadır, Hata yapma ihtimali çok azdır.

Dejavantajı: Ölçütlere girilen değerler tablodakiler ile bire bir aynı olmak zorundadır ki bu diğer durumlar için de geçerlidir.

Veritabanı fonksiyonların ayırt etmek de çok kolaydır. Bütün veritabanı fonksiyonları Türkçe’de VSeç kelimesi ile İngilizce de ise D karakteri ile başlar. Örneğin VSeçTopla fonksiyonu DSum fonksiyonudur gibi. Toplamda 12 tanedir. En çok kullanlanları ise DSum, DAvarage, DMax, DMin ve DCount fonksiyonlarıdır.

Aşağıdaki Excel’de bulunan Veritabanı fonksiyoları bulunmaktadır.

Fonksiyon Açıklama
DAVERAGE Belirtilen koşulları sağlayan bir listenin veya veritabanının alanındaki değerlerin ortalamasını hesaplar.
DCOUNT Belirtilen koşulları sağlayan bir listede veya veritabanında bir alanda sayı içeren hücre sayısını döndürür
DCOUNTA Belirli koşulları sağlayan bir liste veya veritabanının alanındaki boş olmayan hücrelerin sayısını döndürür
DGET Belirtilen koşulları sağlayan bir listenin veya veritabanının alanından tek bir değer döndürür
DMAX Belirtilen koşulları sağlayan bir listenin veya veritabanının alanındaki maksimum değeri döndürür
DMIN Belirli koşulları sağlayan bir liste veya veritabanının alanından minimum değeri döndürür
DPRODUCT Belirtilen koşulları sağlayan bir liste veya veritabanının alanındaki değerlerin çarpımını hesaplar.
DSTDEV Belirli koşulları sağlayan bir liste veya veritabanının alanındaki standart sapmayı (popülasyonun bir örneğini temel alarak hesaplar) hesaplar.
DSTDEVP Belirtilen koşulları sağlayan, bir liste veya veritabanının alanındaki standart sapmayı (tüm popülasyona dayalı olarak) hesaplar.
DSUM Belirtilen koşulları sağlayan bir liste veya veritabanındaki alanın toplam değerini hesaplar.
DVAR Belirli koşulları sağlayan, bir liste veya veritabanının alanındaki değerlerin varyansını (bir popülasyondan bir örneğe dayalı olarak) hesaplar.
DVARP Belirli koşulları sağlayan bir listedeki veya veritabanındaki bir alandaki (tüm popülasyona dayalı olarak) varyansı hesaplar.

Veritabanı fonksiyonlarını kullanırken söz dizimi aşağıdaki gibidir.

=VSEÇTOPLA(veritabanı, alan, ölçüt)

VSEÇTOPLA işlevinin söz diziminde aşağıdaki bağımsız değişkenler bulunur:

  • Veritabanı    Gereklidir. Listeyi veya veritabanını oluşturan hücre aralığıdır. Başlıkları ile beraber taratmak gerekir.
  • Alan    Gereklidir. İlgili hesaplama için hangi sütunun kullanıldığını belirtir. Örneğimizde bulmak istediğimiz sonuç “Satış Tutarı” toplamlarıdır. Başlığı çift tırnak içine yazmak yerine sütunun listedeki konumunu gösteren bir sayıda (tırnak işareti arasına almadan) girebilirsiniz. Örneğin: ilk sütun için 1, ikinci sütun için 2, vb.
  • Ölçüt    Gereklidir. Belirttiğiniz koşulları içeren bir hücre aralığıdır. Başlıkları ile beraber taratılmak zorundadır.

Tekrar gelelim sorumuza;

Ali isimli satış temsilcilerinin 15 Ağustos 2009 tarihinden önce Adana’da yapmış oldukları Bilgisayar Satış tutarının toplamı nedir?

Bu soru için öncelikle her bir alan kadar ölçüt çıkarmamız gerekiyor.

Soruda İsim, Tarih, Bölge ve Ürün bilgileri geçtiği için 4 ölçüt alanımız var.

Ölçütleri aşağıdaki gibi çıkarırken iki duruma dikkat etmemiz gerekiyor. Birincisi Ölçüt başlıklarının tablo başlıkları ile aynı olması gerekiyor, İkincisi ise yazdığımız değerlerin tabloda bulunan bir veri olması gerekiyor. Aksi durumda sonuç sıfır 0 (Sıfır) gelebilir.

 

İlk önce bu soruyu ÇOKETOPLA fonksiyonu ile çözelim:

Yukarıda görüldüğü üzere fonksiyon karmaşık ve uzun olduğu için sonra değiştirilmesi gerekirse dikkatli şekilde düzenlenmesi gerekiyor. Aksi durumda çalışmayabilir.

Şimdi de VSEÇTOPLA fonksiyonunu kullanacağız. 4 farklı parametre olmasına rağmen formül uzunluğu aşağıdaki görüntüden daha uzun olmaz.

 

Görüldüğü üzere bu fonksiyon yapılarında ölçütler tablosu taratıldığı için parametreleri fonksiyonlara tek tek girmek gerekmez buda bizim için az kod çok iş anlamına gelir.

Başaka bir yazı görüşmek üzere.

SharePoint Framework’de Çok Dilli Geliştirme

SharePoint Framework ile uygulama geliştirirken çok dilli bir yapıya ihtiyacımız varsa bunu Resource yapısını kullanarak çok basit bir şekilde yapabiliriz.

Sharepoint Online ile bu özelliği kullanmak çok kolay. Eğer WebPart içerisinde tanımladığınız diller, kullanıcının alternatif olarak seçtiği diğer diller içerisinde yer alıyorsa gerekli dilde gösterim otomatik olarak yapılıyor.

Öncelikle kullanıcımızın varsayılan dil seçeneğinin yanında kullanmak isteyeceği alternatif dili nasıl ayarlayabiliriz bu adımı tamamlayalım. Bunu en kolay şekilde yapabilmek için aşağıda yer alan linki tıkladıktan sonra gereken adımları takip etmeniz yeterli olacaktır. https://eur.delve.office.com

 

Ben İngilizce diliyle SharePoint kullandığım için örneği de Türkçe ve İngilizce dil seçenekleri üzerinden anlatacağım. Görüldüğü üzere dil seçenekleri ve diğer alanlarla ilgili olarak Privacy(Gizlilik) ayarları da yapmak mümkün görünüyor.Çok dilli portalların yanında, birden fazla ülkeden SharePoint kullanıcısına sahipseniz buradaki ayarları kullanarak belli standartları genel olarak tanımlayabilmeniz mümkün.

Bir önceki SharePoint Framework’e Giriş ve WebPart Geliştirmek
makalesini takip ederek baştan bir WebPart projesi için kurulum yapabilirsiniz. Bu kurulumu yaptığınızı varsayıyorum.

Microsoft’un en son çıkarttığı, kısa sürede çok sevilen IDE diğer adıyla editörü yani VS Code veya Visual Studio kullanarak uygulamalarınızda gerekli kodu çok kolay bir şekilde yazabilirsiniz. Ben hafifliği ve Cross Platform geliştirmenin mümkün olabilmesi için bu makalede şimdilik Visual Studio Code kullanacağım.

Command Prompt ile gerekli klasörün içerisindeyken “code .” komutuyla projeyi VS Code ile açalım.

 


Kırmızıyla işaretlediğim alandan da görebileceğiniz üzere ağırlıklı olarak çalışacağımız klasör “src” klasörü. Bunun yanında WebPart uygulamaları geliştirirken versiyon kontrol sistemi olarak Git’de kullanabiliriz. Gerekli dosyalar varsayılan olarak gelmektedir.

Makalemizin ana konusu olan çok dilli yaptığı Resource üzerinden sağlayabilmek için srcloc klasörüne bir göz atalım.

mystrings.d.ts dosyamız Resource mantığı içerisinde “Key” bilgilerinin tutulduğu dosyamız. Bu dosyayı çok dilli bir yapı kullanmıyorsanız bile şimdilik silmeminizi tavsiye ederim. Dosya içerisinde varsayılan olarak gelen 3 adet Property yani key bulunuyor. Bunun yanında ben ekstra olarak ApplicationTitle adında, string veri türünde bir Property/Key daha tanımladım.

Şimdi loc içerisinde tr-TR global Locale Standartını kullanarak bizim için gerekli dosyamızı oluşturalım. Burada kullanacağınız tire karakterinin, alttire yerine normal tire olması önemlidir. Dosya içeriğini aşağıda görebilirsiniz.

Artık dil dosyasıyla ilgili olarak tanımlamalarımız bitti. Hemen WebPart uygulaması üzerinde nasıl kullanacağımızı görelim.

Öncesinde bu dosyaların oluşturulması, intellisense desteği alabilmek ve css ile ilgili. Scss uzantılı dosyalardan gelen uyarılardan kurtulmak için “gulp build” komutunu çalıştırarak projemizi derleyelim.

Proje ile ilgili tüm geliştirmeyi yapacağımız HelloWorldWebPart.js dosyasını açalım. Burada HelloWorldWebPart isimi benim kurulum aşamasında verdiğim isim, elbette siz farklı bir isim vermişseniz farklı olacaktır.

Eğer C# veya Java gibi programlama dillerine hakimseniz dosyayı ilk açtığınızda TypeScript yapısı size çok tanıdık gelecektir.

15. satırda yer alan Render methodu tüm C#’daki Console uygulamalarında yer alan Main methodu gibi uygulamanın başladığı Entry Point olarak kabul edilebilir. Burada proje içerisindeki CSS’in dahi çok programatik bir şekilde kullanıldığını görmek mümkün. Oluşturduğumuz Resource dosyası içerisindeki anahtarlara ${strings.PropertyName } notasyonuyla ulaşmak ve bu aşamada intellisense desteği de alabilmek mümkün.

Uygulamamız en basit şekilde görüntülemek için hazır. “gulp serve” komutuyla uygulamayı çalıştıralım ve iki farklı kullanıcı tarafında hangi dillerin kullanıldığını görelim.

İki farklı Browser’da iki farklı hesaptan giriş yapıp Web Part uygulamasını bir sayfaya eklediğimde elde ettiğimiz sonuç aşağıdaki gibidir!

Makalenin kaynak koduna buraya tıklayarak PeakUp Github hesabından ulaşabilirsiniz.

Microsoft Connections ve Microsoft Listings: Çevrimiçi Asistanlarınızın Yardımıyla İşinizi Büyütün!

Office 365’i küçük ölçekli işletmeler için daha değerli ve verimli hale getirmek üzere, Microsoft’un Business Premium’a getirdiği üç önemli uygulama var:

  • Microsoft Connections: Kolay kullanımlı bir e-mail marketing ve pazarlama hizmeti sağlıyor.
  • Microsoft Listings: Yaptığınız işe dair bilgileri ve gelişmeleri, en popüler sitelerde kolayca ve hızlıca yayınlamanızı sağlayacak bir yol sunuyor.
  • Microsoft Invoicing: Profesyonel faturalar oluşturmanın ve ödeme süreçlerini hızlandırmanın yeni bir yöntemi olarak konumlandırılıyor.

Microsoft Invoicing, Türkiye pazarında yer almayacak, dolayısıyla onun üzerinde durmayacağız; ancak diğer iki ürünü inceleyeceğiz.

Microsoft Connections: Basit email marketing araçları ile satış süreçlerinizi destekleyin!

Email marketing, satışların artırılmasında kritik önem taşıyan bir süreçtir; ancak bu sürece başlamak ve onu yönetmek gerçekten zahmetli ve zor olabilir. Microsoft Connections sayesinde, önceden tasarlanmış bülten, duyuru, teklif ve referans şablonlarını kullanarak profesyonel görünümlü email marketing kampanyaları oluşturabilirsiniz ve daha da önemlisi, bunu gerçekten çok kolay bir şekilde yapabilirsiniz. Ek olarak, kullanıcıların ve müşterilerinizin, mailing listelerinize kolaylıkla abone olmalarını veya abonelikten çıkmalarını sağlayacak yöntemleri kullanabilirsiniz. Connections, yeni ve potansiyel müşterilerinize ulaşma, var olan müşterilerinizin memnuniyetini ve bağlılıklarını güçlendirme ve işinizi büyütme gibi konularda size yardımcı olacak, etkili bir uygulamadır.

Connections ile, mailing listeleriniz büyüdükçe, müşterilerinizi belirli özelliklerine göre, etkili ve net şekilde ayırıp gruplandırabilirsiniz. Performans grafikleri ve abonelerin aktivite güncellemeleri sayesinde, her kampanyanız için tıklamalar, yeni abonelikler, ödemeler, aboneliklerden çıkışlar gibi göstergeleri takip edebilir, böylelikle nelerin düzgün çalışıp yolunda gittiğini ve nelerin yolunda olmadığını görebilirsiniz.

Connections, Office 365 Business Premium (İş Ekstra) aboneliğine sahip kullanıcılar için, web’de ve iOS ile Android cihazlarda kullanılabilir durumdadır. Web’de Office 365 Business center panelinden, iOS veya Android cihazlarınızda ise Microsoft Connections mobil uygulaması ile erişebilirsiniz.

Connections, yakın gelecekte, tüm müşterilerin kullanımına açık bir Outlook eklentisi olarak da hayatımıza girecek.

Microsoft Listings: Firmanızın ve yaptığınız işin yeni müşterilerce keşfedilmesini sağlayın!

İşinizin ve faaliyetlerinizin çevrimiçi ortamda aktif ve takip edilebilir durumda olması, potansiyel müşteriler tarafından keşfedilebilmenin etkili bir yoludur. Bununla birlikte, çevrimiçi varlığınızı uygun şekilde düzenleyip geliştirmek, kritik sayılabilecek bilgileri güncel tutmak ve sitelerdeki performansları ayrı ayrı ölçümlemek, süreci karmaşıklaştırıp zaman alıcı bir hale getirebilir. Microsoft Listings, Facebook, Google, Bing ve Yelp gibi platformlarda, işinize ve firmanıza dair bilgileri yayınlamanız ve yönetmeniz için kolay ve ideal bir yöntem sunar.

Microsoft Listings, Office 365’i kullanmaya başlarken girdiğiniz şirket ve firma profili verilerinizi çekerek işe başlar. Bunun ardından, süreç dahilinde, Office 365 Business center panelinden ulaşacağınız Listings panonuzda iş profilinizi güncellediğinizde, bu değişiklikler, Facebook, Google ve Bing’e otomatik olarak yansır. Bu işlemleri gerçekleştirmek ve söz konusu platformlarda listelenelerek Listings’i yönetmek için, kullanıcınızın Office 365’te Genel Yönetici (Global Admin) rolüne sahip olması gerekir.

Listings, işinizle ve firmanızla ilgili yapılan derecelendirmeleri, değerlendirmeleri ve geri bildirimleri kolayca takip etmenizi sağlayacak bir web paneli de içerir. Tüm platformlardaki verileri tek seferde kontrol edebilir veya bunları ayrı ayrı gözlemleyip karşılaştırmayı da tercih edebilirsiniz.

Listings size, müşterilerinizin fikirlerini ve görüşlerini anlayıp çevrimiçi ortamdaki bilinirliğinizi güçlendirmeniz adına çok kolay ve etkili bir çözüm sunmuş olur.

Keyifli çalışmalar!

Azure NestedVM

Merhabalar, bu makale Azure’da NestedVM özelliğini test etmek için lab ortamı kuracağım. Azure’ da öncelikle sanal makine açmamız gerekiyor. NestedVM özelliğini kullanmak için birkaç dikkat etmemiz gereken bazı detaylar mevcuttur:

  • Açtığımız sanal makinenin boyutu (size) Dv3 serisi ve Ev3 serisi olmalıdır.
  • Açtığımız makinelerin bölgesine (region) dikkat etmemiz gerekiyor. Dv3 serisi ve Ev3 serisi makineler her bölgede (region) açılmamaktadır.
  • Dv3 ve Ev3 serisi makineler hangi bölgede açıldığını aşağıdaki makaleden bulabilirsiniz.
  • Makalenin içerisinde detaylı bilgi mevcut olucaktır.(https://azure.microsoft.com/en-us/regions/services/)

İlk olarak Azure’da bir sanal makine oluşturalım.

Sol alandan “Virtual Machine ” alanına tıklayalım. Ardından sol üst köşedeki “Add” butonuna tıklayalım.

Açılan ekrandan Azure’un bize sunduğu hazır image’lerin başlıklarını görüntülüyor olacağız. Biz Windows Server özellikli bir makine kuracağımız için “Windows Server”a tıkladıktan sonra sağda çıkan ekrandan kuracağımız sanal makinenin işletim sistemini seçiyor olacağız. Ben Windows Server 2016 Datacenter’ı seçerek devam edeceğim.

Resimde de göreceğiniz gibi kuracağımız sanal makineye bağlanacak olan kullanıcın adını, şifresini , Azure da görüntüleyeceğimiz adını, subscription’ını, Resource group’unu ve location’ını belirtiyor olacağız.

Ardından gelecek olan ekrandan makinenin boyutunu(size) belirteceğiz.

Makalenin ilk bölümünde de belirttiğim gibi seçmiş olduğumuz bölgeye göre sanal makine boyutlarını görüyor olacağız. Bize 3 adet önerilen makine boyutu sunacak. Eğer bizim kullanacak olduğumuz altyapı daha fazla kaynak harcayacaksa sağ üstte bulunan ” View All “a tıkladıktan sonra tüm boyutları görüyor olacağız.

Resimde de göreceğiniz gibi açılan ekranda ise makineyi bir sanal network’e dahil edebiliriz,oluşturduğumuz sanal network subnet ekleyebilir hatta network’ü 2 subnet’e ayırabiliriz. Makineye bir publıc ip ve network security group da ekleyebiliriz. Network security group’u ekleyerek makine üzerinde açılması ya da kapatılması gereken portları yönetiyor olacağız.

“Purchase(satın alma)” butonuna tıklayarak makinenin kurulumunu başlatmış olacağız.

Ardından Azure’da kurduğumuz makineye kullanıcı adı ve şifresi ile makineye uzaktan bağlantı gerçekleştirelim. NestedVM özelliğini kullanmak için Hyper-V rolünü konumlandırmamız gerekiyor. “Add Roles and Features”e tıklayalım.

Ardından kurmak istediğimiz Rolü ya da özelliği hangi makineye kurmak istediğimizi belirtip “Next” butonuna tıklayalım.

Ekleyeceğimiz olacağımız Hyper-V rolünü seçip “Next” tuşuna basalım.Ardından “Features” ekranına geldiğimizde bir özellik eklemeyeceğimizden dolayı “Next” diyelim.

“Virtual Switches” Alanına geldiğimizde bir network adaptör seçmemizi isteyecek. Biz seçmeden devam edeceğiz. Çünkü sanal içinde sanal oluşturacağımız için Hyper-V içerisindeki sanal makine ya da makineler internete çıkmayacak. Azure’ da oluşturduğumuz makinede “NAT” kuralı oluşturarak Hyper-V üzerinde olan makineleri internete çıkaracağız.

Hyper-V rolünün kurulumu tamamlandığında makineyi yeniden başlatmamız gerekecek.

“Virtual Switch Manager” alanına tıklayarak bir adet sanal switch oluşturalım. Sırasıyla;

  1. Sanal switch olarak “Internal”ı seçelim
  2. Create Virtual Switch’e tıkladıktan sonra ok tuşuna tıklayalım.

Oluşturmuş olduğum “Virtual Switch”i Azure’da açmış olduğum makinede de görüntülüyor olacağız.Azure da olan makinin network ayarlarına gelerek, eklemiş olduğumuz “Virtual Switch”in IPv4 ayarlarına girelim.

Sonrasında IPv4 ayarlarını konfigüre edelim. İstediğiniz bir network aralığından bir ip adresi tanımlayalım. Ben 192.168.0.0/24 network’ünü tercih ettim. IP adresini verdikten sonra Azure’daki makine de PowerShell’i Administrator olarak çalıştıralım.

Powershell üzerinden bir NAT kuralı yazalım. Internal IP adresi kısmına ise Azure’daki makinenin “Sanal Switch”ine verdiğimiz IP bloğunu yazalım.

New-NetNat
–Name
NVMNat
–InternalIPInterfaceAddressPrefix
192.168.0.0/24

Ardından Hyper-V ortamına dönüyoruz. Hyper-V de oluşturduğumuz makinelere oluşlturmuş olduğumuz Internal Swith’i tanımlıyorum. Sırasıyla;

  1. Sanal makineye sağ tıklayıp “Settings”
  2. Virtual Switch’den oluşturmuş olduğumuz Internal Switch’i seçelim.
  3. Ok tuşuna basarak ekranı kapatalım.

Hyper-V de oluşturduğumuz sanal makineye bağlanarak. Network ayarlarına gelelim sonrasında oluşturduğumuz NAT’ın network’ünden bir IP adresi verelim. Burada dikkat etmmiz gereken unsur Gateway olarak Azure’daki makinenin IP adresini Gateway olarak vermek olacaktır.

Yapmış olduğumuz işlemlerin ardından ,Hyper-V de olan sanal makine üzerinden internete çıkıyor ve kullanılıyor olacaktır.

GENERAL DATA PROTECTION REGULATION NEDİR, NELER GETİRMEKTEDİR?

General Data Protection Regulation (GDPR) bir süredir fazlasıyla kullanılan bir kalıp ve birçok kişi de konu üzerinde fikir beyanında bulunmakta. Tam olarak bu nedenle de GDPR’ ın ne olduğu ya da belki de ne olmadığıyla ilgili ciddi bir bilgi kirliliği mevcut. Bu nedenle de mümkün mertebe konu ile ilgili soru işaretlerine cevap vermeye çalışacağımız bir seri derlemenin sağlıklı olacağı kanaati ile seriye ilk olarak temel bilgilendirme notlarıyla başlamayı uygun gördük.

Yıllar süren tartışma, görüşme, düzenleme ve fikir teatisi sonunda Avrupa Parlamentosu nihayet 14 Nisan 2016 tarihinde gerçekleştirdiği oylama ile GDPR’ ı kabul etti. Parlamentonun onayını takiben GDPR çevirileri gerçekleştirilerek onay takibinden itibaren takribi bir aylık bir süre sonunda Resmî Gazete’ de (Official Journal) yayınlandı ve böylece resmi olarak kabul edilmiş oldu. Konu ile ilgili olanların bildiği ve hatta konu ile ilgili malumat sahibi olunan yegâne husus ise yürürlüğe girme tarihinden itibaren iki yıl içerisinde Avrupa Birliği ülkelerindeki GDPR’ a uymakla mükellef olanların, uyumluluk sürecini tamamlamış olmaları gerektiği. GDPR ile ilgili Resmî Gazete ilanında Parlamento, yeni veri korumasına ilişkin düzenlemesine yönelik gerekçelerini de paylaşmış ve gerçek kişilerin, kişisel verilerinin işlenmesi ile bağlantılı olarak korunması gerekliliğini temel bir hak olarak nitelendirmiş; düzenlemenin maksadının ekonomik birliğin özgürlükler ile güvenlik ve adalet alanlarında başarının, ekonomik ve sosyal gelişimin ve iç marketler bakımından ekonomilerin yaklaşımının ve bunun yanında gerçek kişilerin refahının sağlanmasına katkıda bulunması olduğunu belirtmiştir. 1

Resmî gazetede yayınlanmasını takip eden 20 günün sonunda yürürlüğe giren GDPR her ne kadar sıkça tartışılan ve belki de bir anlamda yepyeni bir düzenlemeymişçesine veri işleyen/işlemek yükümü ve/veya zorunluluğu bulunanları tedirgin etse de Avrupa Birliği’ nin konu üzerindeki ilk düzenlemesi esasen oldukça geriye dayanıyor. İlk olarak; 1950 tarihli Avrupa İnsan Hakları Sözleşmesi’ nin “Özel ve Aile Hayatına Saygı” kenar başlıklı 8. maddesinde “Herkes özel ve aile hayatına, konutuna ve yazışmasına saygı gösterilmesi hakkına sahiptir. Bu hakkın kullanılmasına bir kamu makamının müdahalesi, ancak müdahalenin yasayla öngörülmüş ve demokratik bir toplumda ulusal güvenlik, kamu güvenliği, ülkenin ekonomik refahı………….için gerekli bir tedbir olması durumunda söz konusu olabilir.” hükmü yer almaktadır.

1981 yılında yürürlük kazanmış olan Kişisel Verilerin Otomatik İşleme Tabi Tutulması Karşısında Bireylerin Korunmasına ilişkin 108 sayılı Konvansiyon (Convention 108 for the Protection of Individuals with Regard to Automatic Processing of Personal Data) veri koruması hususunda bağlayıcılık öngören ilk düzenleme olarak düşünülmektedir. Söz konusu Konvansiyon, hem Avrupa Birliği üyesi ülkeler bakımından hem de üye olmayan ülkeler bakımından katılıma açık olması esası ile gündeme gelmiş, Türkiye de verilerin korunması açısından Avrupa Birliği uyumluluk çalışmaları çerçevesinde 108 sayılı Konvansiyona yönelik çalışmalar gerçekleştirmiş ve son olarak 30.01.2016 tarihinde kabul edilen 6669 sayılı Kişisel Verilerin Otomatik Olarak İşleme Tabi Tutulması Karşısında Bireylerin Korunması Sözleşmesinin Onaylanmasının Uygun Bulunduğuna Dair Kanun ile 108 sayılı Konvansiyonu onaylamıştır. 2

108 sayılı Konvansiyonu takiben Avrupa Birliği nezdinde tam teşekküllü ilk düzenleme olarak yorumlanan ve 1995 yılında yürürlük kazanmış olan Kişisel Verilerin İşlenmesi ve Bu Tür Verilerin Serbest Dolaşımına Dair Bireylerin Korunmasına İlişkin 95/46/EC Direktifi (Directive 95/46/EC of the European Parliament and of the Council of 24 October 1995 on the Protection of Individuals with Regard to the Processing of Personal Data and on the Free Movement of Such Data)3 temelde Avrupa Birliği vatandaşlarının mahremiyetinin ve toplanan kişisel verilerinin korunmasına ilişkin bir düzenlemedir. Direktifin amacı birinci maddesinde yer aldığı biçimiyle “kişisel verilerin işlenmesi bakımından, bireylerin temel hak ve özgürlüklerinin korunması ve üye devletlerce verilen serbest dolaşımını engelleyecek düzenlemeler yapılmasının önüne geçilmesi” olarak belirlenmiştir.

95/46/EC yürürlük tarihi itibariyle tüm Avrupa Birliği üyesi ülkeler için geçerli olmakla beraber, her bir üye ülke bakımından kendi iç düzenlemelerini yapmalarına müsaade eden, belli ölçüde çerçeve bir düzenleme olarak düşünebilecek bir direktif iken GDPR; tüm 28 Avrupa Birliği ülkesi için aynı. Bu da demek oluyor ki; GDPR’ a uyum yükümü olan şirketler bakımın Avrupa Birliği içerisinde uymaları gereken tek bir standart söz konusu. Her ne kadar GDPR bakımından tek bir standart belirlenmiş olması ve bir üst uygulama standardı ile ülkeler bazında düzenlenmiş ayrıca bir uygulamaya uyumluluk yükümüne oranla daha pratik bir düzenleme olarak düşünülse de GDPR ile belirlenen standartlar oldukça yüksek ve birçok şirket bakımından uyumluluğun sağlanması ciddi bir yatırım anlamına geliyor.

Yukarıda bahsetmiş olduğumuz gibi GDPR’ a uyumluluk süresi olarak yürürlük tarihinden itibaren iki yıllık bir süre öngörülmüş durumda ve bu süre 25 Mayıs 2018 tarihi itibariyle sona erecek. Belirlenmiş olan işbu tarihe kadar ise Avrupa Birliği içinde, Avrupa Birliği vatandaşlarının verilerine erişim bakımından veri sorumlusu “controller” ve veri işleyen “processor” her bir şirket bakımından GDPR’ a uyum yükümünün yerine getirilmesi söz konusu. Bu iki terimin GDPR içerisindeki tanımı, 95/46/EC ile 95/46 direktifi göz önünde bulundurularak düzenlenmiş bulunan Kişisel Verilerin Korunması Kanunu “KVKK” tanımları ile temel noktalarda benzerlik göstermekle, veri işleyen bakımından herhangi bir veri kaybı durumunda kayda değer biçimde daha fazla hukuki sorumluluk yüklüyor olması gibi spesifik birtakım yükümlülükler öngörmüş bulunmakta. Veri sorumluları ise, veri işleyenin dahil olduğu durumlarda özellikle sözleşmelerinin GDPR uyumluluğunu sağlamak zorunda. Tüm bunların yanında uyumluluk yükümün doğması bakımından spesifik kriterler ise şöyle:

  • Bir Avrupa Birliği ülkesi içerisinde var olma,
  • Avrupa Birliği içerisinde bulunulmasa da Avrupa’ da yaşayan (European Resident) kişilerin kişisel verilerini işleme,
  • 250′ den fazla çalışanı olma,
  • 250′ den az çalışanı olmakla birlikte veri sahiplerinin hak ve özgürlüklerine etki eden veri işleme süreçlerinin bulunması ya da belli özel nitelikteki kişisel verileri içerme.

Kriterler temelde hemen tüm şirketleri kapsıyor olmakla, Pwc’ nin4 gerçekleştirdiği araştırmada Amerikan menşeili şirketlerin %92′ sinin GDPR’ ı verilerin korunması bakımından en öncelikli prosedür biçiminde yorumladığı tespiti yapılmıştır. Ovum raporuna5 göre; Amerika’ daki şirketlerin 2/3′ ü GDPR ile birlikte Avrupa’ daki stratejilerini değiştirmelerini gerekli kılacak. Yaklaşık %85′ lik bir kısmı ise GDPR’ ın Amerikan menşeili şirketleri Avrupalı rakipleri karşısında avantajsız bir konuma soktuğu görüşünde.

GDPR’ ın koruma alanı 95/46/EC direktifi ile 1998 tarihinde İngiltere’ de yürürlüğe girmiş olan Veri Koruması Kanunu’ nda (Data Protection Act “DPA”) olduğu gibi kişisel veri olmakla, GDPR’ ın tanımı çok daha detaylı ve IP adresi gibi online belirteçlerin de kişisel veri olarak kabul edilebilir olduğu hususunu açıkça dile getirmekte. Bu haliyle GDPR’ daki daha geniş kapsamlı tanım, sektörler arası veri işleme biçimleri göz önünde bulundurularak ve teknolojinin değişkenliği de hesaba katılarak kaleme alınmış gibi görünmekte. Regülasyon ile belirlenmiş olan spesifik kriterler çerçevesinde otomatik olarak işlenen veriler ile manuel olarak dosyalama sistemleri aracılığıyla işlenen kişisel veriler GDPR’ ın koruması altına girmekte. Bu düzenleme 95/46/EC ile DPA tarafından bakıldığında GDPR ile daha geniş bir kapsam anlamına geliyor.

KVKK ile birlikte özel nitelikli veri olarak tanımladığımız direktif ile ilgili düzenlemeler bakımından ise hassas kişisel veri (sensitive personal data) olarak betimlenmiş olan veri biçimi GDPR madde 96 ile kişisel verilerin özel kategorileri (special categories of personal data) olarak tanımlanmakta olup, tanım görece mülga düzenleme ile örtüşmekle beraber özel kategori olarak belirlenmiş bu veriler bakımından herhangi bir kişiyi özellikli olarak tanımlamaya yarayacak genetik ve biometrik veriler özellikle yer almakta.

GDPR ile detaylandırılmış bir diğer husus ise verilerin hukuka uygun işlenmesi. GDPR çatısı altında veri işlemenin hukuka uygun olabilmesi için uyumluluk yükümü olanların, kişisel veri işleme faaliyetlerine başlamadan önce çoğunlukla “işleme koşulları” olarak tanımlanan hukuka uygun bir temel belirlemeleri ve bu hukuka uygunluk temelini dokümante etmeleri gerekmekte. Hukuka uygunluk temeli oluşturma bakımından ise GDPR ile birlikte gelen değişikliklerden biri de verileri işlenen kişilerin haklarının belirlenen temele göre değişiklik gösterebilecek olması. Örneğin, bir uyum yükümü altındaki bir şirketin veri toplama temeli veri işlenen kişi/lerin rızasına dayanmakta ise, başka bir deyişle kişilerin rızası hukuka uygunluk temeli olarak belirlenmişse; bu noktada verisi işlenen kişinin veri işleyene karşı kullanabileceği daha güçlü haklara sahip olacağı; söz gelimi verilerinin silinmesini talep edebileceğini söylemek mümkün.

GDPR ile uyum yükümü altındakilerin belirlemesi ve dokümante etmesi gerekli görülen hukuka uygun işleme koşulları GDPR madde 67 ile düzenlenmiş bulunmakta. Bu koşullar ise özet olarak şu şekilde belirlenmiş bulunmakta:

  • 6(1)(a) Veri sahibinin rızası
  • 6(1)(b) Veri sahibi ile imza edilmiş bir sözleşmenin uygulanabilmesi veya sözleşmenin yürürlüğe girebilmesi bakımından veri işlemenin gerekli olması
  • 6(1)(c) Hukuki bir yükümlülüğe uyumluluk bakımından işlemenin gerekli olması
  • 6(1)(d) Veri işlemenin veri sahibinin yahut bir başka kişinin yaşamsal faaliyetleri bakımından gerekli olması
  • 6(1)(e) Kamu yararının sağlanması üzere gerçekleştirilen işlemler yahut veri sorumlusuna verilmiş kanuni bir yetkinin yerine getirilebilmesi bakımından veri işlemenin gerekli olması
  • 6(1)(f)8 Veri sorumlusunun haklarını, özgürlüğünü kısıtlamamak kaydıyla; veri sorumlusu yahut üçüncü kişi tarafından hukuki bir yararın sağlanması bakımından veri işlemenin gerekli olması

Veri işleme ile ilgili hukuka uygunluk temelinin belirlenmesi ve dokümante edilmesi yanında GDPR’ ın temellendirdiği ve 95/46/EC ile DPA göz önünde bulundurulduğunda detaylandırdığı konu başlıklarından biri de veri sahibinin rızası. Buna göre; GDPR’ a dayalı olarak verilen rıza veri sahibinin özgür iradesiyle, spesifik, bilgilendirilmiş ve kişinin isteklerinin belirsiz olmadığı bir biçime sahip olacaktır. Rızanın varlığından bahsedebilmek için onaylayıcı bir aksiyon yahut bir başka deyişle olumlu bir onay söz konusu; rızanın veri sahibinin sessiz kalması, hali hazırda tiklenmiş kutucuklar yahut veri sahibinin hareketsiz kalması onay olarak varsayılmayacağı belirlenmiştir. Ayrıca rıza uyumluluğa dair diğer hüküm ve koşullardan ayrı yer almalı ve veri sahibinin rızasını geri çekebilmesi için kullanıcı odaklı, basit yöntemler sunulmalıdır. Rızanın veri sahibinin özgür iradesi ile sağlanmış olduğuna ilişkin kamu makamları ile personellerin özel bir yükümlülüğü bulunmaktadır.

GDPR ile düzenlenen başka bir husus ise çocukların kişisel verileri. GDPR çatısı altında bu yönde bir düzenlemeye gidiliyor olmasının temel nedeni ise çocuklara ait kişisel verilerin korumasının artırılması. GDPR ile çocuklara yönelik verilerin işlenmesi ve çocuğun veri işlemesine ilişkin rızasının direkt çocuk nezdinde konu edilebilmesi bakımından öngörülen yaş alt sınırı 16 olarak belirlenmiş. 16 yaşın altındaki çocukların verilerinin işlenebilmesi bakımından başvurulacak merci ise kesin olarak çocuğun ebeveyn yükümlülüklerini üstlenenlere “holder of parental responsibility” özgülenmiş bulunmakta. Çocukların verisinin düzenlenmesinde yaş sınırının altında kalanlar bakımından başvurulacak mercii olarak yalnızca çocukların ebeveynleri değil aynı zamanda hukuki koruma sağlayanlar da düşünülmüş olduğundan, bu maddenin mevcut düzenlemeler göz önünde bulundurulduğunda çok daha geniş bir merci düzenlemesi sağlamış olduğunu söylemek mümkün. Çocukların verilerinin işlenmesine ilişkin düzenlenmiş işbu madde9 çerçeve bir düzenleme olarak düşünülmüş ve üye devletlerin kendi düzenlemelerine müsaade edilmiş. Ancak GDPR ile bu düzenleyici madde ile yine de bir alt sınır belirlenmiş ve verileri işlenecek çocuklar bakımından en az 13 yaş kuralı öngörülmüş bulunmakta. Bir başka deyişle verileri işlenecek çocuklar bakımından çocuğun rızasının alınabileceği yaş, üye devletlerin düzenlemeleri çerçevesinde en az 13 olabilecek. Bu sınırın altındaki çocuklar bakımından yine ebeveyn rıza beyanında bulunabilecektir. Uyum yükümlüsü olanlar bakımından yaş koşulu yanında bir de gizlilik bildiriminin çocukların anlayabilecekleri bir dille yazılması gerekliliği söz konusu. Yaş sınırı ile ilgili aktarılabilecek son bilgi ise ebeveyn/koruyucu rızasının aranmadığı durumlar ile ilgili. Bu haller ise GDPR kapsamında direkt olarak çocuğa yönelen önleyici yahut danışmanlık servisleri.

GDPR düzenlemeleri içerisindeki belki de en kayda değer yenilik -Avrupa Birliği üyesi ülkelerin her biri bakımından uygulanması gerekliliği göz önünde bulundurulduğunda- hesap verilebilirlik hükmüdür. Bu maddeye yakınsanabilecek yegâne düzenleme İngiltere’ nin konuya ilişkin düzenlemesi olan DPA ve buna bağlı kurulmuş ve çeşitli düzenlemeler getirmiş olan bilgi komisyonu ofisi (Information Commissioner’s Office) “ICO” olarak düşünülebilir olsa da GDPR, uyum yükümü altında olanların kanun hükümlerine uyumluluğun nasıl sağlandığının gösterilebilir olmasını örneğin; işleme faaliyetlerine ilişkin uyum yükümü altında olanların aldıkları kararların dokümante edilmesini öngörmekte.

Hesap verilebilirlik ile ilgili hüküm GDPR madde 5(2) ile düzenlenmiş olup, uyum yükümü altında olanların kanun hükümlerine uyumunu ve bu uyum yükümü sorumluluğun sarih biçimde yüküm altında olanlara ait olduğunu ifade etmektedir. Bu madde bakımından yüküm altında olanların uygun ölçüde teknik ve organizasyonel önlemler alarak uyumluluğun sağlanması ile ilgili tabir-i caizse bir garantör element oluşturmaları gerekliliği söz konusu. Gereklilik söz konusu olduğunda bir veri koruma yetkilisi atanması, dizayn olarak ve kendiliğinden veri koruması olarak ifade edilebilecek GDPR hükümlerine uyum için gerekli önlemlerin alınması, kişilerin veri işleme süreçlerini monitör edebilmelerinin sağlanması gibi koşullar ile de hesap verilebilirlik hükmü bakımından temel gerekliliklerin sağlanabilmesi öngörülmekte.

GDPR’ ın getirdiği yeniliklerden ve belki anahtar hükümlerden -üstünkörü de olsa- bahsetmişken, uyumu yükümü altında olanların en büyük çekincelerinden olan uyum yükümünün sağlanamaması/yerine getirilememesi halinde söz konusu olabilecek “ceza” tutarlarından da bahsetmek gerekecek. Belirlenen süre (25 Mayıs 2018) sonunda uyum yükümü altında olan şirketlerin uyumluluk hükümlerine uygun faaliyetleri gerçekleştirmemiş olması halinde, GDPR 20.000.000,00- Euro’ ya kadar ya da global yıllık cirosunun %4′ üne kadar cezayı -hangisi daha yüksekse onun uygulanması üzere- öngörüyor. Ovum raporuna10 göre uyum yükümü altında olan şirketlerin %52′ si uyumluluğu sağlayamadığından, bahsi geçen cezaların aleyhlerinde uygulanacak olduğunu düşünüyor. Söz konusu cezalara yönelik olarak öngörüler ise Avrupa Birliği’ nin ilk yıl sonunda 6.000.000.000,00- Euro’ ya kadar ceza uygulayacak olduğu. Bu konu ile ilgili olarak ICO ise şunu söylüyor; “GDPR cezalar ilgili değil, tüketici ve vatandaşları ilk sıraya koymakla ilgili. Cezai şart üst sınırının yükseldiği ve bu durumun şirketleri korkuttuğu doğru olsa da ICO; şirketlere kanuna uyumlulukla ilgili olarak yol gösterici olmaya, tavsiye ve eğitim veren misyonuna GDPR altında da devam edecektir. Geçtiğimiz dönem içerisinde (2016-2017) 17.300 talebi karara bağladık ve ilintili şirketlerden yalnızca 16 adedi cezaya hükmedildi.”11 Bu konu ile ilgili olarak Avrupa Birliği ülkeleri nazarında bir değerlendirme yapıldığında da ICO’ nun GDPR dönemine kadar benimsemiş olduğu yukarıda bahsedilen ilkeden sapmadıkları görülmekte. Dolayısıyla uyum yükümü altında olanların endişelenmesi her ne kadar haklı görülebilir olsa da minör ihlaller ile bunlara bağlı cezai yükümlerin uygulanmasının hiçbir zaman bir norm haline gelmediği ve GDPR sonrasında da bu politikadan sapılmayacağını söylemek yanlış bir değerlendirme olmayacaktır.

ICO’ dan bahsetmişken, İngiltere’ nin Brexit sonrası veri koruması ile ilgili tam olarak ne yönde ilerleyeceği belirsizliği de ortadan kaldırılmış gibi görünüyor. İngiltere’ nin Avrupa Birliği’ nden ayrılmasını takiben, diğer Avrupa Birliği üyesi olmayıp da Avrupa Birliği vatandaşlarının verilerini işleyenler gibi değerlendirilecek olduğuna şüphe yok. Hali hazırda bu konuda -GDPR- ICO gerekli çalışmaları başlatmış olup, uyum yükümü altında olanlara GDPR’ a uyumluluk ile ilgili birifinglerde bulunmaya başlamış olduğundan, Brexit’ in yürürlük tarihine kadar İngiltere menşeili şirketlerin GDPR uyumluluklarını yerine getirmek çabasında olacaklarını söylemek yanlış olmaz.12

Bir yandan GDPR’ ın öngördüğü cezalar uyum yükümü altında olanları ürkütmekte iken, diğer yandan 25 Mayıs 2018 tarihine kadar gerçekleştirilecek uyumluluk çalışmaları da ciddi bir bütçeyi öngörmekte. PwC’ nin gerçekleştirmiş olduğu bir araştırmaya göre, Amerikan menşeili şirketlerin %68′ i GDPR gerekliliklerini sağlayabilmek adına 1.000.000,00 ila 10.000.000,00-$ arasında bir harcama gerçekleştirmeleri gerektiğini öngörürken, %9′ luk bir kısım da 10.000.000,00- $’ ı aşacak oranda bir harcama gerekeceğini öngörmekte.

Temel olarak GDPR düzenlemeleri ele alındığında global bağlamda ve veri işleyenler özelinde ciddi değişiklikler yaşanacağının ve bu değişikliklerle birlikte, veri işleme faaliyetlerinde hali hazırda Anayasal bir hak olarak görülen kişilerin özel hayatının gizliliği hususlarının çok daha sık duyulacak olduğuna şüphe yok. GDPR uyum yükümü altında olanlar bakımından hem pahalı hem de cezai şart bakımından ürkütücü görünse de veri işleme bakımından devrim niteliğinde bir düzenleme olduğunu düşünen bir çevre de mevcut. GDPR’ ın şirketlerin veri stratejileri, big data ve veri temelinde ilerleyen inovasyonlar bakımından ve bu başlıkların önümüzdeki dönemlerde çok daha fazla zikredilecek olmasına dayalı olarak düzenlenmiş olduğunu ve önleyici hukuk düzleminde bir düzenleme olarak düşünülmüş olduğunu söylemek yanlış olmayacaktır.

Yukarıda özet olarak belirtilmiş olan veri korumasına ilişkin regülasyon ve düzenlemeler çerçevesinde GDPR’ ın temel çerçevesine ve veri işlemesi hususları bakımından yenilik olarak nitelendirilebilecek hükümlerine yönelik bir inceleme gerçekleştirmiş olsak da GDPR hükümlerinin her birine ve buna bağlı uygulamalar ile ilgili olarak devam ettirecek olduğumuz seri ile bu yazıda ele alınmayan konular, bahsedilmiş olsa dahi detaylandırılmamış olan düzenlemelere dayalı bilgilendirmeler devam eden yazılarda paylaşılacaktır.

[1] Official Journal of the European Union, L119/1, 04.05.2016

[2]http://www.resmigazete.gov.tr/main.aspxhome=http://www.resmigazete.gov.tr/eskiler/2016/02/20160218.htm&main=http://www.resmigazete.gov.tr/eskiler/2016/02/20160218.htm

[3] http://eur-lex.europa.eu/legal-content/en/TXT/?uri=CELEX%3A31995L0046

[4] http://www.pwc.com/us/en/increasing-it-effectiveness/publications/assets/pwc-gdpr-series-pulse-survey.pdf

[5] https://www.intralinks.com/resources/analyst-reports/ovum-report-data-privacy-laws-cutting-red-tape

[6] https://gdpr-info.eu/art-9-gdpr/

[7] https://gdpr-info.eu/art-6-gdpr/

[8] Bu madde ile belirlenmiş olan koşullardan (f) fıkrası, kamu kuruluşlarının görevleri esnasında işleyecekleri veriler bakımından geçerlilik arz etmemektedir.

[9] https://gdpr-info.eu/art-8-gdpr/

[10] https://www.intralinks.com/resources/analyst-reports/ovum-report-data-privacy-laws-cutting-red-tape

[11] https://iconewsblog.org.uk/2017/08/09/gdpr-sorting-the-fact-from-the-fiction/

[12] http://www.cio.co.uk/opinion/legal-briefing/brexit-law-what-cios-need-know-about-eu-gdpr-it-contracts-3642872/