/**
  * Complete an Activity.
  *
  * Changes the ActivityWorkflow status of an Activity to 'Complete'.
  * @param                          $id
  * @param Request                  $request
  * @param ActivityElementValidator $activityElementValidator
  * @return mixed
  */
 public function complete($id, Request $request, ActivityElementValidator $activityElementValidator)
 {
     $activity = $this->workFlowManager->findActivity($id);
     if (Gate::denies('ownership', $activity)) {
         return redirect()->back()->withResponse($this->getNoPrivilegesMessage());
     }
     $this->authorize('edit_activity', $activity);
     if ($cannotBeCompletedMessage = $activityElementValidator->validateActivity($activity, $activity->transactions)) {
         return redirect()->back()->withResponse(['type' => 'warning', 'code' => ['message', ['message' => $cannotBeCompletedMessage]]]);
     }
     if ($invalidResponse = $this->workFlowManager->validate($activity)) {
         return redirect()->back()->withResponse(['type' => 'danger', 'messages' => $invalidResponse, 'activity' => 'true']);
     }
     return redirect()->back()->withResponse($this->respondTo($this->workFlowManager->update($request->all(), $activity), $request->get('activity_workflow')));
 }
 /**
  * @param                          $id
  * @param Request                  $request
  * @param ActivityElementValidator $activityElementValidator
  * @return \Illuminate\Http\RedirectResponse
  */
 public function updateStatus($id, Request $request, ActivityElementValidator $activityElementValidator)
 {
     $activityData = $this->activityManager->getActivityData($id);
     if (Gate::denies('ownership', $activityData)) {
         return redirect()->back()->withResponse($this->getNoPrivilegesMessage());
     }
     $this->authorize('edit_activity', $activityData);
     $input = $request->all();
     $activityWorkflow = $input['activity_workflow'];
     if ($activityWorkflow == 3) {
         $this->authorize('publish_activity', $activityData);
     }
     $settings = $this->settingsManager->getSettings($activityData['organization_id']);
     $transactionData = $this->activityManager->getTransactionData($id);
     $resultData = $this->activityManager->getResultData($id);
     $organization = $this->organizationManager->getOrganization($activityData->organization_id);
     $orgElem = $this->organizationManager->getOrganizationElement();
     $activityElement = $this->activityManager->getActivityElement();
     $xmlService = $activityElement->getActivityXmlService();
     if ($activityWorkflow == 1) {
         $validationMessage = $activityElementValidator->validateActivity($activityData, $transactionData);
         if ($validationMessage) {
             $response = ['type' => 'warning', 'code' => ['message', ['message' => $validationMessage]]];
             return redirect()->back()->withResponse($response);
         }
         $messages = $xmlService->validateActivitySchema($activityData, $transactionData, $resultData, $settings, $activityElement, $orgElem, $organization);
         if ($messages != []) {
             $response = ['type' => 'danger', 'messages' => $messages, 'activity' => 'true'];
             return redirect()->back()->withResponse($response);
         }
     } elseif ($activityWorkflow == 3) {
         if (empty($settings['registry_info'][0]['publisher_id']) && empty($settings['registry_info'][0]['api_id'])) {
             $response = ['type' => 'warning', 'code' => ['settings_registry_info', ['name' => '']]];
             return redirect()->to('/settings')->withResponse($response);
         }
         $xmlService->generateActivityXml($activityData, $transactionData, $resultData, $settings, $activityElement, $orgElem, $organization);
         if ($settings['registry_info'][0]['publish_files'] == 'yes') {
             $publishedStatus = $this->publishToRegistry();
             $this->activityManager->updateStatus($input, $activityData);
             if ($publishedStatus) {
                 $this->activityManager->makePublished($activityData);
                 $this->activityManager->activityInRegistry($activityData);
                 $this->twitter->post($settings, $organization);
                 $response = ['type' => 'success', 'code' => ['publish_registry_publish', ['name' => '']]];
                 return redirect()->back()->withResponse($response);
             } else {
                 $response = ['type' => 'warning', 'code' => ['publish_registry', ['name' => '']]];
                 return redirect()->back()->withResponse($response);
             }
         }
     }
     $statusLabel = ['Completed', 'Verified', 'Published'];
     $response = $this->activityManager->updateStatus($input, $activityData) ? ['type' => 'success', 'code' => ['activity_statuses', ['name' => $statusLabel[$activityWorkflow - 1]]]] : ['type' => 'danger', 'code' => ['activity_statuses_failed', ['name' => $statusLabel[$activityWorkflow - 1]]]];
     return redirect()->back()->withResponse($response);
 }