<?php

/**
 * @file src/Model/OpenWebAuthToken.php
 */
namespace Friendica\Model;

use Friendica\Database\DBA;
use Friendica\Util\DateTimeFormat;

/**
 * Methods to deal with entries of the 'openwebauth-token' table.
 */
class OpenWebAuthToken
{
	/**
	 * Create an entry in the 'openwebauth-token' table.
	 *
	 * @param string $type   Verify type.
	 * @param int    $uid    The user ID.
	 * @param string $token
	 * @param string $meta
	 *
	 * @return boolean
	 */
	public static function create($type, $uid, $token, $meta)
	{
		$fields = [
			"type" => $type,
			"uid" => $uid,
			"token" => $token,
			"meta" => $meta,
			"created" => DateTimeFormat::utcNow()
		];
		return DBA::insert("openwebauth-token", $fields);
	}

	/**
	 * Get the "meta" field of an entry in the openwebauth-token table.
	 *
	 * @param string $type   Verify type.
	 * @param int    $uid    The user ID.
	 * @param string $token
	 *
	 * @return string|boolean The meta enry or false if not found.
	 */
	public static function getMeta($type, $uid, $token)
	{
		$condition = ["type" => $type, "uid" => $uid, "token" => $token];

		$entry = DBA::selectFirst("openwebauth-token", ["id", "meta"], $condition);
		if (DBA::isResult($entry)) {
			DBA::delete("openwebauth-token", ["id" => $entry["id"]]);

			return $entry["meta"];
		}
		return false;
	}

	/**
	 * Purge entries of a verify-type older than interval.
	 *
	 * @param string $type     Verify type.
	 * @param string $interval SQL compatible time interval
	 */
	public static function purge($type, $interval)
	{
		$condition = ["`type` = ? AND `created` < ?", $type, DateTimeFormat::utcNow() . " - INTERVAL " . $interval];
		DBA::delete("openwebauth-token", $condition);
	}

}