From dba6a1285917d8b99451f7e91ca2067708a7a27c Mon Sep 17 00:00:00 2001 From: "Erik C. Thauvin" Date: Thu, 23 Jul 2020 22:51:50 -0700 Subject: [PATCH] Added README. --- README.md | 70 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 70 insertions(+) create mode 100644 README.md diff --git a/README.md b/README.md new file mode 100644 index 0000000..86469e5 --- /dev/null +++ b/README.md @@ -0,0 +1,70 @@ +[![License (3-Clause BSD)](https://img.shields.io/badge/license-BSD%203--Clause-blue.svg?style=flat-square)](http://opensource.org/licenses/BSD-3-Clause) [![release](https://img.shields.io/github/release/ethauvin/isgd-shorten.svg)](https://github.com/ethauvin/isgd-shorten/releases/latest) [![Maven Central](https://maven-badges.herokuapp.com/maven-central/net.thauvin.erik/isgd-shorten/badge.svg)](https://maven-badges.herokuapp.com/maven-central/net.thauvin.erik/isgd-shorten) [![Download](https://api.bintray.com/packages/ethauvin/maven/isgd-shorten/images/download.svg)](https://bintray.com/ethauvin/maven/isgd-shorten/_latestVersion) + +[![Known Vulnerabilities](https://snyk.io/test/github/ethauvin/isgd-shorten/badge.svg?targetFile=pom.xml)](https://snyk.io/test/github/ethauvin/isgd-shorten?targetFile=pom.xml) [![Quality Gate Status](https://sonarcloud.io/api/project_badges/measure?project=ethauvin_isgd-shorten&metric=alert_status)](https://sonarcloud.io/dashboard?id=ethauvin_isgd-shorten) [![Build Status](https://travis-ci.com/ethauvin/isgd-shorten.svg?branch=master)](https://travis-ci.com/ethauvin/isgd-shorten) [![CircleCI](https://circleci.com/gh/ethauvin/isgd-shorten/tree/master.svg?style=shield)](https://circleci.com/gh/ethauvin/isgd-shorten/tree/master) + +# [is.gd](https://is.gd/developers.php) Shortener for Kotlin/Java + +A simple implementation of the [is.gd API](https://is.gd/developers.php). + +## Examples (TL;DR) + +```kotlin +import net.thauvin.erik.isgd.Isgd + +... + +Isgd.shorten("https://www.example.com/") // returns https://is.gd/Pt2sET +Isgd.lookup("https://is.gd/Pt2sET") // returns https://www.example.com + +``` + + - View [Kotlin](https://github.com/ethauvin/isgd-shorten/blob/master/examples/src/main/kotlin/com/example/IsgdExample.kt) or [Java](https://github.com/ethauvin/isgd-shorten/blob/master/examples/src/main/java/com/example/IsgdSample.java) Examples. + + +### JSON or XML + +The [is.gd API](https://is.gd/developers.php) can return data in plain text (default), JSON or XML. + +```kotlin +Isgd.shorten("https://www.example.com/", format = Format.JSON) +``` + +returns: + +```json +{ "shorturl": "https://is.gd/Pt2sET" } +``` + +### Parameters + +All of the [is.gd API](https://is.gd/developers.php) parameters are supported: + +```kotlin +Isgd.shorten(url = url, shorturl="foobar", callback = "test", logstats = true, format = Format.JSON) +``` +returns: + +```json +test({ "shorturl": "https://is.gd/foobar" }); +``` +### Gradle + +To use with [Gradle](https://gradle.org/), include the following dependency in your [build](https://github.com/ethauvin/isgd-shorten/blob/master/examples/build.gradle.kts) file: + +```gradle +repositories { + jcenter() +} + +dependencies { + implementation("net.thauvin.erik:isgd-shorten:0.9.1") +} +``` + +### v.gd + +Additionally, link can be shortened using [v.gd](https://v.gd/) by setting the `isVgd` flag: + +```kotlin +Isgd.shorten("https://www.example.com/", isVgd = true) // returns https://v.gd/2z2ncj +```