2018-01-05 06:08:18 +01:00
|
|
|
<?php
|
|
|
|
require_once('./Db.php');
|
|
|
|
require_once('./Token.php');
|
|
|
|
|
|
|
|
class Dictionary {
|
|
|
|
private $db;
|
|
|
|
private $token;
|
2018-01-06 18:51:19 +01:00
|
|
|
private $defaults;
|
2018-01-05 06:08:18 +01:00
|
|
|
function __construct () {
|
|
|
|
$this->db = new Db();
|
|
|
|
$this->token = new Token();
|
2018-01-06 18:51:19 +01:00
|
|
|
|
|
|
|
$this->defaults = array(
|
|
|
|
'partsOfSpeech' => array("Noun","Adjective","Verb"),
|
|
|
|
'phonology'=> array(
|
|
|
|
'consonants' => array(),
|
|
|
|
'vowels' => array(),
|
|
|
|
'blends' => array(),
|
|
|
|
'phonotactics' => array(
|
|
|
|
'onset' => array(),
|
|
|
|
'nucleus' => array(),
|
|
|
|
'coda' => array(),
|
|
|
|
'exceptions' => '',
|
|
|
|
),
|
|
|
|
),
|
|
|
|
);
|
2018-01-05 06:08:18 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function create ($user) {
|
|
|
|
$insert_dictionary_query = "INSERT INTO dictionaries (user) VALUES ($user)";
|
|
|
|
$insert_dictionary = $this->db->execute($insert_dictionary_query);
|
|
|
|
|
|
|
|
if ($insert_dictionary === true) {
|
|
|
|
$new_dictionary_id = $this->db->lastInsertId();
|
|
|
|
|
2018-01-06 18:51:19 +01:00
|
|
|
$insert_linguistics_query = "INSERT INTO dictionary_linguistics (dictionary, partsOfSpeech, phonology)
|
|
|
|
VALUES ($new_dictionary_id, ?, ?)";
|
|
|
|
$insert_linguistics = $this->db->execute($insert_linguistics_query, array(
|
|
|
|
json_encode($this->defaults['partsOfSpeech']),
|
|
|
|
json_encode($this->defaults['phonotactics']),
|
|
|
|
));
|
2018-01-05 06:08:18 +01:00
|
|
|
|
|
|
|
if ($insert_linguistics === true) {
|
2018-01-05 07:02:06 +01:00
|
|
|
return $this->changeCurrent($user, $new_dictionary_id);
|
2018-01-05 06:08:18 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function changeCurrent ($user, $dictionary) {
|
|
|
|
$update_query = 'UPDATE users SET current_dictionary=? WHERE id=?';
|
|
|
|
$update = $this->db->query($update_query, array($dictionary, $user));
|
|
|
|
if ($update->rowCount() > 0) {
|
2018-01-05 07:02:06 +01:00
|
|
|
return $dictionary;
|
2018-01-05 06:08:18 +01:00
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getAllNames ($user) {
|
|
|
|
$query = "SELECT id, name, specification FROM dictionaries WHERE user=$user";
|
|
|
|
$results = $this->db->query($query)->fetchAll();
|
|
|
|
if ($results) {
|
|
|
|
return array_map(function($result) {
|
|
|
|
return array(
|
|
|
|
'id' => $this->token->hash($result['id']),
|
|
|
|
'name' => $result['name'] . ' ' . $result['specification'],
|
|
|
|
);
|
|
|
|
}, $results);
|
|
|
|
}
|
|
|
|
return array();
|
|
|
|
}
|
2018-01-05 07:03:24 +01:00
|
|
|
|
|
|
|
public function getDetails ($user, $dictionary) {
|
|
|
|
$query = "SELECT * FROM dictionaries JOIN dictionary_linguistics ON dictionary = id WHERE user=$user AND id=$dictionary";
|
|
|
|
$result = $this->db->query($query)->fetch();
|
|
|
|
if ($result) {
|
2018-01-06 18:51:19 +01:00
|
|
|
// Default json values in case they are somehow not created by front end first
|
|
|
|
$partsOfSpeech = $result['parts_of_speech'] !== '' ? json_decode($result['parts_of_speech']) : $this->defaults['partsOfSpeech'];
|
|
|
|
$phonology = $result['phonology'] !== '' ? json_decode($result['phonology']) : $this->defaults['phonology'];
|
|
|
|
|
2018-01-05 07:03:24 +01:00
|
|
|
return array(
|
|
|
|
'id' => $this->token->hash($result['id']),
|
|
|
|
'name' => $result['name'],
|
|
|
|
'specification' => $result['specification'],
|
|
|
|
'description' => $result['description'],
|
2018-01-06 18:51:19 +01:00
|
|
|
'partsOfSpeech' => $partsOfSpeech,
|
2018-01-05 07:03:24 +01:00
|
|
|
'details' => array(
|
2018-01-06 18:51:19 +01:00
|
|
|
'phonology' => $phonology,
|
2018-01-05 07:03:24 +01:00
|
|
|
'orthography' => array(
|
|
|
|
'notes' => $result['orthography_notes'],
|
|
|
|
),
|
|
|
|
'grammar' => array(
|
|
|
|
'notes' => $result['grammar_notes'],
|
|
|
|
),
|
|
|
|
),
|
|
|
|
'settings' => array(
|
|
|
|
'allowDuplicates' => $result['allow_duplicates'] === '1' ? true : false,
|
|
|
|
'caseSensitive' => $result['case_sensitive'] === '1' ? true : false,
|
|
|
|
'sortByDefinition' => $result['sort_by_definition'] === '1' ? true : false,
|
|
|
|
'isComplete' => $result['is_complete'] === '1' ? true : false,
|
|
|
|
'isPublic' => $result['is_public'] === '1' ? true : false,
|
|
|
|
),
|
2018-01-07 20:59:40 +01:00
|
|
|
'lastUpdated' => is_null($result['last_updated']) ? null : strtotime($result['last_updated']),
|
|
|
|
'createdOn' => strtotime($result['created_on']),
|
2018-01-05 07:03:24 +01:00
|
|
|
);
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2018-01-07 00:53:58 +01:00
|
|
|
public function setDetails ($user, $dictionary, $dictionary_object) {
|
|
|
|
$query1 = "UPDATE dictionaries
|
|
|
|
SET name=:name,
|
|
|
|
specification=:specification,
|
|
|
|
description=:description,
|
|
|
|
allow_duplicates=:allow_duplicates,
|
|
|
|
case_sensitive=:case_sensitive,
|
|
|
|
sort_by_definition=:sort_by_definition,
|
|
|
|
is_complete=:is_complete,
|
|
|
|
is_public=:is_public,
|
|
|
|
last_updated=NOW()
|
|
|
|
WHERE user=$user AND id=$dictionary";
|
|
|
|
|
2018-01-07 20:59:40 +01:00
|
|
|
$result1 = $this->db->query($query1, array(
|
2018-01-07 00:53:58 +01:00
|
|
|
':name' => $dictionary_object['name'],
|
|
|
|
':specification' => $dictionary_object['specification'],
|
|
|
|
':description' => $dictionary_object['description'],
|
|
|
|
':allow_duplicates' => $dictionary_object['settings']['allowDuplicates'],
|
|
|
|
':case_sensitive' => $dictionary_object['settings']['caseSensitive'],
|
|
|
|
':sort_by_definition' => $dictionary_object['settings']['sortByDefinition'],
|
|
|
|
':is_complete' => $dictionary_object['settings']['isComplete'],
|
|
|
|
':is_public' => $dictionary_object['settings']['isPublic'],
|
|
|
|
));
|
|
|
|
if ($result1->rowCount() > 0) {
|
|
|
|
$linguistics = $dictionary_object['details'];
|
|
|
|
$query2 = "UPDATE dictionary_linguistics
|
|
|
|
SET parts_of_speech=:parts_of_speech,
|
|
|
|
phonology=:phonology,
|
|
|
|
orthography_notes=:orthography_notes,
|
|
|
|
grammar_notes=:grammar_notes
|
|
|
|
WHERE dictionary=$dictionary";
|
|
|
|
|
2018-01-07 20:59:40 +01:00
|
|
|
$result2 = $this->db->query($query2, array(
|
2018-01-07 00:53:58 +01:00
|
|
|
':parts_of_speech' => json_encode($dictionary_object['partsOfSpeech']),
|
|
|
|
':phonology' => json_encode($linguistics['phonology']),
|
|
|
|
':orthography_notes' => $linguistics['orthographyNotes'],
|
|
|
|
':grammar_notes' => $linguistics['grammarNotes'],
|
|
|
|
));
|
|
|
|
|
|
|
|
if ($result2->rowCount() > 0) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2018-01-05 07:03:24 +01:00
|
|
|
public function getWords ($user, $dictionary) {
|
|
|
|
$query = "SELECT words.* FROM words JOIN dictionaries ON id = dictionary WHERE dictionary=$dictionary AND user=$user";
|
|
|
|
$results = $this->db->query($query)->fetchAll();
|
|
|
|
if ($results) {
|
|
|
|
return array_map(function ($row) {
|
|
|
|
return array(
|
|
|
|
'id' => $result['word_id'],
|
|
|
|
'name' => $result['name'],
|
|
|
|
'pronunciation' => $result['pronunciation'],
|
|
|
|
'partOfSpeech' => $result['part_of_speech'],
|
|
|
|
'definition' => $result['definition'],
|
|
|
|
'details' => $result['details'],
|
2018-01-07 20:59:40 +01:00
|
|
|
'lastUpdated' => is_null($result['last_updated']) ? null : strtotime($result['last_updated']),
|
|
|
|
'createdOn' => strtotime($result['created_on']),
|
2018-01-05 07:03:24 +01:00
|
|
|
);
|
|
|
|
}, $results);
|
|
|
|
}
|
2018-01-06 18:51:19 +01:00
|
|
|
return array();
|
2018-01-05 07:03:24 +01:00
|
|
|
}
|
2018-01-07 00:53:58 +01:00
|
|
|
|
|
|
|
public function setWords ($dictionary, $words = array()) {
|
2018-01-07 20:59:40 +01:00
|
|
|
$query = 'INSERT INTO words (word_id, name, pronunciation, part_of_speech, definition, details, last_updated, created_on) VALUES ';
|
2018-01-07 00:53:58 +01:00
|
|
|
$params = array();
|
|
|
|
foreach($words as $word) {
|
2018-01-07 20:59:40 +01:00
|
|
|
$query .= "(?, ?, ?, ?, ?, ?, FROM_UNIXTIME(?), FROM_UNIXTIME(?)), ";
|
|
|
|
$params[] = $word['id'];
|
|
|
|
$params[] = $word['name'];
|
|
|
|
$params[] = $word['pronunciation'];
|
|
|
|
$params[] = $word['partOfSpeech'];
|
|
|
|
$params[] = $word['definition'];
|
|
|
|
$params[] = $word['details'];
|
|
|
|
$params[] = is_null($word['lastUpdated']) ? $word['createdOn'] : $word['lastUpdated'];
|
|
|
|
$params[] = $word['createdOn'];
|
2018-01-07 00:53:58 +01:00
|
|
|
}
|
2018-01-07 20:59:40 +01:00
|
|
|
$query = trim($query, ', ') . ' ON DUPLICATE KEY UPDATE
|
2018-01-07 00:53:58 +01:00
|
|
|
name=VALUES(name),
|
2018-01-07 20:59:40 +01:00
|
|
|
pronunciation=VALUES(pronunciation),
|
|
|
|
part_of_speech=VALUES(part_of_speech),
|
|
|
|
definition=VALUES(definition),
|
|
|
|
details=VALUES(details),
|
|
|
|
last_updated=VALUES(last_updated)';
|
2018-01-07 00:53:58 +01:00
|
|
|
|
2018-01-07 20:59:40 +01:00
|
|
|
$results = $this->db->query($query, $params);
|
|
|
|
return $results->rowCount();
|
2018-01-07 00:53:58 +01:00
|
|
|
}
|
2018-01-05 06:08:18 +01:00
|
|
|
}
|