-
Notifications
You must be signed in to change notification settings - Fork 15
/
Copy pathpvoutput.pl
125 lines (110 loc) · 3.65 KB
/
pvoutput.pl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
#!/usr/bin/perl -w
#
# AS AT 08Mar2012
#
# Submit solar production data to pvoutput.org per http://pvoutput.org/help.html#api
#
# Setup your pvoutput settings per http://pvoutput.org/help.html#api
# Set all values in @PVOUTPUT in this script to match those in your pvoutput settings
# - API_KEY & SYSTEM_ID to your settings from pvoutput.org
# - SERIAL_NUM to your inverter's serial number
# - add another record (in curly braces) if you have more than 1 inverter
#
# V1: Initial release
#
# Copyright Eric Sandeen <[email protected]> 2010
# released under GNU GPL v3 or later
#
# + editions by mmcdon23:
# + removed enphase envoy lines
# + added 4 arguments
#
# + editions by shell_l_d:
# + added serial_num argument so works for multiple inverters
# + replaced variables with @PVOUTPUT array of hashes
# + removed die if $current_watts = 0
#
# Usage examples:
# perl pvoutput.pl 5500 1813 20110307 12:15 1234567890
#
# Arguments:
# $ARGV[0] = (ETODAY) watt hrs exported so far today
# $ARGV[1] = (PAC) current watts
# $ARGV[2] = date (YYYYMMDD)
# $ARGV[3] = time (HH:MM)
# $ARGV[4] = inverter serial number - in case of multiple inverters
#
#######################################################################
use HTTP::Request::Common qw(POST GET);
use LWP::UserAgent; # Web User Agent
use strict;
my $daily_watthrs = $ARGV[0];
my $current_watts = $ARGV[1];
my $log_date = $ARGV[2];
my $log_time = $ARGV[3];
my $serial_num = $ARGV[4];
use constant {
DEBUG_SCRIPT => 0, # 0 = NO, 1 = YES
LIVE_DATA_URL => "http://pvoutput.org/service/r1/addstatus.jsp",
};
#
# Array of Hashes of pvoutput information for each inverter - add more as required (in extra curly braces)
#
my @PVOUTPUT = (
{
SERIAL_NUM => "1234567890",
API_KEY => "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
SYSTEM_ID => "XXX",
},
{
SERIAL_NUM => "1009BO1383",
API_KEY => "7d6f0c8f79fcec98437a4ab339a753fafb4f2e7a",
SYSTEM_ID => "802",
},
);
#######################################################################
#
# Display arguments if $debug turned on
#
if ( DEBUG_SCRIPT ) {
print "Serial: $serial_num as at: $log_date $log_time\n";
print "Now: $current_watts W\n";
print "Today: $daily_watthrs Wh\n";
}
#
# Prepare the web request
#
my $ua = LWP::UserAgent->new;
#
# Loop through the PVOUTPUT Array of Hashes to find the matching inverter serial number
#
my $i;
for $i ( 0 .. $#PVOUTPUT ) {
if ( $PVOUTPUT[$i]{SERIAL_NUM} eq $serial_num ) {
if ( DEBUG_SCRIPT ) {
print $PVOUTPUT[$i]{SERIAL_NUM} . " serial match found at index $i\n";
}
$ua->default_header(
"X-Pvoutput-Apikey" => $PVOUTPUT[$i]{API_KEY},
"X-Pvoutput-SystemId" => $PVOUTPUT[$i]{SYSTEM_ID},
"Content-Type" => "application/x-www-form-urlencoded"
);
#
# Prepare request string
#
print "Sending to PVOUTPUT [ d => $log_date, t => $log_time, v1 => $daily_watthrs, v2 => $current_watts ]\n";
my $request = POST LIVE_DATA_URL, [ d => $log_date, t => $log_time, v1 => $daily_watthrs, v2 => $current_watts ];
#
# Send request to pvoutput to add/update live output status
#
my $res = $ua->request($request);
#
# Display any errors
#
if (! $res->is_success) {
die "Error via pvoutput.org: " . $res->content . "\n";
#die "Couldn't submit data to pvoutput.org: " . $res->status_line . "\n";
}
}
}
exit;