L

3 Messages

 • 

200 Points

Tuesday, September 3rd, 2024 3:36 PM

Receiving 403, 'CSRF token mismatch', errors from POST commands

Within the last 2 weeks I have started receiving 403 return codes for every REST API POST command attempted via Python scripts in our Dev environment. All of these scripts have executed successfully multiple times prior to something changing in the environment.

I have tested the POST commands via the REST API GUI and via Postman, all work. The problem definitely seems to be related to the Python to Collibra REST API environment.

Has anyone experienced this and come up with a resolution?

87 Messages

 • 

3.1K Points

5 months ago

We have run into this when the API user account password expired. There is no notification that I have seen, but it could be because of a shared email address. The fix was to update the password associated with the account.

6 Messages

 • 

50 Points

28 days ago

For us, everything works in non prod regions. It's same python code but when deployed to prod. it breaks on csrf mismatch..


This seems to work.

  1. Get the session by calling auth/sessions api
  2. Get the csrfToken from the response.
  3. Pass the csrfToken in the headers
    def signIn(self):
        url = self.url + 'auth/sessions'
        session = requests.Session()
        response = session.post(
            url,
            data=self.userInfo,
            headers= {
                "Content-Type":"application/json",
                "Authorization":"Authorize" ,
                "accept-encoding":"identity",
                "User-agent":"curl/7.29.0"
                },
            proxies= self.proxy

        )

        self.session = session
        token = response.json()
        self.csrfToken = token["csrfToken"]
        return session

//pass the CSRF token in the header upon call.
headers= {"Content-Type": "application/json", "X-CSRF-TOKEN": self.csrfToken},
Loading...