-
Notifications
You must be signed in to change notification settings - Fork 19
/
Copy pathimport.php
63 lines (49 loc) · 1.76 KB
/
import.php
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
<?php
/**
* Usage: php import.php [SYMBOL] [DATE]
* e.g. php import.php tvix 2018-09-25
*/
require('./vendor/autoload.php');
use Carbon\Carbon;
use Dotenv\Dotenv;
$dotenv = new Dotenv(__DIR__);
$dotenv->load();
if ($argc < 2) {
print "Usage: php import.php [SYMBOL] [DATE=YYYY-MM-DD]" . PHP_EOL;
exit();
}
$symbol = strtolower($argv[1]);
if ($argc > 2) {
$date = new Carbon($argv[2]);
} else {
$date = Carbon::now();
}
$db = new mysqli($_ENV['MYSQL_HOST'], $_ENV['MYSQL_USER'], $_ENV['MYSQL_PASS'], $_ENV['MYSQL_DB']);
$client = new GuzzleHttp\Client();
$request = $client->request(
'GET',
'https://sandbox.tradier.com/v1/markets/timesales?symbol=' . strtoupper($symbol) . '&interval=1min&start=' . $date->format('Y-m-d') . 'T00:00:00&end=' . $date->format('Y-m-d') . 'T23:59:59&session_filter=open',
[
'headers' => [
'Accept' => 'application/json',
'Authorization' => 'Bearer ' . $_ENV['TRADIER_KEY']
]
]
);
$data = $request->getBody();
file_put_contents("./data/" . strtoupper($symbol) . "_{$date->format('Y-m-d')}.json", $data);
$file = json_decode($data, true);
foreach ($file['series']['data'] as $bar) {
$start = (new Carbon($bar['time']))->format('Y-m-d H:i:s');
$open = (double)$bar['open'];
$close = (double)$bar['close'];
$high = (double)$bar['high'];
$low = (double)$bar['low'];
$volume = (double)$bar['volume'];
$db->query("INSERT IGNORE INTO {$symbol} VALUES('{$start}', '{$open}', '{$high}', '{$low}', '{$close}', '{$volume}')");
if ($db->error) {
fwrite(STDOUT, "[!] MYSQL ERROR: {$db->error}" . PHP_EOL);
}
}
fwrite(STDOUT, "[+] Processed: ./data/{$symbol}_{$date->format('Y-m-d')}.json" . PHP_EOL);
$db->close();