Центр оповещений Google Workspace получает/обновляет вызовы настроек, возвращая 404
Ссылка: https://developers.google.com/admin-sdk/alertcenter/reference/rest
The getSettings
&updateSettings
Вызовы API там возвращают 404.
Код Go, который работал до начала января, начал давать сбои как минимум с середины января. Одни и те же учетные данные служебной учетной записи правильно работают для вызоваlist
Вызов API, например, мне было интересно, является ли это проблемой SDK, и я тоже попробовал Python, но увидел там то же поведение.
На https://alertcenter.googleapis.com в браузере без учетных данных:
-
/v1beta1/settings
выдает 404, что не ожидается -
/v1beta1/alerts
бросает 401 правильно
Пример кода Python с использованиемgoogle-api-python-client==2.75.0
# alert.py
from google.oauth2 import service_account
from googleapiclient.discovery import build
def main():
credentials = service_account.Credentials.from_service_account_file(
'service_account_credentials.json',
scopes=['https://www.googleapis.com/auth/apps.alerts'],
subject='<email of Google Workspace user authorized to manage alerts>'
)
# Build the service
service = build('alertcenter', 'v1beta1', credentials=credentials)
response = service.v1beta1().getSettings().execute()
# When uncommented, the below call works with the same credentials
# response = service.alerts().list().execute()
print(response)
if __name__ == '__main__':
main()
Пример кода Golang с использованиемgoogle.golang.org/api v0.109.0
// alert.go
package main
import (
"context"
"crypto/tls"
"fmt"
"github.com/hashicorp/go-cleanhttp"
"golang.org/x/oauth2"
"golang.org/x/oauth2/google"
"google.golang.org/api/alertcenter/v1beta1"
"io/ioutil"
"net/http"
"time"
)
func main() {
creds, err := ioutil.ReadFile("service_account_credentials.json")
if err != nil {
fmt.Println(err)
}
config, err := google.JWTConfigFromJSON(creds, alertcenter.AppsAlertsScope)
if err != nil {
fmt.Println(err)
}
config.Subject = "<email of Google Workspace user authorized to manage alerts>"
transport := cleanhttp.DefaultPooledTransport()
transport.TLSClientConfig = &tls.Config{
InsecureSkipVerify: false,
}
transport.ResponseHeaderTimeout = 30 * time.Second
hc := &http.Client{
Transport: transport,
}
ctx := context.WithValue(context.Background(), oauth2.HTTPClient, hc)
client := config.Client(ctx)
srv, err := alertcenter.New(client)
if err != nil {
fmt.Println(err)
}
fmt.Println(srv)
s, err := srv.V1beta1.GetSettings().Context(ctx).Do()
// When uncommented, the below call works with the same credentials
// s, err := srv.Alerts.List().Context(ctx).Do()
fmt.Println(s)
fmt.Println(err)
}
Какие шаги воспроизведут проблему?
- Получите JSON-файл учетных данных служебной учетной записи и замените путь в коде
- Получите адрес электронной почты пользователя Google Workspace и замените тему в коде.
-
python3 alert.py
илиgo run alert.go
Ожидаемый/фактический результат
Раньше я получал стандартные настройки получения и обновления 200 ответов, как упоминалось в документации ранее. Теперь я получаю это с кодом Python:
googleapiclient.errors.HttpError: <HttpError 404 when requesting https://alertcenter.googleapis.com/v1beta1/settings?alt=json returned "Not Found". Details: "<!DOCTYPE html>
<html lang=en>
<meta charset=utf-8>
<meta name=viewport content="initial-scale=1, minimum-scale=1, width=device-width">
<title>Error 404 (Not Found)!!1</title>
<style>
*{margin:0;padding:0}html,code{font:15px/22px arial,sans-serif}html{background:#fff;color:#222;padding:15px}body{margin:7% auto 0;max-width:390px;min-height:180px;padding:30px 0 15px}* > body{background:url(//www.google.com/images/errors/robot.png) 100% 5px no-repeat;padding-right:205px}p{margin:11px 0 22px;overflow:hidden}ins{color:#777;text-decoration:none}a img{border:0}@media screen and (max-width:772px){body{background:none;margin-top:0;max-width:none;padding-right:0}}#logo{background:url(//www.google.com/images/branding/googlelogo/1x/googlelogo_color_150x54dp.png) no-repeat;margin-left:-5px}@media only screen and (min-resolution:192dpi){#logo{background:url(//www.google.com/images/branding/googlelogo/2x/googlelogo_color_150x54dp.png) no-repeat 0% 0%/100% 100%;-moz-border-image:url(//www.google.com/images/branding/googlelogo/2x/googlelogo_color_150x54dp.png) 0}}@media only screen and (-webkit-min-device-pixel-ratio:2){#logo{background:url(//www.google.com/images/branding/googlelogo/2x/googlelogo_color_150x54dp.png) no-repeat;-webkit-background-size:100% 100%}}#logo{display:inline-block;height:54px;width:150px}
</style>
<a href=//www.google.com/><span id=logo aria-label=Google></span></a>
<p><b>404.</b> <ins>That’s an error.</ins>
<p>The requested URL <code>/v1beta1/settings</code> was not found on this server. <ins>That’s all we know.</ins>
">
Код Golang теперь также имеет аналогичный вывод.