summary refs log tree commit diff stats
path: root/cmd
diff options
context:
space:
mode:
authorAndinus <andinus@inventati.org>2020-03-14 12:14:27 +0530
committerAndinus <andinus@inventati.org>2020-03-14 12:14:27 +0530
commit666c04dc05231c171937a2e84a2f2668b5e351a3 (patch)
treed59182a817b8aee7279368232c547ed2baeb0c20 /cmd
parent3b71ae4119a00c8c1351a845c54fa643764f4324 (diff)
downloadcetus-666c04dc05231c171937a2e84a2f2668b5e351a3.tar.gz
Restructure project
Diffstat (limited to 'cmd')
-rw-r--r--cmd/cetus/cetus.go159
1 files changed, 159 insertions, 0 deletions
diff --git a/cmd/cetus/cetus.go b/cmd/cetus/cetus.go
new file mode 100644
index 0000000..731a4ae
--- /dev/null
+++ b/cmd/cetus/cetus.go
@@ -0,0 +1,159 @@
+// Copyright (c) 2020, Andinus <andinus@inventati.org>
+
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted, provided that the above
+// copyright notice and this permission notice appear in all copies.
+
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+
+package main
+
+import (
+	"flag"
+	"fmt"
+	"log"
+	"math/rand"
+	"net/http"
+	"os/exec"
+	"strconv"
+	"time"
+)
+
+var (
+	timeout time.Duration
+
+	unsplashAPI string
+
+	width  int
+	height int
+)
+
+func main() {
+	rand.Seed(time.Now().Unix())
+
+	var (
+		err error
+
+		imgPath string
+		wall    string
+		src     string
+		srcArr  []string = []string{
+			"unsplash",
+		}
+	)
+
+	// Parse flags passed to program
+	flag.StringVar(&src, "src", "random", "Source for the image")
+	flag.StringVar(&wall, "wall", "random", "Daily, Weekly or Random wallpaper")
+
+	flag.IntVar(&width, "width", 1920, "Width of the image")
+	flag.IntVar(&height, "height", 1080, "Height of the image")
+
+	flag.StringVar(&unsplashAPI, "unsplash-api", "https://source.unsplash.com", "Unsplash Source API URL")
+	flag.DurationVar(&timeout, "timeout", 16, "Timeout for http client")
+	flag.Parse()
+
+	if src == "random" {
+		src = srcArr[rand.Intn(len(srcArr))]
+	}
+
+	// Check if the source is known
+	if !contains(srcArr, src) {
+		log.Fatal("Error: Unknown Source")
+	}
+
+	imgPath, err = parseSrcAndGetPath(src, wall)
+	errChk(err)
+
+	err = setWall(imgPath)
+	errChk(err)
+}
+
+func contains(arr []string, str string) bool {
+	for _, i := range arr {
+		if i == str {
+			return true
+		}
+	}
+	return false
+}
+
+// Gets image path from src
+func parseSrcAndGetPath(src string, wall string) (string, error) {
+	var err error
+	var imgPath string
+
+	switch src {
+	case "unsplash":
+		fmt.Println("Unsplash Source")
+		imgPath, err = getPathUnsplash(wall)
+	}
+
+	return imgPath, err
+}
+
+func getPathUnsplash(wall string) (string, error) {
+	var err error
+	var imgPath string
+
+	switch wall {
+	case "daily", "weekly":
+		unsplashAPI = fmt.Sprintf("%s/%s",
+			unsplashAPI, wall)
+	case "random":
+		unsplashAPI = fmt.Sprintf("%s/%sx%s",
+			unsplashAPI, strconv.Itoa(width), strconv.Itoa(height))
+	default:
+		return "", fmt.Errorf("Error: Unknown wall")
+	}
+
+	req, err := http.NewRequest(http.MethodGet, unsplashAPI, nil)
+	if err != nil {
+		return "", err
+	}
+
+	res, err := getRes(req)
+	if err != nil {
+		return "", err
+	}
+	defer res.Body.Close()
+
+	// Unsplash Source API will redirect to the image
+	imgPath = res.Request.URL.String()
+	return imgPath, err
+}
+
+// Calls feh to set the wallpaper
+func setWall(imgPath string) error {
+	feh, err := exec.LookPath("feh")
+	if err != nil {
+		fmt.Println("Error: feh is not in $PATH")
+		return err
+	}
+
+	fmt.Printf("Path to set as Wallpaper: %s\n", imgPath)
+
+	err = exec.Command(feh, "--bg-fill", imgPath).Run()
+	return err
+}
+
+func getRes(req *http.Request) (*http.Response, error) {
+	client := http.Client{
+		Timeout: time.Second * timeout,
+	}
+	res, err := client.Do(req)
+
+	return res, err
+}
+
+func errChk(err error) {
+	if err != nil {
+		log.Fatal(err)
+	}
+}
='#n216'>216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402