You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Here's how I got it to work for anyone that's still planning on using this tool today (cause it is - imo - still very cool):
Setting up GCP
Head over to GCP Console, create a new project (I called mine gslides-generator), search for "APIs & Services" on the top search bar and click on "OAuth consent screen" on the left.
Setup your OAuth consent screen via the wizard by giving it a suitable name (I called mine <myname>-md2gslides) and adding your personal email as a test user.
Head over to the Credentials tab on the left, click "+ Create Credentials" and select "OAuth Client ID".
After that, select "Desktop app" as your Application Type and give it a suitable name (I called mine desktop-md2gslides)
Finally, save the generated credentials JSON file into your computer. Open the file and copy the client_id and client_secret which will come in handy later.
Setting up Node.js and compiling md2gslides
Clone this repository to get the latest version of the md2googleslides' source code on your computer: git clone https://github.com/googleworkspace/md2googleslides.git
Change your Node.js version to 12 (which is the only version I got this to work in) by typing nvm use 12 (if you don't have this version installed, you can run nvm install 12)
Ensure that you're using Node.js version 12 by running node --version.
Run npm i from within the md2googleslides' folder you just cloned to install all dependencies.
Run npm run compile to build the tool. The code should build in the lib/ folder.
functiongetAuthenticatedClient(){returnnewPromise((resolve,reject)=>{// create an oAuth client to authorize the API call. Secrets are kept in a `keys.json` file,// which should be downloaded from the Google Developers Console.constoAuth2Client=newOAuth2Client("<your_client_id>",// This should come from the credentials JSON file you generated earlier"<your_client_secret>","http://localhost:3000"// This doesn't matter, as long as it is localhost);// Generate the url that will be used for the consent dialog.constauthorizeUrl=oAuth2Client.generateAuthUrl({access_type: 'offline',scope: SCOPES,});console.log('Authorize this app by visiting this url:',authorizeUrl);});}
This snippet of code will help us run the latest supported version of OAuth to allow the tool to access the Google Slides and Google Drive APIs (without this, I always get the following error on the OAuth Consent Screen: Error 401: unauthorized_client Request details: lowName=GeneralOAuthFlow).
Scroll down this file to find the authorizeUser() function. Make this function async and at the top of this function, call the getAuthenticatedClient() function you just created by adding the following code:
awaitgetAuthenticatedClient()
After that, comment out all the lines from below this line to the end of the authorizeUser() function to prevent any additional authentication code from running. Finally, this function should look like this:
asyncfunctionauthorizeUser(){// Google OAuth2 clients always have a secret, even if the client is an installed// application/utility such as this. Of course, in such cases the "secret" is// actually publicly known; security depends entirely on the secrecy of refresh// tokens, which effectively become bearer tokens.// Load and parse client ID and secret from client_id.json file. (Create// OAuth client ID from Credentials tab at console.developers.google.com// and download the credentials as client_id.json to ~/.md2googleslidesawaitgetAuthenticatedClient()// let data; // needs to be scoped outside of try-catch// try {// data = fs.readFileSync(STORED_CLIENT_ID_PATH);// } catch (err) {// console.log('Error loading client secret file:', err);// throw err;// }// if (data === undefined) {// console.log('Error loading client secret data');// throw 'No client secret found.';// }// const creds = JSON.parse(data).installed;// // Authorize user and get (& store) a valid access token.// const options = {// clientId: creds.client_id,// clientSecret: creds.client_secret,// filePath: STORED_CREDENTIALS_PATH,// prompt: prompt,// };// const auth = new UserAuthorizer(options);// return auth.getUserCredentials(args.user, SCOPES);}
Scroll all the way to the end of this file, and comment out the .then methods after the first authorizeUser() call. Your last code snippet should look like this:
After that, you can run this file by typing node bin/md2gslides.js from your terminal. You will get the following DepreciationWarning(s) on your terminal:
(node:60689) DeprecationWarning: ArgumentParser(): following options are renamed: 'addHelp' -> 'add_help'
(node:60689) DeprecationWarning: The "version" argument to ArgumentParser is deprecated. Please use add_argument(..., { action: 'version', version: 'N', ... }) instead.
(node:60689) DeprecationWarning: _ActionsContainer.addArgument() is renamed to _ActionsContainer.add_argument()
(node:60689) DeprecationWarning: add_argument(): following options are renamed: 'defaultValue' -> 'default'
(node:60689) DeprecationWarning: use add_argument('-u', '--user', {...}) instead of add_argument([ '-u', '--user' ], { ... })
(node:60689) DeprecationWarning: {action: "storeTrue"} is renamed to {action: "store_true"}
(node:60689) DeprecationWarning: ArgumentParser.parseArgs() is renamed to ArgumentParser.parse_args()
...but not to worry, you should now see a URL output on the screen to open up your OAuth Consent Screen!
Copy this link over to a web browser, ignore any security messages and complete the OAuth flow. You should end up with a "This site can’t be reached" page at the end - since nothing is running on localhost. This is fine, since what matters to us is that the URL now contains a query parameter called code. Copy this!
Finally, uncomment the lines of code that we commented in bin/md2gslides.js and comment out the await getAuthenticatedClient(). You may revert the authorizeUser() function back to a sync function too.
Now, re-run node bin/md2gslides.js examples/example.md --use-fileio. You should see the following prompt:
Authorize this app in your browser.
Enter the code here:
Add the code you copied from Step 7 into this prompt:
The examples/example.md is the sample Markdown file provided in the source code to test conversion
--use-fileio enables the use of local files. (Even though I used the --use-fileio flag, I was never able to get local images to work. So I deleted the ![](image_slide.png) on the example.md file before re-running the command, because this results in a runtime error)
If everything worked, you should see the fully converted Google Slides open on your web browser!
Thanks for following through! I'll try my best to create a fork with these code changes - but until then, best of luck with your slides!
The text was updated successfully, but these errors were encountered:
When I got to Updating bin/md2gslides.js step 9, I got the error that md2googleslides was trying to read my Google OAuth credentials from the file /Users/<name>/.md2googleslides/client_id.json rather than getting the prompt you describe.
If I renamed and moved the json from setting up GCP step 5 to /Users/<name>/.md2googleslides/client_id.json then re-running node bin/md2gslides.js examples/example.md --use-fileio results in my browser opening to a google sign in page with a Error 400: invalid_request, with the further details:
The out-of-band (OOB) flow has been blocked in order to keep users secure. Follow the Out-of-Band (OOB) flow migration guide linked in the developer docs below to migrate your app to an alternative method.
Request details: redirect_uri=urn:ietf:wg:oauth:2.0:oob flowName=GeneralOAuthFlow
2024 - My experience in getting md2googleslides to work
After spending close to a day reading and debugging all the open issues, I've finally been able to get
example.md
to convert to Google Slides 🎉Here's details from my device for your reference:
Here's how I got it to work for anyone that's still planning on using this tool today (cause it is - imo - still very cool):
Setting up GCP
Head over to GCP Console, create a new project (I called mine
gslides-generator
), search for "APIs & Services" on the top search bar and click on "OAuth consent screen" on the left.Setup your OAuth consent screen via the wizard by giving it a suitable name (I called mine
<myname>-md2gslides
) and adding your personal email as a test user.Head over to the Credentials tab on the left, click "+ Create Credentials" and select "OAuth Client ID".
After that, select "Desktop app" as your Application Type and give it a suitable name (I called mine
desktop-md2gslides
)Finally, save the generated credentials JSON file into your computer. Open the file and copy the
client_id
andclient_secret
which will come in handy later.Setting up Node.js and compiling
md2gslides
Clone this repository to get the latest version of the md2googleslides' source code on your computer:
git clone https://github.com/googleworkspace/md2googleslides.git
Change your Node.js version to 12 (which is the only version I got this to work in) by typing
nvm use 12
(if you don't have this version installed, you can runnvm install 12
)Ensure that you're using Node.js version 12 by running
node --version
.Run
npm i
from within the md2googleslides' folder you just cloned to install all dependencies.Run
npm run compile
to build the tool. The code should build in thelib/
folder.Updating
bin/md2gslides.js
Run
npm install google-auth-library
to install the latest version of Google's Authentication Library for Node.js. This will be required to get support for the OAuth2 flow.Add this import at the top of
bin/md2gslides.js
:This snippet of code will help us run the latest supported version of OAuth to allow the tool to access the Google Slides and Google Drive APIs (without this, I always get the following error on the OAuth Consent Screen:
Error 401: unauthorized_client Request details: lowName=GeneralOAuthFlow
).authorizeUser()
function. Make this functionasync
and at the top of this function, call thegetAuthenticatedClient()
function you just created by adding the following code:After that, comment out all the lines from below this line to the end of the
authorizeUser()
function to prevent any additional authentication code from running. Finally, this function should look like this:.then
methods after the firstauthorizeUser()
call. Your last code snippet should look like this:node bin/md2gslides.js
from your terminal. You will get the followingDepreciationWarning
(s) on your terminal:...but not to worry, you should now see a URL output on the screen to open up your OAuth Consent Screen!
Copy this link over to a web browser, ignore any security messages and complete the OAuth flow. You should end up with a "This site can’t be reached" page at the end - since nothing is running on localhost. This is fine, since what matters to us is that the URL now contains a query parameter called
code
. Copy this!Finally, uncomment the lines of code that we commented in
bin/md2gslides.js
and comment out theawait getAuthenticatedClient()
. You may revert theauthorizeUser()
function back to a sync function too.Now, re-run
node bin/md2gslides.js examples/example.md --use-fileio
. You should see the following prompt:examples/example.md
is the sample Markdown file provided in the source code to test conversion--use-fileio
enables the use of local files. (Even though I used the--use-fileio
flag, I was never able to get local images to work. So I deleted the![](image_slide.png)
on theexample.md
file before re-running the command, because this results in a runtime error)Thanks for following through! I'll try my best to create a fork with these code changes - but until then, best of luck with your slides!
The text was updated successfully, but these errors were encountered: