changing weather script to support wttr.in
This commit is contained in:
		
							parent
							
								
									2e087b18c0
								
							
						
					
					
						commit
						60972cc069
					
				@ -1,15 +1,35 @@
 | 
			
		||||
#!/usr/bin/env bash
 | 
			
		||||
# creates a hidden file of your location details based on your address, will expand to support addition via zip codes
 | 
			
		||||
 | 
			
		||||
if [[ -z $1 ]] ; then
 | 
			
		||||
usage() { echo "Usage: $0 [-z zipcode]" 1>&2; exit 1; }
 | 
			
		||||
 | 
			
		||||
if [[ $# -eq 0 ]] ; then
 | 
			
		||||
    # called without args
 | 
			
		||||
    CURRENT_LOCATION=$(curl --silent http://ip-api.com/csv)
 | 
			
		||||
 | 
			
		||||
    STATE_CODE=$(echo "$CURRENT_LOCATION" | cut -d, -f 4)
 | 
			
		||||
    CITY=$(echo "$CURRENT_LOCATION" | cut -d , -f 6)
 | 
			
		||||
    LAT=$(echo "$CURRENT_LOCATION" | cut -d , -f 8)
 | 
			
		||||
    LON=$(echo "$CURRENT_LOCATION" | cut -d , -f 9)
 | 
			
		||||
    printf "STATE=%s\nCITY=%s\nLAT=%s\nLON=%s\n" $STATE_CODE $CITY $LAT $LON > "$HOME/.dotfiles/bin/weather/.env.location"
 | 
			
		||||
    printf "CITY=%s\nLAT=%s\nLON=%s\n" "$CITY" $LAT $LON > "$HOME/.dotfiles/bin/weather/.env.location"
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
while getopts "z:" arg; do
 | 
			
		||||
    case ${arg} in
 | 
			
		||||
        z)
 | 
			
		||||
            ZIPCODE=${OPTARG}
 | 
			
		||||
            source "$HOME/.dotfiles/.priv/key"
 | 
			
		||||
            URL="http://api.openweathermap.org/geo/1.0/zip?zip=$ZIPCODE&appid=$API_KEY"
 | 
			
		||||
            LOCATION=$(curl --silent "$URL")
 | 
			
		||||
            CITY=$(echo $LOCATION | jq -r '.name')
 | 
			
		||||
            LAT=$(echo $LOCATION | jq -r '.lat')
 | 
			
		||||
            LON=$(echo $LOCATION | jq -r '.lon')
 | 
			
		||||
            printf "CITY=%s\nLAT=%s\nLON=%s\n" "$CITY" $LAT $LON > "$HOME/.dotfiles/bin/weather/.env.location"
 | 
			
		||||
            # emptying weather buffer
 | 
			
		||||
            >"$HOME/.dotfiles/bin/weather/.env.weather"
 | 
			
		||||
            ;;
 | 
			
		||||
        ?)
 | 
			
		||||
            usage
 | 
			
		||||
            ;;
 | 
			
		||||
    esac
 | 
			
		||||
done
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@ -15,7 +15,6 @@ type Weather struct {
 | 
			
		||||
	Humidity   int
 | 
			
		||||
	Icon       rune
 | 
			
		||||
	City       string
 | 
			
		||||
	State      string
 | 
			
		||||
	LastPinged int64
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@ -36,7 +35,7 @@ const (
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
func (w *Weather) String() string {
 | 
			
		||||
	return fmt.Sprintf(" %c %.1f%c %d%c in %s, %s", w.Icon, w.Temp, DEGREES_F, w.Humidity, HUMIDITY, w.City, w.State) // Output as ICON ##.#*F ##% in City, ST where the rune is a degree sign
 | 
			
		||||
	return fmt.Sprintf(" %c %.1f%c %d%c in %s", w.Icon, w.Temp, DEGREES_F, w.Humidity, HUMIDITY, w.City) // Output as ICON ##.#*F ##% in City, ST where the rune is a degree sign
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func main() {
 | 
			
		||||
@ -56,7 +55,6 @@ func main() {
 | 
			
		||||
	var err error
 | 
			
		||||
 | 
			
		||||
	city := os.Getenv("CITY")
 | 
			
		||||
	state := os.Getenv("STATE") // fine as strings
 | 
			
		||||
	icon := getIcon(os.Getenv("ICON"))
 | 
			
		||||
	h := os.Getenv("HUMIDITY")
 | 
			
		||||
	t := os.Getenv("TEMP")
 | 
			
		||||
@ -73,7 +71,7 @@ func main() {
 | 
			
		||||
			panic(err)
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
	weather := &Weather{City: city, State: state, Icon: icon, Humidity: humidity, Temp: temp}
 | 
			
		||||
	weather := &Weather{City: city, Icon: icon, Humidity: humidity, Temp: temp}
 | 
			
		||||
	fmt.Print(weather)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										56
									
								
								bin/weather/symbols.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										56
									
								
								bin/weather/symbols.go
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,56 @@
 | 
			
		||||
package main
 | 
			
		||||
 | 
			
		||||
import "fmt"
 | 
			
		||||
 | 
			
		||||
var WeatherCodesDay map[string]rune
 | 
			
		||||
var WeatherCodesNight map[string]rune
 | 
			
		||||
 | 
			
		||||
func SymbolTest() {
 | 
			
		||||
	WeatherCodesDay := map[string]rune{
 | 
			
		||||
		"Unkown":              '\ue374',
 | 
			
		||||
		"Cloudy":              '\ue302',
 | 
			
		||||
		"Fog":                 '\ue303',
 | 
			
		||||
		"HeavyRain":           '\ue318',
 | 
			
		||||
		"HeavyShowers":        '\ue318',
 | 
			
		||||
		"HeavySnow":           '\ue31a',
 | 
			
		||||
		"HeavySnowShowers":    '\ue31a',
 | 
			
		||||
		"LightRain":           '\ue308',
 | 
			
		||||
		"LightShowers":        '\ue308',
 | 
			
		||||
		"LightSleet":          '\ue3aa',
 | 
			
		||||
		"LightSleetShowers":   '\ue3aa',
 | 
			
		||||
		"LightSnow":           '\ue30a',
 | 
			
		||||
		"LightSnowShowers":    '\ue30a',
 | 
			
		||||
		"PartlyCloudy":        '\ue37b',
 | 
			
		||||
		"Sunny":               '\ue30d',
 | 
			
		||||
		"ThunderyHeavyRain":   '\ue31d',
 | 
			
		||||
		"ThunderyShowers":     '\ue31d',
 | 
			
		||||
		"ThunderySnowShowers": '\ue365',
 | 
			
		||||
		"VeryCloudy":          '\ue312',
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	WeatherCodesNight := map[string]rune{
 | 
			
		||||
		"Unkown":              '\ue374',
 | 
			
		||||
		"Cloudy":              '\ue37e',
 | 
			
		||||
		"Fog":                 '\ue346',
 | 
			
		||||
		"HeavyRain":           '\ue318',
 | 
			
		||||
		"HeavyShowers":        '\ue318',
 | 
			
		||||
		"HeavySnow":           '\ue31a',
 | 
			
		||||
		"HeavySnowShowers":    '\ue31a',
 | 
			
		||||
		"LightRain":           '\ue325',
 | 
			
		||||
		"LightShowers":        '\ue325',
 | 
			
		||||
		"LightSleet":          '\ue3ac',
 | 
			
		||||
		"LightSleetShowers":   '\ue3ac',
 | 
			
		||||
		"LightSnow":           '\ue361',
 | 
			
		||||
		"LightSnowShowers":    '\ue361',
 | 
			
		||||
		"PartlyCloudy":        '\ue379',
 | 
			
		||||
		"Sunny":               '\ue32b',
 | 
			
		||||
		"ThunderyHeavyRain":   '\ue31d',
 | 
			
		||||
		"ThunderyShowers":     '\ue31d',
 | 
			
		||||
		"ThunderySnowShowers": '\ue365',
 | 
			
		||||
		"VeryCloudy":          '\ue312',
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	for k, v := range WeatherCodesDay {
 | 
			
		||||
		fmt.Printf("%s: %c %c\n", k, v, WeatherCodesNight[k])
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
										
											Binary file not shown.
										
									
								
							@ -10,6 +10,7 @@ CUR_TIMESTAMP=$(date +%s)
 | 
			
		||||
if [[ $CUR_TIMESTAMP -gt $EXPIRATION  || -z $EXPIRATION ]] ; then
 | 
			
		||||
    WEATHER=$(curl --silent http://api.openweathermap.org/data/2.5/weather\?lat="$LAT"\&lon="$LON"\&appid="$API_KEY"\&units=imperial)
 | 
			
		||||
 | 
			
		||||
    echo $WEATHER
 | 
			
		||||
    TEMP=$(echo $WEATHER | jq -r '.main.temp')
 | 
			
		||||
    HUMIDITY=$(echo $WEATHER | jq -r '.main.humidity')
 | 
			
		||||
    ICON=$(echo $WEATHER | jq -r '.weather[0].icon')
 | 
			
		||||
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user