2019-06-04 00:08:13 +02:00
|
|
|
<?php
|
|
|
|
/**
|
2020-09-06 11:38:10 +02:00
|
|
|
* Invoice Ninja (https://invoiceninja.com).
|
2019-06-04 00:08:13 +02:00
|
|
|
*
|
|
|
|
* @link https://github.com/invoiceninja/invoiceninja source repository
|
|
|
|
*
|
2021-01-03 22:54:54 +01:00
|
|
|
* @copyright Copyright (c) 2021. Invoice Ninja LLC (https://invoiceninja.com)
|
2019-06-04 00:08:13 +02:00
|
|
|
*
|
2021-06-16 08:58:16 +02:00
|
|
|
* @license https://www.elastic.co/licensing/elastic-license
|
2019-06-04 00:08:13 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
namespace App\Utils;
|
|
|
|
|
2019-10-16 22:12:38 +02:00
|
|
|
use Illuminate\Support\Facades\DB;
|
|
|
|
|
2019-06-04 00:08:13 +02:00
|
|
|
/**
|
|
|
|
* Class Ninja.
|
|
|
|
*/
|
|
|
|
class Ninja
|
|
|
|
{
|
2020-03-17 09:40:10 +01:00
|
|
|
const TEST_USERNAME = 'user@example.com';
|
|
|
|
|
2019-10-16 22:12:38 +02:00
|
|
|
public static function isSelfHost()
|
|
|
|
{
|
|
|
|
return config('ninja.environment') === 'selfhost';
|
|
|
|
}
|
|
|
|
|
|
|
|
public static function isHosted()
|
|
|
|
{
|
|
|
|
return config('ninja.environment') === 'hosted';
|
|
|
|
}
|
|
|
|
|
2020-03-01 11:18:13 +01:00
|
|
|
public static function isNinja()
|
|
|
|
{
|
|
|
|
return config('ninja.production');
|
|
|
|
}
|
|
|
|
|
2020-03-18 10:40:15 +01:00
|
|
|
public static function isNinjaDev()
|
|
|
|
{
|
2020-03-28 12:34:04 +01:00
|
|
|
return config('ninja.environment') == 'development';
|
2020-03-18 10:40:15 +01:00
|
|
|
}
|
|
|
|
|
2019-10-16 22:12:38 +02:00
|
|
|
public static function getDebugInfo()
|
|
|
|
{
|
2020-09-06 11:38:10 +02:00
|
|
|
$mysql_version = DB::select(DB::raw('select version() as version'))[0]->version;
|
|
|
|
|
|
|
|
$info = 'App Version: v'.config('ninja.app_version').'\\n'.
|
|
|
|
'White Label: '.'\\n'. // TODO: Implement white label with hasFeature.
|
|
|
|
'Server OS: '.php_uname('s').' '.php_uname('r').'\\n'.
|
|
|
|
'PHP Version: '.phpversion().'\\n'.
|
|
|
|
'MySQL Version: '.$mysql_version;
|
2019-06-04 00:08:13 +02:00
|
|
|
|
2019-10-16 22:12:38 +02:00
|
|
|
return $info;
|
|
|
|
}
|
2020-03-07 13:46:45 +01:00
|
|
|
|
|
|
|
public static function boot()
|
|
|
|
{
|
2020-03-26 04:23:57 +01:00
|
|
|
if (self::isNinjaDev()) {
|
2020-03-25 03:50:08 +01:00
|
|
|
return true;
|
2020-03-26 04:23:57 +01:00
|
|
|
}
|
2020-09-06 11:38:10 +02:00
|
|
|
|
2020-03-07 13:46:45 +01:00
|
|
|
$data = [
|
|
|
|
'license' => config('ninja.license'),
|
|
|
|
];
|
|
|
|
|
|
|
|
$data = trim(CurlUtils::post('https://license.invoiceninja.com/api/check', $data));
|
|
|
|
$data = json_decode($data);
|
|
|
|
|
2020-03-22 21:45:16 +01:00
|
|
|
if ($data && property_exists($data, 'message') && $data->message == sha1(config('ninja.license'))) {
|
2020-03-07 13:46:45 +01:00
|
|
|
return true;
|
2020-03-28 12:34:04 +01:00
|
|
|
} else {
|
|
|
|
return false;
|
2020-03-21 06:37:30 +01:00
|
|
|
}
|
2020-03-07 13:46:45 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public static function parse()
|
|
|
|
{
|
|
|
|
return 'Invalid license.';
|
|
|
|
}
|
2020-03-07 23:15:11 +01:00
|
|
|
|
|
|
|
public static function selfHostedMessage()
|
|
|
|
{
|
|
|
|
return 'Self hosted installation limited to one account';
|
|
|
|
}
|
2020-03-17 09:40:10 +01:00
|
|
|
|
|
|
|
public static function registerNinjaUser($user)
|
|
|
|
{
|
2020-03-18 10:40:15 +01:00
|
|
|
if (! $user || $user->email == self::TEST_USERNAME || self::isNinjaDev()) {
|
2020-03-17 09:40:10 +01:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2020-09-06 11:38:10 +02:00
|
|
|
$url = config('ninja.license_url').'/signup/register';
|
2020-03-17 09:40:10 +01:00
|
|
|
$data = '';
|
|
|
|
$fields = [
|
|
|
|
'first_name' => urlencode($user->first_name),
|
|
|
|
'last_name' => urlencode($user->last_name),
|
|
|
|
'email' => urlencode($user->email),
|
|
|
|
];
|
|
|
|
|
|
|
|
foreach ($fields as $key => $value) {
|
|
|
|
$data .= $key.'='.$value.'&';
|
|
|
|
}
|
|
|
|
rtrim($data, '&');
|
|
|
|
|
|
|
|
$ch = curl_init();
|
|
|
|
curl_setopt($ch, CURLOPT_URL, $url);
|
|
|
|
curl_setopt($ch, CURLOPT_POST, count($fields));
|
|
|
|
curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
|
|
|
|
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
|
|
|
|
curl_exec($ch);
|
|
|
|
curl_close($ch);
|
|
|
|
}
|
2020-07-08 14:02:16 +02:00
|
|
|
|
2021-04-13 01:52:17 +02:00
|
|
|
public static function eventVars($user_id = null)
|
2020-07-08 14:02:16 +02:00
|
|
|
{
|
2021-11-11 10:35:07 +01:00
|
|
|
|
2022-01-30 00:46:39 +01:00
|
|
|
$ip = '';
|
|
|
|
|
|
|
|
if(request()->hasHeader('Cf-Connecting-Ip'))
|
|
|
|
$ip = request()->header('Cf-Connecting-Ip');
|
|
|
|
elseif(request()->hasHeader('X-Forwarded-For'))
|
2022-02-02 00:58:43 +01:00
|
|
|
$ip = request()->header('X-Forwarded-For');
|
2022-01-30 00:46:39 +01:00
|
|
|
else
|
2022-02-02 00:58:43 +01:00
|
|
|
$ip = request()->ip() ?: ' ';
|
2021-11-11 10:35:07 +01:00
|
|
|
|
2020-07-08 14:02:16 +02:00
|
|
|
return [
|
2021-11-11 10:35:07 +01:00
|
|
|
'ip' => $ip,
|
2020-07-08 14:02:16 +02:00
|
|
|
'token' => request()->header('X-API-TOKEN'),
|
|
|
|
'is_system' => app()->runningInConsole(),
|
2021-04-13 01:52:17 +02:00
|
|
|
'user_id' => $user_id,
|
2020-07-08 14:02:16 +02:00
|
|
|
];
|
|
|
|
}
|
2020-11-10 04:36:16 +01:00
|
|
|
|
|
|
|
public static function transformTranslations($settings) :array
|
|
|
|
{
|
|
|
|
$translations = [];
|
|
|
|
|
|
|
|
$trans = (array)$settings->translations;
|
|
|
|
|
2020-11-25 15:19:52 +01:00
|
|
|
if (count($trans) == 0) {
|
2020-11-10 04:36:16 +01:00
|
|
|
return $translations;
|
2020-11-25 15:19:52 +01:00
|
|
|
}
|
2020-11-10 04:36:16 +01:00
|
|
|
|
2020-11-25 15:19:52 +01:00
|
|
|
foreach ($trans as $key => $value) {
|
|
|
|
$translations['texts.'.$key] = $value;
|
2020-11-10 04:36:16 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return $translations;
|
|
|
|
}
|
2021-04-06 16:00:24 +02:00
|
|
|
|
|
|
|
public function createLicense($request)
|
|
|
|
{
|
|
|
|
// $affiliate = Affiliate::where('affiliate_key', '=', SELF_HOST_AFFILIATE_KEY)->first();
|
|
|
|
// $email = trim(Input::get('email'));
|
|
|
|
|
|
|
|
// if (! $email || $email == TEST_USERNAME) {
|
|
|
|
// return RESULT_FAILURE;
|
|
|
|
// }
|
|
|
|
|
|
|
|
// $license = new License();
|
|
|
|
// $license->first_name = Input::get('first_name');
|
|
|
|
// $license->last_name = Input::get('last_name');
|
|
|
|
// $license->email = $email;
|
|
|
|
// $license->transaction_reference = Request::getClientIp();
|
|
|
|
// $license->license_key = self::generateLicense();
|
|
|
|
// $license->affiliate_id = $affiliate->id;
|
|
|
|
// $license->product_id = PRODUCT_SELF_HOST;
|
|
|
|
// $license->is_claimed = 1;
|
|
|
|
// $license->save();
|
|
|
|
|
|
|
|
// return RESULT_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
// public static function generateLicense()
|
|
|
|
// {
|
|
|
|
// $parts = [];
|
|
|
|
// for ($i = 0; $i < 5; $i++) {
|
|
|
|
// $parts[] = strtoupper(str_random(4));
|
|
|
|
// }
|
|
|
|
|
|
|
|
// return implode('-', $parts);
|
|
|
|
// }
|
2021-07-19 06:17:58 +02:00
|
|
|
//
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Available - but not recommended for use
|
|
|
|
*
|
|
|
|
* This will guarantee a given string IS the correct format for a
|
|
|
|
* base64 encoded string ,
|
|
|
|
* but can't guarantee that it is a base64 encoded string
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public static function isBase64Encoded(string $s) : bool
|
|
|
|
{
|
|
|
|
|
|
|
|
// Check if there are valid base64 characters
|
|
|
|
if (!preg_match('/^[a-zA-Z0-9\/\r\n+]*={0,2}$/', $s)) return false;
|
|
|
|
// Decode the string in strict mode and check the results
|
|
|
|
$decoded = base64_decode($s, true);
|
|
|
|
if(false === $decoded) return false;
|
|
|
|
// if string returned contains not printable chars
|
|
|
|
if (0 < preg_match('/((?![[:graph:]])(?!\s)(?!\p{L}))./', $decoded, $matched)) return false;
|
|
|
|
// Encode the string again
|
|
|
|
if(base64_encode($decoded) != $s) return false;
|
|
|
|
return true;
|
|
|
|
|
|
|
|
}
|
2019-06-04 00:08:13 +02:00
|
|
|
}
|