summaryrefslogtreecommitdiff
path: root/lib/type-todo.php
diff options
context:
space:
mode:
Diffstat (limited to 'lib/type-todo.php')
-rw-r--r--lib/type-todo.php132
1 files changed, 132 insertions, 0 deletions
diff --git a/lib/type-todo.php b/lib/type-todo.php
new file mode 100644
index 0000000..f813543
--- /dev/null
+++ b/lib/type-todo.php
@@ -0,0 +1,132 @@
+
+ public function type($get){
+
+ $search = $get["s"];
+ $bang = $get["bang"];
+
+ if(empty($search)){
+
+ if(!empty($bang)){
+
+ // !youtube
+ $conn = pg_connect("host=localhost dbname=4get user=postgres password=postgres");
+
+ pg_prepare($conn, "bang_get", "SELECT bang,name FROM bangs WHERE bang LIKE $1 ORDER BY bang ASC LIMIT 8");
+ $q = pg_execute($conn, "bang_get", ["$bang%"]);
+
+ $results = [];
+ while($row = pg_fetch_array($q, null, PGSQL_ASSOC)){
+
+ $results[] = [
+ "s" => "!" . $row["bang"],
+ "n" => $row["name"]
+ ];
+ }
+
+ return $results;
+ }else{
+
+ // everything is empty
+ // lets just return a bang list
+ return [
+ [
+ "s" => "!w",
+ "n" => "Wikipedia",
+ "u" => "https://en.wikipedia.org/wiki/Special:Search?search={%q%}"
+ ],
+ [
+ "s" => "!4ch",
+ "n" => "4chan Board",
+ "u" => "https://find.4chan.org/?q={%q%}"
+ ],
+ [
+ "s" => "!a",
+ "n" => "Amazon",
+ "u" => "https://www.amazon.com/s?k={%q%}"
+ ],
+ [
+ "s" => "!e",
+ "n" => "eBay",
+ "u" => "https://www.ebay.com/sch/items/?_nkw={%q%}"
+ ],
+ [
+ "s" => "!so",
+ "n" => "Stack Overflow",
+ "u" => "http://stackoverflow.com/search?q={%q%}"
+ ],
+ [
+ "s" => "!gh",
+ "n" => "GitHub",
+ "u" => "https://github.com/search?utf8=%E2%9C%93&q={%q%}"
+ ],
+ [
+ "s" => "!tw",
+ "n" => "Twitter",
+ "u" => "https://twitter.com/search?q={%q%}"
+ ],
+ [
+ "s" => "!r",
+ "n" => "Reddit",
+ "u" => "https://www.reddit.com/search?q={%q%}"
+ ],
+ ];
+ }
+ }
+
+ // now we know search isnt empty
+ if(!empty($bang)){
+
+ // check if the bang exists
+ $conn = pg_connect("host=localhost dbname=4get user=postgres password=postgres");
+
+ pg_prepare($conn, "bang_get_single", "SELECT bang,name FROM bangs WHERE bang = $1 LIMIT 1");
+ $q = pg_execute($conn, "bang_get_single", [$bang]);
+
+ $row = pg_fetch_array($q, null, PGSQL_ASSOC);
+
+ if(isset($row["bang"])){
+
+ $bang = "!$bang ";
+ }else{
+
+ $bang = "";
+ }
+ }
+
+ try{
+ $res = $this->get(
+ "https://duckduckgo.com/ac/",
+ [
+ "q" => strtolower($search)
+ ],
+ ddg::req_xhr
+ );
+
+ $res = json_decode($res, true);
+
+ }catch(Exception $e){
+
+ throw new Exception("Failed to get /ac/");
+ }
+
+ $arr = [];
+ for($i=0; $i<count($res); $i++){
+
+ if($i === 8){break;}
+
+ if(empty($bang)){
+
+ $arr[] = [
+ "s" => $res[$i]["phrase"]
+ ];
+ }else{
+
+ $arr[] = [
+ "s" => $bang . $res[$i]["phrase"],
+ "n" => $row["name"]
+ ];
+ }
+ }
+
+ return $arr;
+ }