WHAT'S NEW?
Loading...
Tutorial Cara Install Arch Linux

Pada artikel kali ini saya akan mengulas mengenai salah satu Linux favorite yaitu Arch Linux. Umumnya saat menggunakan Arch Linux, proses installasi yang ditawarkan berupa text mode, sehingga menyusahkan user yang belum familiar. Jadi saya akan berikan cara install Arch Linux yang menggunakan text mode didalam virtualbox, tetapi cara ini juga bisa digunakan pada installasi langsung pada perangkat komputer.

Terlebih dahulu silakan download versi terbaru melalui link official ini, jika sudah silakan masuk ke proses installasi (saya asumsikan sudah bisa menggunakan virtualbox ataupun sudah masuk mode install perangkat komputer).

Setup Partisi

# lsblk

# fdisk /dev/sda  (bisa juga sdb atau yang lainnya tergantung dari hasil lsblk)
n (to add a new partition)
p (for primary partition)
1 (default partition number)
(accept default start)
(accept default end)
t (to change partition type)
8e (for LVM partition when using MBR)
i (to verify)
w (save and quit)

Perintah diatas adalah untuk melihat partisi yang tersedia semisal /dev/sda1 (setiap perangkat mungkin akan berbeda), disini saya akan menggunakan LVM dengan jumlah partisi kosong yang disediakan yaitu 30GB.
# pvcreate /dev/sda1

# vgcreate vg_arch /dev/sda1

# lvcreate -L 200M -n boot vg_arch
# lvcreate -L 20G -n root vg_arch
# lvcreate -L 4G -n swap vg_arch
# lvcreate -l 100%FREE -n home vg_arch

Proses partisi diatas menghasilkan:

  • Volume group dengan nama vg_arch
  • partisi /boot = 200MB
  • partisi /root = 20GB
  • partisi /swap = 4GB
  • partisi /home = sisa storage yang ada setelah pembagian partisi diatas
Dari hasil partisi diatas, kita anggap telah sesuai dengan jumlah partisi yang diinginkan, langkah selanjutnya adalah memberikan tipe partisi yang akan digunakan, dicontohkan tipe ext4 ataupun bisa menggunakan tipe yang lain sesuai yang diinginkan.
# mkfs.ext4 /dev/vg_arch/boot
# mkfs.ext4 /dev/vg_arch/root
# mkfs.ext4 /dev/vg_arch/home
# mkswap /dev/vg_arch/swap
# swapon /dev/vg_arch/swap

Setelah memberikan tipe partisi, selanjut kita perlu untuk melakukan proses mounting partisi tersebut sebelum melakukan proses installasi.
# mount /dev/vg_arch/root /mnt
# mkdir /mnt/boot
# mount /dev/vg_arch/boot /mnt/boot
# mkdir /mnt/home
# mount /dev/vg_arch/home /mnt/home

Pada tahap ini kita sudah siap untuk melakukan installasi, cukup dengan perintah berikut kita akan menginstall base system, dan setelahnya membuat isi file fstab.
# pacstrap /mnt base base-devel

# genfstab -U /mnt >> /mnt/etc/fstab

Kita telah berhasil menginstall Arch Linux, tetapi masih ada beberapa hal yang perlu dilakukan yaitu menginstall grub dan membuat hostname serta setting waktu, berikut ini perintah yang diperlukan.
# arch-chroot /mnt /bin/bash

# locale-gen

# vi /etc/locale.conf
.. LANG=en_US.UTF-8  (isikan language yang diinginkan)

# tzselect
# rm /etc/localtime
# ln -s /usr/share/zoneinfo/Asia/Jakarta /etc/localtime

# hwclock --systohc --utc

# vi /etc/mkinitcpio.conf
.. HOOKS="...lvm2 filesystems..." (tambahkan lvm2 pada HOOKS)

# mkinitcpio -p linux

# pacman -S grub

# grub-install --target=i386-pc /dev/sda
# grub-mkconfig -o /boot/grub/grub.cfg

# vi /etc/hostname
.. nama_hostname_yg_diinginkan

Pada saat proses grub-install mungkin akan ketemu peringatan semacam WARNING: Failed to connect to lvmetad. Falling back to internal scanning yang biasa terjadi dalam proses installasi, kadang sering ditemukan saat proses install dalam virtualbox, langkah yang perlu dilakukan sebagai berikut:
# exit
# mkdir /mnt/hostrun
# mount --bind /run /mnt/hostrun
# arch-chroot /mnt /bin/bash
# mkdir /run/lvm
# mount --bind /hostrun/lvm /run/lvm

Setelah itu lakukan lagi perintah grub-install & grub-mkconfig seharusnya warning diatas sudah hilang. Kemudian setelah proses install grub selesai lakukan perintah umount /run/lvm.

Semua proses installasi telah selesai, tahap terakhir yaitu membuat root password dengan perintah yang sederhana, cukup ketikkan "passwd" (tanpa tanda kutip) lalu masukkan root password yang anda inginkan.

Dengan demikian semua proses sudah selesai, kita dapat merestart terlebih dahulu dengan cara berikut:
# passwd (masukkan password root)
# exit
# umount -R /mnt
# reboot

Setelah restart kita sudah bisa login menggunakan user root, tentunya belum ada display manager dan desktop environment yang tersedia, saya akan lanjut ke artikel selanjutnya untuk menginstall GUI pada Arch Linux. Silakan isi kolom komentar dibawah jika ada yang ingin ditanyakan.
[Google Play Store Deal] - Download Premium Android Icon Pack - Part I

Icon menjadi salah satu daya tarik bagi pengguna Android, terdapat banyak sekali icon pack yang dapat didownload secara gratis maupun berbayar. Dan umumnya lebih banyak icon pack yang menarik namun berbayar, kali ini saya akan membagi beberapa icon pack premium yang dapat di download secara gratis dalam beberapa hari dari sekarang, berikut ini diantaranya:

Lanting

[Google Play Store Deal] - Download Premium Android Icon Pack - Part I

Memiliki lebih dari 2.500 custom icon dan 90+ wallpaper yang dapat di download. Untuk mendownload dapat langsung klik link berikut: Download Lanting Icon Pack from Play Store.

Six

[Google Play Store Deal] - Download Premium Android Icon Pack - Part I

Memiliki lebih dari 980 custom icon dan mendukung lebih dari 30 launcher, yang menariknya icon ini terasa seperti icon miliki Nokia. Untuk mendownload dapat langsung klik link berikut: Download Six Icon Pack from Play Store.

S8 UX Amaze

[Google Play Store Deal] - Download Premium Android Icon Pack - Part I

Icon yang satu ini merupakan icon yang sama pada Samsung Galaxy S8 dan Samsung Galaxy Note 8. Jika ingin merasakan sensasi dari icon perangkat high-end, dapat langsung klik link berikut: Download S8 UX Amaze Icon Pack from Play Store.

Aspire UX S8

[Google Play Store Deal] - Download Premium Android Icon Pack - Part I

Aspire juga merupakan icon yang digunakan pada Samsung Galaxy S8 (beta). Jadi silakan langsung mencobanya dengan mendownload melalui link berikut: Download Aspire UX S8 Icon Pack from Play Store.

Nougat Square

[Google Play Store Deal] - Download Premium Android Icon Pack - Part I

Menyediakan lebih dari 1000 icon flat desain vector dengan update regular setiap minggunya dan tentunya dapat digunakan pada berbagai jenis launcher. Silakan langsung mendownload melalui link berikut: Download Nougat Square Icon Pack from Play Store.

Silakan download semua icon pack premium diatas secara Gratis, perlu diketahui icon tersebut tersedia secara gratis hanya dalam beberapa jam dan hari kedepan, jadi pastikan segera download agar tidak kehabisan waktu.


Image credit: Google Play Store, Freepik.
Google Resmi Rilis Android 8.0 Oreo
bgr
Google baru saja merilis Android versi baru yaitu Android 8.0 dengan codename Oreo. Cukup banyak perubahan dan tentunya dengan tambahan fitur baru dan salah satunya cukup menarik perhatian yaitu fitur Rescue Party.

Bootlooping, istilah ini bisa dikatakan tidak begitu asing bagi beberapa orang, karena memang kerap kali terjadi pada perangkat Android. Umumnya memang sering terjadi jika kita melakukan kesalahan saat proses modifikasi, tapi juga sering terjadi pada pengguna biasa yang tidak melakukan modifikasi apapun. Bootloop dapat membuat frustasi karena pengguna tidak dapat menggunakan smartphone mereka akibat proses startup yang berhenti, dan cara penanganannya pun juga cukup sulit.

Oleh karena itu, Google mengenalkan fitur Rescue Party pada Android 8.0 Oreo. Dengan jelas diberikan informasi bahwa Android 8.0 sudah menyediakan 'rescue party' yang akan mengetahui jika komponen core system mengalami crash loop. Rescue Party kemudian dengan segera melakukan serangkaian tindakan untuk melakukan pemulihan pada perangkat, lalu setelah itu Rescue Party akan melakukan reboot ke mode recovery dan meminta pengguna untuk melakukan factory reset.

Fitur ini secara default aktif dalam Android 8.0 Oreo, dan tidak ada kebutuhan hardware khusus untuk mengaktifkannya alias bisa digunakan pada semua device. Beberapa jenis device memang ada yang mengalami bootloop yang terkait oleh software maupun hardware, tetapi dengan adanya fitur ini setidaknya dapat menghilangkan masalah tersebut pada perangkat yang memiliki kesalahan pada hardware sehingga mengakibatkan bootloop.

Source: Google.
Mengenal Dasar Teknologi RESTful Web Service

Saat ini, topik seperti cloud computing, serverless, stateless dan teknologi sumber data mutakhir lainnya sebagai penyalur data perangkat seluler seperti RESTful web service yang banyak digunakan sebagai penyalur data telah meninggalkan kesan bahwa REST (Representational State Transfer) merupakan teknologi baru, tapi faktanya REST ditemukan pada akhir abad ke 20.

Pada artikel ini saya akan menjelaskan sejarah singkat tentang REST (berdasarkan buku) dan mengulas sedikit bagaimana REST bekerja dalam protokol HTTP. Ada beberapa dasar acuan yang perlu diperhatikan ketika ingin mengubah sebuah aplikasi HTTP menjadi aplikasi RESTful service.

Di tahun 1999, ketika sebuah komentar definisi diajukan ke Internet Engineering Task Force (IETF: http://www.ietf.org) melalui RFC 2616: "Hypertext Transfer Protocol - HTTP/1.1." salah satu penulisnya, Roy Fielding yang mendefinisikan sebuah prinsip yang dibangun berdasarkan standar lingkungan HTTP dan URI yang kemudian melahirkan REST yang dikenal sekarang (disertasi lengkap mengenai informasi REST yang dibuat oleh Roy Fielding dapat dilihat melalui link publikasi berikut: http://www.ics.uci.edu/~fielding/pubs/dissertation/rest_arch_style.htm).

Seperti keterangan diatas, prinsip yang dibuat berdasarkan standar linkungan HTTP dan URI. Mari kita lihat dasar utama seputar standar HTTP dan URI, tetap berkaitan dengan cara mengubah sebuah aplikasi HTTP menjadi aplikasi RESTful service.

- resource adalah segalanya

Untuk memahami prinsip ini, kita harus memahami gagasan dari represenstasi adalah dengan format tertentu dan bukan berdasarkan file. Setiap data yang tersedia di internet memiliki sebuah format yang dapat dideskripsikan dengan content-type. Misalnya, text document; JPEG Images; MPEG videos; xml, html, text document; dan binary data yang semuanya adalah resource dengan jenis content-type berikut: image/jpeg, video/mpeg, text/html, text/xml, application/json dan application/octet-stream.

- setiap resource dapat diidentifikasi oleh unique identifier

Karena internet mengandung banyak resource berbeda, semua resource itu harus bisa diakses melalui URI dan harus diidentifikasi secara unik. Selanjutnya, URI bisa dalam format yang mudah dibaca manusia (sebagian orang memang mewajibkannya) terlepas dari kenyataan bahwa penggunanya adalah programmer dan bukan manusia pada umumnya (bukan berprofesi sebagai programmer).

URI menyimpan data secara self-descriptive dan memudahkan pengembangan lebih lanjut. Selain itu, menggunakan URI yang dapat dibaca manusia dapat membantu mengurasi resiko kesalah logis dalam program seminimalis mungkin. Berikut ini beberapa contoh URI:
- http://www.example.com/images/party/2017/newyear

- http://www.example.com/videos/party/2017/newyear

- http://www.example.com/data/documents/outcome?format-xml

- http://www.example.com/data/archives/2015
Pada URI diatas telah mengekspos berbagai jenis resource yang cukup jelas yaitu berupa images, videos, XML document dan binary archive document. Itulah contoh dari URI yang memang harusnya dapat dengan mudah dipahami manusia.

- menggunakan standar metode HTTP

Protokol asli HTTP (RFC2616) mendefinisikan 8 action atau dikenal dengan verb yaitu: GET, POST, PUT, DELETE, HEAD, OPTIONS, TRACE, CONNECT. Urutan 4 verbs awal terasa sudah dapat dikenali dalam konteks resource, terutama ketika mendefinisikan aksi manipulasi data resource yaitu CRUD. Jika secara relative dibandingkan dengan operasi CRUD database SQL, dengan cara yang sama saat menerapkan prinsip REST dengan tepat, HTTP verb dapat digambarkan seperti berikut:
Namun ada pengecualian dalam menggunakan verb. Seperti contoh POST yang digunakan untuk membuat resource. Tapi ketika resource harus dibuat berdasarkan URI tertentu, maka PUT adalah verb yang sesuai (menyisipkan tanggal kedalam bagian URI).
PUT /data/documents/outcome/13082017 HTTP/1.1

Content-Type: text/xml
Host: www.example.com


<?xml version="1.0" encoding="utf-8"?>
<outcome date="outcome">
<Item>Sample item</Item>
<price currency="IDR">3500000</price>
</outcome>

HTTP/1.1 201 Created
Content-Type: text/xml
Location: /data/documents/outcome/13082017

Bagaimanapun juga, dalam aplikasi yang kita punya, mungkin kita ingin menyerahkan ke aplikasi REST dalam menentukan lokasi untuk menempatkan resource yang baru dibuat dan dengan demikian membuatnya berada dilokasi yang sesuai namun masih belum diketahui ataupun tidak temukan.

Misalnya, kita contohkan kita ingin server membuat bagian tanggal pada URI berdasarkan tanggal sekarang. Dalam kasus seperti itu, sangat tepat untuk menggunakan verb POST ke resource utama URI dan membiarkan server merespon dengan lokasi resource yang baru dibuat (outcome date akan terisi otomatis).
POST /data/documents/outcome HTTP/1.1

Content-Type: text/xml
Host: www.example.com

<?xml version="1.0" encoding="utf-8"?>
<outcome date="13082017">
<Item>Sample item</Item>
<price currency="IDR">3500000</price>
</outcome>

HTTP/1.1 201 Created
Content-Type: text/xml
Location: /data/documents/outcome

- resource dapat memiliki banyak jenis representasi

Fitur kunci dari sebuah resource adalah resource dapat direpresentasikan dalam bentuk yang berbeda dari yang disimpan. Jadi resource dalam proses request dan posting bisa dalam berbagai macam jenis representasi, selama format yang ditentukan didukung. Pada contoh sebelumnya, kita telah membuat resource dengan representasi XML, tetapi jika server mendukung format JSON, proses dari representasi berikut tetap dapat diterima.
POST /data/documents/balance HTTP/1.1

Content-Type: application/json
Host: www.mydatastore.com

{
 "balance": {
  "date": ""22082014"",
  "Item": "Sample item",
  "price": {
   "-currency": "IDR",
   "#text": "3500000"
  }
 }
}

HTTP/1.1 201 Created
Content-Type: application/json
Location: /data/documents/balance

Dengan memahami dasar protokol HTTP dapat dengan mudah untuk mengerti cara kerja RESTful service. Jadi untuk itu sebagai pelengkap dalam memahami RESTful service bisa terlebih dahulu membaca cara kerja protokol HTTP yang kemudian merujuk pada HTTP verb yang disebutkan diatas.

Itulah sedikit penjelasan mengenai RESTful service, jika mungkin ada yang kurang jelas ataupun salah dalam penjelasan saya mohon kiranya berikan komentar pada kolom dibawah. Dan untuk artikel selanjutnya saya akan coba berikan contoh membuat RESTful service dengan NodeJS.

Image source: javabeat.
Tutorial MongoDB: Operasi CRUD - Part 6

Create, read, update dan delete (CRUD) dasar interaksi yang selalu dilakukan saat menggunakan sebuah database. Setelah sebelumnya kita mengenal dasar-dasar MongoDB, kali ini kita mulai untuk ke bagian penting yaitu CRUD dalam MongoDB yang tersedia dengan beberapa metode.

Membuat document (Insert)

Dalam hal membuat document (istilah pengganti record table dalam NoSQL) MongoDB menyediakan beberapa cara yang diantaranya yaitu:

- membuat document menggunakan insert()

Cara yang paling umum untuk membuat data document baru adalah dengan metode insert(). Metode ini memerlukan 1 argument yang merepresentasikan data baru sebuah document. Contohnya yaitu sebagai berikut:
> db.people.insert({ "firstname": "Jim", "lastname": "Doe", "address": "20 Main St." })

- membuat document menggunakan update()

Metode update() biasanya digunakan untuk mengubah sebuah data. Tetapi dalam MongoDB kita dapat menggunakannya untuk membuat document baru dengan syarat jika tidak ada document yang sama dengan query document dan juga perlu menambahkan "upsert" flag. Contohnya sebagai berikut:
> db.people.update({
... "firstname": "Jim"
... },
... {
... "firstname": "Jim",
... "lastname": "Doe",
... "address": "555 Main St."
... },
... {
... upsert: true
... })
WriteResult({ "nMatched" : 0, "nUpserted" : 1, "nModified" : 0, "_id" : ObjectId("58e34c04002c40a5718b63af")
Contoh query diatas akan membuat MongoDB mencari "firstname" Jim dan mencoba untuk mengubah datanya, tapi nyatanya collection "people" tidak memiliki "firstname" Jim dan karena kita menggunakan "upsert" flag dan MongoDB tidak menemukan data yang sesuai untuk di update maka sebagai gantinya document baru akan dibuat.

- membuat document menggunakan save()

Cara lain untuk membuat document baru adalah dengan menggunakan metode save(). Berikut ini contoh menggunakan save():
> db.people.save({
... "firstname": "John",
... "lastname": "Doe",
... "address": "555 Main St."
... })
WriteResult({ "nInserted" : 1 })
Cukup sederhana cara kerjanya yaitu dengan memasukkan langsung document baru tanpa menyertakan key "_id", atau bisa juga dengan menyertakan key "_id" yang kemudian MongoDB akan memeriksa apakah "_id" itu ada. Efeknya mirip seperti metode update() yang akan langsung membuat document baru jika data yang dicari tidak ditemukan.

Mengubah Dokumen (Update)

Semua proses update membutuhkan paling tidak 2 argument. Argument pertama menspesifikasikan field document dengan nilai apa yang mau diubah dan argument kedua mendefinisikan nilai baru document yang akan diubah. Perlu untuk diketahui kalau secara default fungsi update() cuma mengubah sebuah document (single document), meskipun sebenarnya dapat dioperasikan untuk mengubah banyak document dan bahkan seluruh collection.

Ada 2 tipe umum dari update yaitu perbedaan antara maksud penggunaannya. Tipe pertama yaitu melakukan modifikasi terhadap sebuah document, dan tipe kedua yaitu melakukan replace document lama dengan yang baru. Contoh dari tipe pertama adalah sebagai berikut:
> db.people.update(
... {firstname: "John"},
... {$set: {lastname: "Smith"}}
... )
Proses dari operasi diatas yaitu mencari sebuah document dimana memiliki firstname "John" dan kemudian mengganti nilai field lastname menjadi "Smith". Dan juga kita menggunakan $set operator yang berguna untuk menentukan nilai spesifik sebuah field.

Kemudian untuk cara kedua cukup membingungkan, coba perhatikan operasi berikut ini:
> db.people.update(
... {firstname: "John"},
... {lastname: "Smith"}
... )
Hasil contoh diatas, document akan di-replace hanya pada yang memiliki field lastname, dan field firstname akan dihapus karena document pertama digunakan hanya untuk pencocokan(sebagai argument pertama) dan document kedua digunakan untuk me-replace document yang telah cocok dengan hasil pencarian berdasarkan document pertama.

Jadi intinya, menggunakan teknik replace cukup beresiko karena dapat menghapus field jika tidak digunakan dengan tepat, oleh karena itu harus hati-hati dalam penggunaanya dan lebih disarankan untuk menggunakan $set operator untuk mengupdate document.

Menghapus Document (Delete)

Kita sudah tahu dasar dari operasi create, read, dan update dalam MongoDB. Selanjutnya adalah operasi terakhir yang sederhana yaitu menghapus data.

Dalam penggunaannya, jika tidak ada parameter yang diberikan, operasi remove() akan menghapus semua collection dari document-nya, misalnya:
> db.people.remove()
Hasilnya sudah pasti akan menghapus seluruh data yang ada. Setidaknya kita butuh menghapus data tertentu dari sebuah document, dan untuk itu dibutuhkan parameter ataupun query selector kedalam fungsi remove().

Ada contoh yang misalnya kita ingin menghapus semua nama orang yang memiliki lastname "Smith", jadi bentuk query yang dibuat yaitu:
> db.people.remove(
... {lastname: "Smith"}
... )
Perlu diingat kalau fungsi remove() tidak akan menghapus collection melainkan hanya menghapus document, bisa disamakan dengan klausa DELETE dalam SQL. Dan untuk menghapus collection kita gunakan fungsi drop().
> db.people.drop()

Part 1: Tutorial MongoDB: Pengenalan MongoDB - Part 1
Part 2: Tutorial MongoDB: Mengoperasikan MongoDB - Part 2
Part 3: Tutorial MongoDB: Tipe Data MongoDB - Part 3
Part 4: Tutorial MongoDB: Tipe Data MongoDB (Tambahan) - Part 4
Part 5: Tutorial MongoDB: Dasar MongoDB Shell - Part 5
Part 6: Tutorial MongoDB: Operasi CRUD - Part 6

Itulah dasar dalam menggunakan operasi CRUD di MongoDB. Untuk perbandingan lebih jelas dapat dilihat pada MongoDB CRUD Operations yang telah menyediakan tabel perbanding antara query SQL dan NoSQL.
5 Aplikasi Kamera Terbaik Untuk Android

Kamera smartphone merupakan salah satu bagian paling penting. Banyak perusahaan yang berusaha memaksimalkan dan mengoptimalkan hasil dari foto yang didapat. Namun terkadang aplikasi kamera yang sudah ada terkadang hasilnya terkadang kurang memuaskan dan juga tidak menyediakan fitur yang banyak misalnya filter foto, faktor ini sebenarnya terkait dengan pembuatan aplikasi kamera itu sendiri. 

Meksipun begitu, ada tersedia banyak pilihan alternatif yang dapat menggantikan aplikasi kamera bawaan smartphone. Berikut ini beberapa diantaranya yang merupakan aplikasi yang banyak digunakan sebagai alternatif karena memiliki fitur yang lebih baik.

Camera FV-5

Camera FV-5 adalah salah satu dari banyak aplikasi kamera yang banyak digunakan karena memiliki fitur yang mirip seperti kamera DSLR. Fitur yang tersedia cukup bisa menghasilkan gambar yang bagus jika kita bisa menyesuaikan setting gambar saat proses mengambil foto. Beberapa fitur tersebut yaitu manual shutter speed, light metering, focus, ISO dan lain-lain. Untuk tipe gambar yang didukung yaitu PNG, JPEG hingga DNG (RAW). Untuk mendapatkan aplikasi dengan fitur penuh kita harus membayarnya, akan tetapi aplikasi ini tersedia secara gratis untuk didownload. Download melalui link Google Play: Camera FV-5 for Android.

Camera Zoom FX

Aplikasi yang satu ini pernah saya gunakan dan memang hasil gambarnya sangat baik ketimbang kamera bawaan. Aplikasi ini memilik fitur yang mirip dengan kebanyakan aplikasi kamera seperti kontrol manual ISO, exposure, shutter speed dan lain-lain. Juga tersedia fitur filter, HDR mode, mode pengambilan foto, dan lain sebagainya. Satu fitur yang cukup menarik yaitu tersedia penambahan plugin yang memungkinkan kita dapat fitur tambahan dengan memasangnya. Aplikasi ini dapat digunakan secara gratis, dan untuk fitur yang lengkap dikenakan biaya tambahan. Untuk download silakan langsung melalui link Google Play: Camera Zoom FX for Android.

Camera MX

Aplikasi kamera ini adalah salah satu aplikasi lama dan sangat populer. Pengembang aplikasinya sangat rutin memberikan update fitur hingga sekarang. Aplikasi ini sangat layak untuk digunakan dalam pengambilan foto yang sederhana tanpa perlu melakukan setting ini dan itu. Dengan memiliki beragam mode, dapat membuat foto yang menarik dengan langkah yang cepat. Dan fitur yang seru yaitu kita bisa membuat gambar foto GIF atau foto bergerak dan bahkan sudah tersedia edit foto sederhana didalamnya. Aplikasi ini tersedia gratis, untuk download bisa langsung melalui link Google Play: Camera MX for Android.

Google Camera

Google Camera merupakan aplikasi official dari Google. Aplikasi ini sangat sederhana tetapi memiliki fitur yang efektif, termasuk didalamnya blur mode, slow motion (jika perangkat didukung), photo spheres, video stabilization dan lain sebagainya. Aplikasi ini tersedia secara gratis tanpa perlu membayar untuk mengaktifkan fitur lengkap. Namun sayangnya hanya perangkat yang sudah dengan Android versi terbaru yang bisa menginstallnya. Untuk download dapat melalui link Google Play: Google Camera for Android.

Motion Stills

Aplikasi ini merupakan pendatang baru dalam aplikasi kamera. Dengan fokus fitur utama yaitu merekam video berdurasi pendek dan juga bisa dijadikan gambar GIF tentunya. Aplikasi ini juga menyediakan fitur lainya seperti fast forward untuk mendapatkan video super cepat. Bagaimanapun aplikasi tersedia secara gratis jadi cukup layak untuk digunakan. Untuk mendownload bisa melalui link Google Play: Motion Stills for Android.

Itulah beberapa aplikasi kamera yang dapat dijadikan alternatif bahkan mungkin menggantikan aplikasi kamera bawaan. Saya pribadi sangat merekomendasikan Camera FV-5 karena memiliki fitur yang bagus seperti layaknya DSLR, namun untuk yang gratis saya merekomendasikan Camera MX, silakan anda tentukan pilihan yang paling cocok.

Image source: mobiwoz
Package Sublime Text Terbaik Untuk Web Development

Sublime Text adalah salah satu text editor populer yang masih saya gunakan dalam hal development PHP. Pada artikel sebelumnya yang mengulas sedikit tentang Atom text editor, saya sudah berikan beberapa Atom Plugin Terbaik Untuk JavaScript Development, kali ini saya akan ulas lagi mengenai hal yang sama yaitu Package Sublime text terbaik untuk web development.

- Alignment
- BracketHighlighter
- CodeIgniter Snippets (Optionals)
- Color Highlighter
- ColorPicker
- Colorsublime
- DocBlockr
- Emmet
- FileDiffs
- Javascript Completions
- Package Control
- Status Bar Time
- SublimeLinter
- SublimeLinter-jshint (atau eslint)
- SublimeLinter-contrib-eslint
- SublimeLinter-php

Masih banyak lagi package yang dapat ditemukan melalui website https://packagecontrol.io. Dan juga sudah ada banyak artikel yang mengulas tentang package sublime text, untuk list package diatas adalah versi saya pribadi yang menggunakannya, sampai saat ini masih saya gunakan tanpa kendala.

Jika ada yang ingin ditanyakan, silakan isi komentar dan juga bisa berikan informasi mengenai package lainnya yang mungkin juga lebih baik untuk diguanakan dalam hal web development.

Image source: Wikipedia.
Cara Mengatasi MongoError: E11000 duplicate key error index

Kali ini saya akan menulis singkat mengenai error dalam penggunaan MongoDB dan cara penanganannya. Error ini baru saya alami jadi cukup membuat pusing dan akhirnya bisa terselesaikan.

Saya menggunakan NodeJS dan mongoose dalam membuat RESTful API, dan digunakan dengan jQuery Ajax standard (saya tidak mahir dalam hal front-end framework). Saat masuk proses POST data yang berupa submit form, saya selalu mendapati error di console browser "500 internal server error" dan yang membuat saya makin bingung, API saya tidak crash dan masih bisa berfungsi jika saya gunakan untuk operasi lainnya.

Dalam menggunakan NodeJS, banyak sekali yang merekomendasikan untuk menggunakan debugging tools (API yang saya masih development mode dan belum ada buat testing juga), nah disini saya menggunakan chrome-dev tools dalam hal debungging dan sampai akhirnya saya ketemu penyebab masalah yang saya hadapi yang berisikan error sebagai berikut:
MongoError: E11000 duplicate key error index: toolswatcher.users.$name_1 dup ......
Mungkin nantinya anda akan ketemu masalah yang sama, maka untuk mengatasinya cukup mudah yaitu dengan langkah melalui MongoDB shell dengan perintah berikut:
db.users.dropIndex({"name":1})
Hanya dengan langkah diatas, masalah yang saya hadapi sudah terselesaikan dan API-nya berjalan lancar sesuai yang saya inginkan.

Untuk detail penggunaan MongoDB shell bisa melihat langsung pada tutorial yang ada pada blog ini, dan sedangkan untuk error seperti diatas penjelasan lebih jelasnya bisa mengacu pada link Official MongoDB.

Image source: wpcookhouse.