-
Notifications
You must be signed in to change notification settings - Fork 3
Expand file tree
/
Copy pathConversionMetricController.php
More file actions
82 lines (68 loc) · 3.13 KB
/
ConversionMetricController.php
File metadata and controls
82 lines (68 loc) · 3.13 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
<?php
namespace App\Http\Controllers;
use App\Wiki;
use Carbon\CarbonImmutable;
use Illuminate\Http\Request;
class ConversionMetricController extends Controller {
private string $fileName = 'conversion_metric_for_all_wikis.csv';
/**
* Produce a downloadable csv file with conversion metrics for all wikis.
*/
public function index(Request $request) {
$allWikis = Wiki::all();
$current_date = CarbonImmutable::now();
$output = [];
foreach ($allWikis as $wiki) {
$lifecycleEvents = $wiki->wikiLifecycleEvents()->orderBy('id', 'desc')->first();
$wikiLastEditedTime = null;
$wikiFirstEditedTime = null;
if (!empty($lifecycleEvents)) {
if ($lifecycleEvents['last_edited']) {
$wikiLastEditedTime = CarbonImmutable::parse($lifecycleEvents['last_edited']);
}
if ($lifecycleEvents['first_edited']) {
$wikiFirstEditedTime = CarbonImmutable::parse($lifecycleEvents['first_edited']);
}
}
$time_before_wiki_abandoned_days = null;
$time_to_engage_days = null;
$daysSinceLastEdit = null;
if ($wikiLastEditedTime !== null) {
$daysSinceLastEdit = (int) $wikiLastEditedTime->diffInDays($current_date, false);
}
if ($daysSinceLastEdit !== null && $daysSinceLastEdit >= 90) {
$time_before_wiki_abandoned_days = (int) $wiki->created_at->diffInDays($wikiLastEditedTime, false);
}
if ($wikiFirstEditedTime !== null) {
$time_to_engage_days = (int) $wiki->created_at->diffInDays($wikiFirstEditedTime, false);
}
$wiki_number_of_editors = $wiki->wikiSiteStats()->first()['activeusers'] ?? null;
$output[] = [
'domain' => $wiki->domain,
'time_to_engage_days' => $time_to_engage_days,
'time_before_wiki_abandoned_days' => $time_before_wiki_abandoned_days,
'number_of_active_editors' => $wiki_number_of_editors,
'wiki_creation_time' => $wiki->created_at,
'first_edited_time' => $wikiFirstEditedTime,
'last_edited_time' => $wikiLastEditedTime,
];
}
if ($request->wantsJson()) {
return response()->json($output);
}
return $this->returnCsv($output);
}
private function returnCsv($output) {
ob_start();
$handle = fopen('php://output', 'r+');
fputcsv($handle, ['domain_name', 'time_to_engage_days', 'time_before_wiki_abandoned_days', 'number_of_active_editors', 'wiki_creation_time', 'first_edited_time', 'last_edited_time'], escape: '\\');
foreach ($output as $wikiMetrics) {
fputcsv($handle, array_values($wikiMetrics), escape: '\\');
}
$csv = ob_get_clean();
return response($csv, 200, [
'Content-Type' => 'text/csv',
'Content-Disposition' => 'attachment;filename=' . CarbonImmutable::now()->toIso8601String() . '-' . $this->fileName,
]);
}
}