Skip to main content

Quickly stop all Google Ads advertising

Project description

sem-emergency-stop

Logo

Stop all Google Ads marketing. This utility will pause all marketing campaigns on Google Ads (presumably across many accounts) as fast as possible. The main use case is emergency response during incidents where all landing pages are temporarily unavailable, thereby incurring cost without revenue. Unpausing the paused campaigns (and only those) is also supported.

Usage

In case of emergency, do this:

sem-emergency-stop pause --no-dry-run

A hash will be printed at the end of the process. Use this hash to unpause when the incident is over (the exact instructions are displayed when you run.)

One-time setup (for end users)

Install the tool (requires Python 3.7 or higher; on Ubuntu 18.04 install python3.7-minimal):

pip3 install --user sem-emergency-stop

You can then run sem-emergency-stop setup to authenticate the tool against the API using your Google account. This will request two pieces of information from you:

  1. An organization token. How you get this token depends on your organization's process. See the next section if you are the person to set this up for your organization.
  2. A token specific to your Google account. Follow instructions on screen. Note that you need to have access to your Ads accounts with your Google account.

Deployment at organizations

Authentication uses Google's OAuth2 flow. This app does not come with client secrets, so you will have to generate these and distribute them in your organization through a suitable channel (e.g. using password manager). The client id/secret together with your login customer id and your developer token are packaged in a compact organization token for distribution purposes.

After installing the app, you can generate a token by running ses-create-org-token. It will ask the following information:

  • Login customer id - this is the customer id (without dashes) of your root Google Ads account.
  • Developer token - find it in your root account under "API Center".
  • Client id/secret - follow this guide how to obtain a pair.

Development and contributing

For development pipenv is required on your system. Set up the development environment with make develop, run with pipenv run sem-emergency-stop ... as needed.

We welcome pull requests; if you are planning to perform bigger changes then it makes sense to file an issue first. Make sure make lint comes back clean.

Security

For sensitive security matters please contact security@getyourguide.com.

Legal

Copyright 2021 GetYourGuide GmbH.

sem-emergency-stop is licensed under the Apache License, Version 2.0. See LICENSE for the full text.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

sem_emergency_stop-1.3.12.tar.gz (13.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

sem_emergency_stop-1.3.12-py3-none-any.whl (14.4 kB view details)

Uploaded Python 3

File details

Details for the file sem_emergency_stop-1.3.12.tar.gz.

File metadata

  • Download URL: sem_emergency_stop-1.3.12.tar.gz
  • Upload date:
  • Size: 13.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.17

File hashes

Hashes for sem_emergency_stop-1.3.12.tar.gz
Algorithm Hash digest
SHA256 8716e10e3463313b25d3a64dd0487e5b44db347e10a5ffe9657fba8d420d605d
MD5 1a328b2a5a0a23699eb93c3f069ba5de
BLAKE2b-256 c6497cc5d62f6b6be3200a08aaf148529da1890b59ea55623818f6af02201dc5

See more details on using hashes here.

File details

Details for the file sem_emergency_stop-1.3.12-py3-none-any.whl.

File metadata

File hashes

Hashes for sem_emergency_stop-1.3.12-py3-none-any.whl
Algorithm Hash digest
SHA256 0fcaaaa507755cb1beb245b27b57d796270515ef7d888f42bfd3ccdf27bc62c4
MD5 2c38d384bab8d4ea431978cca4858218
BLAKE2b-256 c6794243401bf39372d3be4c30c9a48c859fc5d73a6f758691ab360c00295cac

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page