Skip to content

Commit

Permalink
Merge pull request #15 from ArcaneDisgea/master
Browse files Browse the repository at this point in the history
"better" cli?
  • Loading branch information
Supamiu authored Dec 15, 2021
2 parents 069b956 + 14aef79 commit 6555455
Show file tree
Hide file tree
Showing 2 changed files with 158 additions and 2 deletions.
19 changes: 18 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,22 @@
# lodestone-parser
Parse lodestone for those juicy details

- Run `php cli <func> <arg1> <arg2> <arg3>` for debugging
- Run `php cli <func> <arguments>` for debugging
- Run `php tests` to validate tests

|CLI Command|Arguments|Description|
|-|-|-|
|`character`|`<id>`|Prints a character parse.
|`freecompany`|`<id>`|Prints a freecompanies parse.|
|`pvpteam`|`<id>`|Prints a pvpteam parse.|
|`linkshell`|`<id>`|Prints a linkshell parse.|
|`achievements`|`<id>`|Prints a characters achievement parse.|
|`banners`|none|Prints the currently displayed banners on the lodestone homepage.|
|`leaderboards`|`feast`,`potd`,`hoh`|Prints the current leaderboard parse for The Feast, Palace of The Dead, or Heaven on High.|

All commands accept a flag to print the returned blob to a json file.
Example
```
// prints returned object to file myCharacter.json
php cli character <lodestoneid> -file myCharacter
```
141 changes: 140 additions & 1 deletion cli
Original file line number Diff line number Diff line change
Expand Up @@ -11,4 +11,143 @@ require __DIR__ . '/vendor/autoload.php';

$api = new \Lodestone\Api();

print_r($api->character()->get('9575452')->Title);
print_r($argv);

if ($argc < 2) {
print("No arguments provided.\n");
return;
}

// Remove the cli file from the arguments array
array_shift($argv);
$cliCommandType = $argv[0];

switch($cliCommandType) {
case "character":
if (!isset($argv[1])) {
print_r("INVALID ARGUMENT: Expected Character ID\n");
break;
}
print_r("Parsing character of {$argv[1]}...\n");
$results = $api->character()->get($argv[1]);
if (isset($argv[2]) == "-file") {
$file = fopen("{$argv[3]}.json", 'w');
fwrite($file, json_encode($results));
fclose($file);
break;
}
print_r($results);
break;

case "freecompany":
if (!isset($argv[1])) {
print_r("INVALID ARGUMENT: Expected FreeCompany ID\n");
break;
}
print_r("Parsing freecompany of {$argv[1]}...\n");
$results = $api->freecompany()->get($argv[1]);
if (isset($argv[2]) == "-file") {
$file = fopen("{$argv[3]}.json", 'w');
fwrite($file, json_encode($results));
fclose($file);
break;
}
print_r($results);
break;

case "pvpteam":
if (!isset($argv[1])) {
print_r("INVALID ARGUMENT: Expected PVP Team ID\n");
break;
}
print_r("Parsing pvp team of {$argv[1]}...\n");
$results = $api->pvpteam()->get($argv[1]);
if (isset($argv[2]) == "-file") {
$file = fopen("{$argv[3]}.json", 'w');
fwrite($file, json_encode($results));
fclose($file);
break;
}
print_r($results);
break;

case "linkshell":
if (!isset($argv[1])) {
print_r("INVALID ARGUMENT: Expected Linkshell ID\n");
break;
}
print_r("Parsing linkshell of {$argv[1]}...\n");
$results = $api->linkshell()->get($argv[1])->Results;
if (isset($argv[2]) == "-file") {
$file = fopen("{$argv[3]}.json", 'w');
fwrite($file, json_encode($results));
fclose($file);
break;
}
print_r($results);
break;

case "achievements":
if (!isset($argv[1])) {
print_r("INVALID ARGUMENT: Expected Linkshell ID\n");
break;
}
print_r("Parsing achievements of {$argv[1]}...\n");
$results = $api->character()->achievements($argv[1]);
if (isset($argv[2]) == "-file") {
$file = fopen("{$argv[3]}.json", 'w');
fwrite($file, json_encode($results));
fclose($file);
break;
}
print_r($results);
break;

case "banners":
$results = $api->lodestone()->banners();
if (isset($argv[1]) == "-file") {
$file = fopen("{$argv[2]}.json", 'w');
fwrite($file, json_encode($results));
fclose($file);
break;
}
print_r($results);
break;

case "leaderboards":
// Don't @me I know this is scuff.
switch ($argv[1]) {
case "feast":
$results = $api->leaderboards()->feast();
if (isset($argv[2]) == "-file") {
$file = fopen("{$argv[3]}.json", 'w');
fwrite($file, json_encode($results));
fclose($file);
break;
}
print_r($results);
break;

case "potd":
$results = $api->leaderboards()->ddPalaceOfTheDead();
if (isset($argv[2]) == "-file") {
$file = fopen("{$argv[3]}.json", 'w');
fwrite($file, json_encode($results));
fclose($file);
break;
}
print_r($results);
break;

case "hoh":
$results = $api->leaderboards()->ddHeavenOnHigh();
if (isset($argv[2]) == "-file") {
$file = fopen("{$argv[3]}.json", 'w');
fwrite($file, json_encode($results));
fclose($file);
break;
}
print_r($results);
break;
}
}

0 comments on commit 6555455

Please sign in to comment.