Commit 5824f1c9d1bd0b9ccd659642ced6be632dcab6bc
1 parent
81164aa6
add get_report_dates() in ap + docs anchor
Showing
3 changed files
with
90 additions
and
36 deletions
Show diff stats
app/library/App/Controllers/AllPositionController.php
@@ -62,9 +62,9 @@ class AllPositionController extends CrudResourceController | @@ -62,9 +62,9 @@ class AllPositionController extends CrudResourceController | ||
62 | 62 | ||
63 | $APObj = new Client(self::API_KEY); | 63 | $APObj = new Client(self::API_KEY); |
64 | 64 | ||
65 | - $projects_info = $APObj->getQueries($project, $id_group); | 65 | + $queries_info = $APObj->getQueries($project, $id_group); |
66 | 66 | ||
67 | - return $projects_info; | 67 | + return $queries_info; |
68 | 68 | ||
69 | } | 69 | } |
70 | 70 | ||
@@ -90,9 +90,9 @@ class AllPositionController extends CrudResourceController | @@ -90,9 +90,9 @@ class AllPositionController extends CrudResourceController | ||
90 | 90 | ||
91 | $APObj = new Client(self::API_KEY); | 91 | $APObj = new Client(self::API_KEY); |
92 | 92 | ||
93 | - $projects_info = $APObj->getReport($project, $date, $prev_date); | 93 | + $report_info = $APObj->getReport($project, $date, $prev_date); |
94 | 94 | ||
95 | - return $projects_info; | 95 | + return $report_info; |
96 | 96 | ||
97 | } | 97 | } |
98 | 98 | ||
@@ -106,9 +106,22 @@ class AllPositionController extends CrudResourceController | @@ -106,9 +106,22 @@ class AllPositionController extends CrudResourceController | ||
106 | 106 | ||
107 | $APObj = new Client(self::API_KEY); | 107 | $APObj = new Client(self::API_KEY); |
108 | 108 | ||
109 | - $projects_info = $APObj->getVisibility($project, $get_start_date, $get_end_date, $id_se); | 109 | + $visibility_info = $APObj->getVisibility($project, $get_start_date, $get_end_date, $id_se); |
110 | 110 | ||
111 | - return $projects_info; | 111 | + return $visibility_info; |
112 | + | ||
113 | + } | ||
114 | + | ||
115 | + public function reportDatesAction() { | ||
116 | + | ||
117 | + /** user params **/ | ||
118 | + $project = $this->request->get('project') ?? 418068; | ||
119 | + | ||
120 | + $APObj = new Client(self::API_KEY); | ||
121 | + | ||
122 | + $report_info = $APObj->getReportDates($project); | ||
123 | + | ||
124 | + return $report_info; | ||
112 | 125 | ||
113 | } | 126 | } |
114 | 127 |
app/library/App/Resources/AllPositionResource.php
@@ -11,7 +11,6 @@ namespace App\Resources; | @@ -11,7 +11,6 @@ namespace App\Resources; | ||
11 | 11 | ||
12 | use App\Constants\AclRoles; | 12 | use App\Constants\AclRoles; |
13 | use App\Controllers\AllPositionController; | 13 | use App\Controllers\AllPositionController; |
14 | -use Phalcon\Acl; | ||
15 | use PhalconApi\Constants\HttpMethods; | 14 | use PhalconApi\Constants\HttpMethods; |
16 | use PhalconRest\Api\ApiEndpoint; | 15 | use PhalconRest\Api\ApiEndpoint; |
17 | use PhalconRest\Api\ApiResource; | 16 | use PhalconRest\Api\ApiResource; |
@@ -24,35 +23,37 @@ class AllPositionResource extends ApiResource | @@ -24,35 +23,37 @@ class AllPositionResource extends ApiResource | ||
24 | $this | 23 | $this |
25 | ->name('All Position') | 24 | ->name('All Position') |
26 | ->expectsJsonData() | 25 | ->expectsJsonData() |
27 | - //->transformer(ModelTransformer::class) | ||
28 | ->itemKey('ap') | 26 | ->itemKey('ap') |
29 | ->collectionKey('ap') | 27 | ->collectionKey('ap') |
30 | ->deny(AclRoles::UNAUTHORIZED) | 28 | ->deny(AclRoles::UNAUTHORIZED) |
31 | ->handler(AllPositionController::class) | 29 | ->handler(AllPositionController::class) |
32 | 30 | ||
33 | - ->endpoint( | ||
34 | - ApiEndpoint::factory('/project', HttpMethods::GET, 'projectAction') | ||
35 | - ->name('project') | ||
36 | - ->description('Данные о проекте') | ||
37 | - ->paramsDescription([ | ||
38 | - 'required params' => [ | ||
39 | - 'project' => "integer(ID проекта)" | ||
40 | - ] | ||
41 | - ]) | ||
42 | - ->exampleResponse([ | ||
43 | - "url" => "rukzachok.com.ua(URL проекта)", | ||
44 | - "cy" => "60(тИЦ)", | ||
45 | - "pr" => "0(Google PageRank)", | ||
46 | - "yaca" => "0(Наличие сайта в Яндекс каталоге)", | ||
47 | - "dmoz" => "0(Наличие сайта в DMOZ)", | ||
48 | - "yahoo" => "0(Наличие сайта в Yahoo)", | ||
49 | - "name" => "rukzachok.com.ua", | ||
50 | - "interval" => 0 | ||
51 | - ]) | ||
52 | - ->allow(AclRoles::USER) | ||
53 | - ) | 31 | + /** -------------------- [GET] project ------------------------------ **/ |
32 | + ->endpoint( | ||
33 | + ApiEndpoint::factory('/project', HttpMethods::GET, 'projectAction') | ||
34 | + ->name('project') | ||
35 | + ->description('Данные о проекте') | ||
36 | + ->paramsDescription([ | ||
37 | + 'required params' => [ | ||
38 | + 'project' => "integer(ID проекта)" | ||
39 | + ] | ||
40 | + ]) | ||
41 | + ->exampleResponse([ | ||
42 | + "url" => "rukzachok.com.ua(URL проекта)", | ||
43 | + "cy" => "60(тИЦ)", | ||
44 | + "pr" => "0(Google PageRank)", | ||
45 | + "yaca" => "0(Наличие сайта в Яндекс каталоге)", | ||
46 | + "dmoz" => "0(Наличие сайта в DMOZ)", | ||
47 | + "yahoo" => "0(Наличие сайта в Yahoo)", | ||
48 | + "name" => "rukzachok.com.ua", | ||
49 | + "interval" => 0 | ||
50 | + ]) | ||
51 | + ->allow(AclRoles::USER) | ||
52 | + ) | ||
53 | + /** ----------------------------------------------------------------- **/ | ||
54 | 54 | ||
55 | - ->endpoint( | 55 | + /** -------------------- [GET] projects ----------------------------- **/ |
56 | + ->endpoint( | ||
56 | ApiEndpoint::factory('/projects', HttpMethods::GET, 'projectsAction') | 57 | ApiEndpoint::factory('/projects', HttpMethods::GET, 'projectsAction') |
57 | ->name('projects') | 58 | ->name('projects') |
58 | ->description('Список проектов пользователя') | 59 | ->description('Список проектов пользователя') |
@@ -86,8 +87,10 @@ class AllPositionResource extends ApiResource | @@ -86,8 +87,10 @@ class AllPositionResource extends ApiResource | ||
86 | ]) | 87 | ]) |
87 | ->allow(AclRoles::USER) | 88 | ->allow(AclRoles::USER) |
88 | ) | 89 | ) |
90 | + /** ------------------------------------------------------------------**/ | ||
89 | 91 | ||
90 | - ->endpoint( | 92 | + /** -------------------- [GET] projects_group ----------------------- **/ |
93 | + ->endpoint( | ||
91 | ApiEndpoint::factory('/projects_group', HttpMethods::GET, 'projectsGroupAction') | 94 | ApiEndpoint::factory('/projects_group', HttpMethods::GET, 'projectsGroupAction') |
92 | ->name('projects group') | 95 | ->name('projects group') |
93 | ->description('Список групп проектов') | 96 | ->description('Список групп проектов') |
@@ -106,8 +109,10 @@ class AllPositionResource extends ApiResource | @@ -106,8 +109,10 @@ class AllPositionResource extends ApiResource | ||
106 | ]) | 109 | ]) |
107 | ->allow(AclRoles::USER) | 110 | ->allow(AclRoles::USER) |
108 | ) | 111 | ) |
112 | + /** ----------------------------------------------------------------- **/ | ||
109 | 113 | ||
110 | - ->endpoint( | 114 | + /** -------------------- [GET] queries ------------------------------ **/ |
115 | + ->endpoint( | ||
111 | ApiEndpoint::factory('/queries', HttpMethods::GET, 'queriesAction') | 116 | ApiEndpoint::factory('/queries', HttpMethods::GET, 'queriesAction') |
112 | ->name('queries') | 117 | ->name('queries') |
113 | ->description('Список запросов, по которым определяется позиция сайта') | 118 | ->description('Список запросов, по которым определяется позиция сайта') |
@@ -137,8 +142,10 @@ class AllPositionResource extends ApiResource | @@ -137,8 +142,10 @@ class AllPositionResource extends ApiResource | ||
137 | ]) | 142 | ]) |
138 | ->allow(AclRoles::USER) | 143 | ->allow(AclRoles::USER) |
139 | ) | 144 | ) |
145 | + /** ----------------------------------------------------------------- **/ | ||
140 | 146 | ||
141 | - ->endpoint( | 147 | + /** -------------------- [GET] queries_group ------------------------ **/ |
148 | + ->endpoint( | ||
142 | ApiEndpoint::factory('/queries_group', HttpMethods::GET, 'queriesGroupAction') | 149 | ApiEndpoint::factory('/queries_group', HttpMethods::GET, 'queriesGroupAction') |
143 | ->name('queries group') | 150 | ->name('queries group') |
144 | ->description('Список групп запросов') | 151 | ->description('Список групп запросов') |
@@ -157,8 +164,10 @@ class AllPositionResource extends ApiResource | @@ -157,8 +164,10 @@ class AllPositionResource extends ApiResource | ||
157 | ]) | 164 | ]) |
158 | ->allow(AclRoles::USER) | 165 | ->allow(AclRoles::USER) |
159 | ) | 166 | ) |
167 | + /** ----------------------------------------------------------------- **/ | ||
160 | 168 | ||
161 | - ->endpoint( | 169 | + /** -------------------- [GET] report ------------------------------- **/ |
170 | + ->endpoint( | ||
162 | ApiEndpoint::factory('/report', HttpMethods::GET, 'reportAction') | 171 | ApiEndpoint::factory('/report', HttpMethods::GET, 'reportAction') |
163 | ->name('report') | 172 | ->name('report') |
164 | ->description('Отчет по позициям сайта') | 173 | ->description('Отчет по позициям сайта') |
@@ -219,8 +228,10 @@ class AllPositionResource extends ApiResource | @@ -219,8 +228,10 @@ class AllPositionResource extends ApiResource | ||
219 | ]) | 228 | ]) |
220 | ->allow(AclRoles::USER) | 229 | ->allow(AclRoles::USER) |
221 | ) | 230 | ) |
231 | + /** ----------------------------------------------------------------- **/ | ||
222 | 232 | ||
223 | - ->endpoint( | 233 | + /** -------------------- [GET] visibility --------------------------- **/ |
234 | + ->endpoint( | ||
224 | ApiEndpoint::factory('/visibility', HttpMethods::GET, 'visibilityAction') | 235 | ApiEndpoint::factory('/visibility', HttpMethods::GET, 'visibilityAction') |
225 | ->name('visibility') | 236 | ->name('visibility') |
226 | ->description('Данные о видимости сайта за указанный период') | 237 | ->description('Данные о видимости сайта за указанный период') |
@@ -244,6 +255,29 @@ class AllPositionResource extends ApiResource | @@ -244,6 +255,29 @@ class AllPositionResource extends ApiResource | ||
244 | ]) | 255 | ]) |
245 | ->allow(AclRoles::USER) | 256 | ->allow(AclRoles::USER) |
246 | ) | 257 | ) |
258 | + /** ----------------------------------------------------------------- **/ | ||
259 | + | ||
260 | + /** -------------------- [GET] visibility --------------------------- **/ | ||
261 | + ->endpoint( | ||
262 | + ApiEndpoint::factory('/report_dates', HttpMethods::GET, 'reportDatesAction') | ||
263 | + ->name('report dates') | ||
264 | + ->description('Список дат, когда обновлялись позиции сайта') | ||
265 | + ->paramsDescription([ | ||
266 | + 'required params' => [ | ||
267 | + 'project' => 'integer(ID проекта)' | ||
268 | + ], | ||
269 | + ]) | ||
270 | + ->exampleResponse([ | ||
271 | + "2017-02-13" => "0.2", | ||
272 | + "2017-02-15" => "0.2", | ||
273 | + "2017-02-20" => "0.3", | ||
274 | + "2017-02-26" => "0.3", | ||
275 | + "2017-03-06" => "0.3", | ||
276 | + "2017-03-12" => "0.2" | ||
277 | + ]) | ||
278 | + ->allow(AclRoles::USER) | ||
279 | + ) | ||
280 | + /** ----------------------------------------------------------------- **/ | ||
247 | ; | 281 | ; |
248 | 282 | ||
249 | } | 283 | } |
app/views/general/documentation.phtml
@@ -27,9 +27,16 @@ | @@ -27,9 +27,16 @@ | ||
27 | 27 | ||
28 | <h2>Коллекции</h2> | 28 | <h2>Коллекции</h2> |
29 | 29 | ||
30 | + <div class="list-group"> | ||
31 | + <a href="#" class="list-group-item active"> | ||
32 | + Анкоры | ||
33 | + </a> | ||
34 | + <a ng-repeat="collection in vm.documentation.collections" href="#{{collection.prefix}}" class="list-group-item">{{collection.name}}</a> | ||
35 | + </div> | ||
36 | + | ||
30 | <div ng-repeat="collection in vm.documentation.collections"> | 37 | <div ng-repeat="collection in vm.documentation.collections"> |
31 | 38 | ||
32 | - <div class="panel panel-primary"> | 39 | + <div class="panel panel-primary" id="{{collection.prefix}}"> |
33 | <div class="panel-heading"> | 40 | <div class="panel-heading"> |
34 | {{ collection.name || collection.prefix }} | 41 | {{ collection.name || collection.prefix }} |
35 | </div> | 42 | </div> |