繁体   English   中英

MailChimp API DrewM \\ MailChimp \\ MailChimp :: call()调用未定义的方法

[英]MailChimp API DrewM\MailChimp\MailChimp::call() call to undefined method

我正在尝试验证apikey,但是如果用户输入apikey,我将在此问题上遇到问题,如果api密钥与MailChimp不匹配,则应该从MailChimp帐户进行验证,并且应该显示无效密钥的消息。

我的代码:

public function authenticateApiKey(Request $request)
{
    $fieldsValidation = [
        'api_key' => 'required|unique:apikey,api_key',
    ];
    $validator = Validator::make($request->all(), $fieldsValidation);

    if ($validator->fails()) {
        $resultArray = [
            'status' => 0,
            'message' => $validator->errors()->first(),
            'dataArray' => []
        ];
    } else {
        $api = new APIKEY($request->all());
        $mc = new MailChimp($api);
        $mailchimp_ping = ($mc->call('helper/ping'));
        if(!$mailchimp_ping){
        }
        $request->user()->apikey()->save($api);
        $resultArray = ['status' => 1, 'message' => 'Mailchimp Api key added into system successfully!', 'dataArray' => $api];
    }
    return \Illuminate\Support\Facades\Response::json($resultArray, 200);
}

当我点击此调用时,它说call to aundefined方法的call to aundefined还有其他可以验证apikey的方法。 任何帮助,将不胜感激!

               namespace App\Http\Controllers;

                    use App\APIKEY;
                 use DrewM\MailChimp\MailChimp;
                use Illuminate\Auth\Access\Response;
                  use Illuminate\Http\Request;
                use Illuminate\Support\Facades\Auth;
                  use Illuminate\Support\Facades\DB;
                 use Illuminate\Support\Facades\Input;
              use Illuminate\Support\Facades\Mail;
            use Illuminate\Support\Facades\Validator;


          class ApiController extends Controller
         {

           public function authenticateApiKey(Request $request)
          {
              $fieldsValidation = [

        'api_key' => 'required|unique:apikey,api_key',

    ];
       $validator = Validator::make($request->all(), $fieldsValidation);

    if ($validator->fails()) {
        $resultArray = [
            'status' => 0,
            'message' => $validator->errors()->first(),
            'dataArray' => []
        ];

    } else {

        $api = new APIKEY($request->all());
        $mc = new MailChimp($api);
        $mailchimp_ping = $mc->get('/ping');
        if ($mailchimp_ping["status"] == 401) {
            return redirect()->back()->with("errorMessage","api key is invalid")->withInput(Input::all());
        }


        ///do here if api key is valid

        $request->user()->apikey()->save($api);
        $resultArray = ['status' => 1, 'message' => 'Mailchimp Api key added into system successfully!', 'dataArray' => $api];
        //   }
        return \Illuminate\Support\Facades\Response::json($resultArray, 200);
    }
}

request 如果请求有效,则该密钥valid 点击链接发出ping请求。 这是MailChimp API 3.0的运行状况检查终结点。

$mailchimp_ping = $mc->get('/ping');

dd($mailchimp_ping);

这是您要求的完整控制器,可以正常运行-

<?php

namespace App\Http\Controllers;

use App\APIKEY;
use DrewM\MailChimp\MailChimp;
use Illuminate\Auth\Access\Response;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\DB;
use Illuminate\Support\Facades\Mail;
use Illuminate\Support\Facades\Validator;


class ApiController extends Controller
{

public function authenticateApiKey(Request $request)
{
    $fieldsValidation = [

        'api_key' => 'required|unique:apikey,api_key',

    ];
    $validator = Validator::make($request->all(), $fieldsValidation);

    if ($validator->fails()) {
        $resultArray = [
            'status' => 0,
            'message' => $validator->errors()->first(),
            'dataArray' => []
        ];

    } else {
        $mc = new MailChimp($request->input('api_key'));
        $mailchimp_ping = $mc->get('/ping');
        if ($mailchimp_ping["status"] != 401) {
             $api = new APIKEY($request->all());
             $request->user()->apikey()->save($api);
             $resultArray = ['status' => 1, 'message' => 'Mailchimp Api key added into system successfully!', 'dataArray' => $api];
             return \Illuminate\Support\Facades\Response::json($resultArray, 200);
        }

          $errorResponse = [
                 'message' => 'Not valid api key!',
                 'code' => '401'
               ];
        return $this->apiResponse('error', '401', $errorResponse);

    }
}
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM