BoxLang 🚀 A New JVM Dynamic Language Learn More...
This module provides a simple SDK for creating and managing Tiny URLs using the open-source Kutt application.
TINYURL_ENABLED
- can be used to disable the moduleKUTT_ENDPOINT
- This is full URL to your Kutt serverKUTT_AUTHTOKEN
- This is the API token used to access the Kutt server APIKUTT_THROWONERROR
- When set to true, errors will be thrown on link creation if there is a failure from the Kutt API serverIn your config/modules/kutt-sdk.cfc
file you use some or all of the following settings. The defaults are provided below:
function configure(){
return {
// When not enabled, the original URL will be returned
"enabled" : getSystemSetting( "TINYURL_ENABLED", true ),
// This is full URL to your Kutt server
"endpoint" : getSystemSetting( "KUTT_ENDPOINT", "" ),
// This is the API token used to access the Kutt server API
"authToken" : getSystemSetting( "KUTT_AUTHTOKEN", "" ),
// The default URL expiration. Must be a number followed by the plural time interval ( e.g. 1 days, 24 hours, 3 minutes, 1 months, etc )
"defaultExipration" : "30 days",
// Whether to throw on error when communication with the Kutt API fails
"throwOnError" : getSystemSetting( "KUTT_THROWONERROR", false )
};
}
create(
required string target, // the URL to shorten
string description, // an optional description for the link
string expires, // an optional number and interval for the URL to expire ( e.g. 30 days, 10 minutes, 2 hours, etc )
boolean reuse = true, // whether or not to reuse the same short URL for the same target. If passed as false a new short URL will be created for each request.
string password, // an optional password to protect the short URL
string domain // an optional domain to use for the short URL
)
var urlService = getInstance( "URLService@kutt" );
// create a basic link
var tiny1 = urlService.create( "https://www.ortussolutions.com" );
// When reuse is set to false it will always create a new tinyURL
var tiny1 = urlService.create( target="https://www.ortussolutions.com", reuse=false );
ColdBox is a professional open-source project and it is completely funded by the community and Ortus Solutions, Corp. Ortus Patreons get many benefits like a cfcasts account, a FORGEBOX Pro account and so much more. If you are interested in becoming a sponsor, please visit our patronage page: https://patreon.com/ortussolutions
"I am the way, and the truth, and the life; no one comes to the Father, but by me (JESUS)" Jn 14:1-12
All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.
$
box install kutt-sdk