Git Product home page Git Product logo

Comments (40)

sovcik avatar sovcik commented on May 6, 2024 12

Summarizing:

  1. There is a difference between version and deployment. A version is similar to a git tag, while a deployment is actual code available for execution and accessible at https://script.google.com/macros/s/{deploymentID}/exec
  2. list of available deployments can be obtained by running clasp deployments
  3. there is always only one published deployment which is available for end-users. The published deployment is is flagged as web app meta-version in the list of deployments.
  4. clasp deploy creates new deployment if no deploymentId is specified and creates new version if no version is specified
  5. new deployments are useful for testing before making them default (using link mentioned in point 1)
  6. in order to make version available for end-users you have to publish it by deploying it into published deployment by running
    clasp --deploymentId {published_deployment_id} --version {selected_version_here}

So the process:

  1. use clasp deployments and
    1. select one deployment you will use for testing => test_deployment_id
    2. get published deployment (one having web app meta-version flag) => pub_deployment_id
  2. modify your code
  3. clasp push
  4. clasp deploy --deploymentId $test_deployment_id creates version => new_version
  5. test your version at
    https://script.google.com/macros/s/{test_deployment_id}/exec
  6. if satisfied, deploy your version into published deployment
    clasp deploy --deploymentId $pub_deployment_id --versionNumber $new_version

So, in the end it looks that clasp deploy works as designed. What's missing is the documentation :-)

from clasp.

grant avatar grant commented on May 6, 2024 6

It looks like the script.google.com UI updates the manifest file (appsscript.json) file when you use the UI to publish a web app.

When you use the UI to deploy a web app, it adds this bit of code to appsscript.json:

  "webapp": {
    "access": "MYSELF",
    "executeAs": "USER_DEPLOYING"
  }

This is really important, as it's the configuration details of the web app.

So if you are using clasp, and expect to deploy a web app, you must manually update the manifest file.

Repro

Create the project with clasp

  1. clasp create
  2. clasp open
  3. View > Show manifest file
  4. Observe the manifest is updated
{
  "timeZone": "America/New_York",
  "dependencies": {
  },
  "webapp": {
    "access": "MYSELF",
    "executeAs": "USER_DEPLOYING"
  },
  "exceptionLogging": "STACKDRIVER"
}

Setup other web app files

index.html

<!DOCTYPE html>
<html>
  <head>
    <base target="_top">
  </head>
  <body>
    hi
  </body>
</html>

test.gs

function doGet() {
    return HtmlService
      .createTemplateFromFile('index')
      .evaluate();
}
  1. clasp push
  2. clasp deploy
    1. Copy the long id
  3. Go to the URL, it should be something like this:
    https://script.google.com/a/{DOMAIN}/macros/s/{VERSION_ID}/exec
  4. See the successful deployment of a web app.

Follow-up

Good news (if this is correct): clasp isn't doing anything wrong.
Bad news: It's really not obvious why creating a web app with clasp fails.

I think a good solution would be to enhance the setup experience around starting a new add-on/web app/script. Some ideas were thrown around in #76, but it seemed out of scope for the clasp project.

We should at least give README tips on how to start with creating the 3 types of scripts to prevent this error.

from clasp.

jooohn avatar jooohn commented on May 6, 2024 6

I'm developing an API executable, and encountered a similar issue.

I can create deployments via clasp, but I can't run these deployed API until I manually update the version via web console.

image

(new deployments exist, but not selected.)

image

Are there ways to update the published version via clasp?

from clasp.

NicolaSpreafico avatar NicolaSpreafico commented on May 6, 2024 6

I found this trick working for deploy a new version of webapp.

clasp deployments

  • Select the version (if exists ) where there is web app meta-version attribute
  • I attribute is not found, use the last deployment id
LAST_DEPLOYMENT_ID=$( clasp deployments | pcregrep -o1 '\- ([A-Za-z0-9\-\_]+) @\d+ - web app meta-version' )
	if [ -z "$LAST_DEPLOYMENT_ID" ]
	then
		LAST_DEPLOYMENT_ID=$( clasp deployments | tail -1 | pcregrep -o1 '\- ([A-Za-z0-9\-\_]+)' ) 
	fi

After selecting deploment ID, proceed with

clasp deploy --deploymentId $LAST_DEPLOYMENT_ID

I found that web app meta-version attribute only appaers when web-app application is update from AppsScript code editor, so we need to consider the deploymentIDs order to get the proper version.
Also the webapp should remain published to last existing version or the "select last row" trick will not work.

I tried a couple of times and seems to work, you can try and test as well.

from clasp.

grant avatar grant commented on May 6, 2024 3

I don't think adding more CLI flags to clasp will help. clasp should work out of the box. A type should really be for create.

clasp create
What type of project do you want to create?
x Standalone
- Add-on
- Web App

# Advanced way
clasp create --type standalone
clasp create --type addon --docs
clasp create --type webapp

What we really need is more of the following:

  • Warn when clasp push would override files. This is probably what happened here with the appsscript.json being overwritten.
  • Improve clasp create to provide options for creating an add-on, executable, or web app. See above.
  • Improve the process of creating a manifest. It would be great if there was autocompletion support. This is like package.json for Node modules.

from clasp.

brianchul avatar brianchul commented on May 6, 2024 3

It seems that clasp deploy a new deployment ID when not specified deployment ID with -i parameter.
So if your just updating a web app using latest code, just get url from apps script website
which like this https://script.google.com/macros/s/{deploymentID}/exec
and specify -i parameter with deploymentID when new code deploy
example command: clasp push && clasp deploy -i deploymentID

from clasp.

campionfellin avatar campionfellin commented on May 6, 2024 2

Is it possible, and/or a good idea to have some sort of flag for clasp deploy like --type (web|api) that adds that to the appsscript.json for the user?

from clasp.

grant avatar grant commented on May 6, 2024 2

So I've just tested that workflow and it does push the deployment up (which was working originally as well) - but it also doesn't make it active as the published project version.

Meaning that you still need to go to the UI and make the project version the one you just deployed :-(

I added the API support label because it looks like the UI does something different the API cannot do yet.

from clasp.

grant avatar grant commented on May 6, 2024 2

FYI: clasp redeploy has been removed in favor of clasp deploy with -- arguments.

from clasp.

pablodonayre avatar pablodonayre commented on May 6, 2024 1

When i use: clasp redeploy <id of deployment> <version> <description>
I get "Updated deployment" in my terminal

But, when i refresh the web browser (F5) i get an error message "Se necesita autorizaciΓ³n para realizar esta acciΓ³n" (You need authorization to perform this action) in the browser.

Also, my previous config was:
Deploy as a web app
Execute the app: As me
Who has access to the app: Anyone, even anonymous

How to send this two config options with a command, and how to solve my issue with the authorization?

from clasp.

shai avatar shai commented on May 6, 2024 1

@grant can you shade some light on where we are with this issue? I would LOVE to be able to deploy a new web-app version when I push my updates. I dislike having to need to go to the WEB UI to deploy that new version of my web-app.

from clasp.

satetsu888 avatar satetsu888 commented on May 6, 2024 1

I found out the way to update the published web app endpoint by clasp.

We should use redeploy to update exists application ( I think we expect it is "deploy" and confusing ).

The function clasp deploy wraps create deployments API, and it always create new endpoints.
https://developers.google.com/apps-script/api/reference/rest/v1/projects.deployments/create

We just need

  • setup appsscript.json
  • clasp deploy only first time
  • clasp version and crasp redeploy to update like #63 (comment)

from clasp.

RomainVialard avatar RomainVialard commented on May 6, 2024 1

Also note that when you manually deploy as a web app your project (using the "Deploy as web app" menu entry), it automatically generates a new deployment (or update the existing deployment if you update your web app).
This specific deployment is automatically named by Apps Script "web app meta-version", you can grab its ID and then reuse it to update this specific deployment with Clasp.
This way, the UI will stay in sync, meaning you will be able to deploy either manually (using the "Deploy as web app" menu entry) or programmatically.

from clasp.

freddy-daniel avatar freddy-daniel commented on May 6, 2024 1

I think you want to redeploy to update a deployment:
clasp redeploy <deploymentId> <version> <description>
Is that right?

I think I forgot to add it in the "How To..." section. LMK if that works.

C:\Users\Freddy\Desktop\gmail add-on  ([email protected])
Ξ» clasp redeploy AKfycbzwBPYA5QYbALsLecxp5_OuOxCrbBKzs78D8XDs9m3kDg2DSvCG-fyNG82ssSoOSDM7gg 1 Test
πŸ€”  Unknown command "clasp redeploy"

Forgot clasp commands? Get help:
  clasp --help

from clasp.

kpoman avatar kpoman commented on May 6, 2024 1

Apparently, when we execute clasp deploy, the command forgets to create an entry point to the webapp. See below:

Entry points after deploying from clasp:

    {
      "deploymentId": "AKfycbwGoFhpo5qekznUEn9z4Crt9BtFz0ubDsjK9sNlcJz0xTroscdU",
      "deploymentConfig": {
        "scriptId": "1jeLVzVdwPdBX5prcwCUeTc4nkQ8XAxFSd7QcuJJ96MB_UozF0iUMShiO",
        "versionNumber": 251,
        "manifestFileName": "appsscript",
        "description": "web app meta-version"
      },
      "updateTime": "2020-06-23T08:08:57.828Z",
      "entryPoints": [
        {
          "entryPointType": "EXECUTION_API",
          "executionApi": {
            "entryPointConfig": {
              "access": "ANYONE"
            }
          }
        }
      ]
    }

Entry points after deploying from the Script Editor:

{
      "deploymentId": "AKfycbwGoFhpo5qekznUEn9z4Crt9BtFz0ubDsjK9sNlcJz0xTroscdU",
      "deploymentConfig": {
        "scriptId": "1jeLVzVdwPdBX5prcwCUeTc4nkQ8XAxFSd7QcuJJ96MB_UozF0iUMShiO",
        "versionNumber": 251,
        "manifestFileName": "appsscript",
        "description": "web app meta-version"
      },
      "updateTime": "2020-06-23T08:10:12.540Z",
      "entryPoints": [
        {
          "entryPointType": "WEB_APP",
          "webApp": {
            "url": "https://script.google.com/macros/s/AKfycbwGoFhpo5qekznUEn9z4Crt9BtFz0ubDsjK9sNlcJz0xTroscdU/exec",
            "entryPointConfig": {
              "access": "ANYONE_ANONYMOUS",
              "executeAs": "USER_DEPLOYING"
            }
          }
        },
        {
          "entryPointType": "EXECUTION_API",
          "executionApi": {
            "entryPointConfig": {
              "access": "ANYONE"
            }
          }
        }
      ]
    }

This is why we get a Drive Error when, after deploy from clasp, we try to enter the /dev page.

referenced here: googleapis/google-api-python-client#866

from clasp.

grant avatar grant commented on May 6, 2024

I think you want to redeploy to update a deployment:
clasp redeploy <deploymentId> <version> <description>
Is that right?

I think I forgot to add it in the "How To..." section. LMK if that works.

from clasp.

andysumi avatar andysumi commented on May 6, 2024

@grant
I am experiencing the same phenomenon.
Can note update version of Web App with "clasp deploy".

from clasp.

grant avatar grant commented on May 6, 2024

@andysumi What are the commands you're using? Use redeploy to update, deploy to create.

from clasp.

andysumi avatar andysumi commented on May 6, 2024

@grant
I used both command, but it did not work as expected.

$ clasp version deploy-from-clasp
Created version 4.
$ clasp deploy 4 deploy-from-clasp
- [deploymentId] @4.
$ clasp open
Opening script: [scriptId]

===> I expected version of WebApp it was updated to "4", but it was not updated(it remained "3").

$ clasp redeploy [deploymentId] 4 deploy-from-clasp-again
Updated deployment.
$ clasp open
Opening script: [scriptId]

===> Again, the version of WebApp was not updated.

from clasp.

jhairau avatar jhairau commented on May 6, 2024

@grant @andysumi @onlinelaser
I've also used both commands.

True: There is a new version deployed on the Google Apps Scripts
False: There is NOT a new Web App version deployed on Google Apps Scripts

from clasp.

grant avatar grant commented on May 6, 2024

This may be an issue with the API. I'll have to look further.

from clasp.

onlinelaser avatar onlinelaser commented on May 6, 2024

@grant sorry for the delay, finally got back to testing this, and I can also confirm that neither deploy nor deploy followed immediately by a redeploy make the new deployment active 😞

from clasp.

Ryangr0 avatar Ryangr0 commented on May 6, 2024

We have the same problem.

from clasp.

iaindooley avatar iaindooley commented on May 6, 2024

It doesn't appear that clasp deploy can be used to update a web application, and also can't be used to approve permissions and things like that. This would be a very useful addition. At the moment, the "Deploy as Web Application" is the only step in the development process that requires a desktop browser.

from clasp.

TrojanCoder avatar TrojanCoder commented on May 6, 2024

@shai If I'm reading this ticket correctly you should be able to do everything without the WEB UI, it's just not super clear because you'll need to manually update your appscript.json file. Here are the valid options:

"webapp": {
    "access": "MYSELF",
    "access": "ANYONE",
    "executeAs": "USER_DEPLOYING"
    "executeAs": "USER_ACCESSING"
    "executeAs": "ANYONE_ANONYMOUS"
  },

You need to pick one of the "acces" types and one of the "executeAs" types. Note that "ANYONE_ANONYMOUS" can only be used with "executeAs" type "USER_DEPLOYING"

from clasp.

shai avatar shai commented on May 6, 2024

@TrojanCoder I've actually got this already:

  "webapp": {
    "access": "ANYONE_ANONYMOUS",
    "executeAs": "USER_DEPLOYING"
  },

and when I clasp deploy it says that it deployed a new version but when I go to publish -> deploy as web app ; I see that it's using the old version. Also, when I go and test the code, I see that I'm not getting the updated expected console logs of the newer version.

from clasp.

grant avatar grant commented on May 6, 2024

I just tested the steps I wrote above again. Deploying a web app from clasp works. You just need to make sure you update the appsscript.json, clasp push, and clasp deploy.

Steps: #63 (comment)

Set up and deploy a web app

clasp clone 1kDaDgJUTxkVmr7TkPSqx2wjxMhiY3DH1v_nZfpdkdsPcy2Lfo-09onYz
Cloned 2 files.
└─ appsscript.json
└─ Code.js
vi appsscript.json # add the `access` and `executeAs` fields.
vi index.html # write an HTML skeleton with "hi"
vi Code.js

clasp push
└─ Code.js
└─ appsscript.json
└─ index.html
Pushed 3 files.

clasp deploy
Created version 1.
- AKfycbwP6WvBwvNI3m_d3Ts8bnYBX8y0lG7OQEuV65m2E6t3J44g9Cay8wGZ2JRfQ9mHcpI1 @1.

Go to
https://script.google.com/a/{YOUR_DOMAIN}/macros/s/AKfycbwP6WvBwvNI3m_d3Ts8bnYBX8y0lG7OQEuV65m2E6t3J44g9Cay8wGZ2JRfQ9mHcpI1/exec

See the page: "hi"

Deploy Again

vi index.html # write an HTML skeleton with "hi 2"
clasp push
clasp version
clasp deploy 2

Go to the new URL.
See the page: "hi2"


I haven't tested redeploy, but deploying a web app multiple times should work.

from clasp.

onlinelaser avatar onlinelaser commented on May 6, 2024

So I've just tested that workflow and it does push the deployment up (which was working originally as well) - but it also doesn't make it active as the published project version.

Meaning that you still need to go to the UI and make the project version the one you just deployed :-(

from clasp.

shai avatar shai commented on May 6, 2024

so I'm unsure about why it's working for some and not others? @grant if you last comment you said and showed that it works, but @onlinelaser and myself say it isn't and then you added the API support needed label which implies it doesn't work?

Should I keep trying to get it working or did you verify that it isn't working and we need to wait for a solution?

from clasp.

lgordey avatar lgordey commented on May 6, 2024

Any news here?

I created an issue #286 about deploy, seems to be a duplicate

from clasp.

rheajt avatar rheajt commented on May 6, 2024

The confusion that I ran into was getting the correct deploymentId to use with clasp deploy.

You need to got to "Publish > Deploy from Manifest" and Get ID of the deployment you want to use.

Then use clasp deploy -i <<ID from the manifest>>

from clasp.

zffocussss avatar zffocussss commented on May 6, 2024

Also note that when you manually deploy as a web app your project (using the "Deploy as web app" menu entry), it automatically generates a new deployment (or update the existing deployment if you update your web app).
This specific deployment is automatically named by Apps Script "web app meta-version", you can grab its ID and then reuse it to update this specific deployment with Clasp.
This way, the UI will stay in sync, meaning you will be able to deploy either manually (using the "Deploy as web app" menu entry) or programmatically.

how do I deloy programmatically?

from clasp.

zffocussss avatar zffocussss commented on May 6, 2024

I just tested the steps I wrote above again. Deploying a web app from clasp works. You just need to make sure you update the appsscript.json, clasp push, and clasp deploy.

Steps: #63 (comment)

Set up and deploy a web app

clasp clone 1kDaDgJUTxkVmr7TkPSqx2wjxMhiY3DH1v_nZfpdkdsPcy2Lfo-09onYz
Cloned 2 files.
└─ appsscript.json
└─ Code.js
vi appsscript.json # add the `access` and `executeAs` fields.
vi index.html # write an HTML skeleton with "hi"
vi Code.js

clasp push
└─ Code.js
└─ appsscript.json
└─ index.html
Pushed 3 files.

clasp deploy
Created version 1.
- AKfycbwP6WvBwvNI3m_d3Ts8bnYBX8y0lG7OQEuV65m2E6t3J44g9Cay8wGZ2JRfQ9mHcpI1 @1.

Go to
https://script.google.com/a/{YOUR_DOMAIN}/macros/s/AKfycbwP6WvBwvNI3m_d3Ts8bnYBX8y0lG7OQEuV65m2E6t3J44g9Cay8wGZ2JRfQ9mHcpI1/exec

See the page: "hi"

Deploy Again

vi index.html # write an HTML skeleton with "hi 2"
clasp push
clasp version
clasp deploy 2

Go to the new URL.
See the page: "hi2"

I haven't tested redeploy, but deploying a web app multiple times should work.

what is difference between deploy and publish?
I just use clasp deploy.but How can I publish this new version to chrome web store?

from clasp.

darul75 avatar darul75 commented on May 6, 2024

hello, what about a google sheets addon, is the deploy option updating a published version?

from clasp.

zffocussss avatar zffocussss commented on May 6, 2024

hello, what about a google sheets addon, is the deploy option updating a published version?

I think there is no difference between sheet and doc.clasp deploy will create a new version number and deploymentId,but you must choose the deplomentID and publish manually

from clasp.

kpoman avatar kpoman commented on May 6, 2024
  • https://script.google.com/macros/s/{test_deployment_id}/exec

When I deploy my test_deployment_id and tries to open it on the browser, it redirects to
https://script.google.com/a/macros/safewebmed.com.br/s/{test_deployment_id}/exec
and shows an error page:
Sorry, unable to open the file at this time.

Please check the address and try again.

Get stuff done with Google Drive

Apps in Google Drive make it easy to create, store and share online documents, spreadsheets, presentations and more.

Learn more at drive.google.com/start/apps.

from clasp.

vuGitH avatar vuGitH commented on May 6, 2024

regarding @sovcik Summarizing
in item 6 of first ordered list

  1. in order to make version available for end-users you have to publish it by deploying it into published deployment by running
    clasp --deploymentId {published_deployment_id} --version {selected_version_here}

sub-command deploy is occasionally omitted after clasp, Presumably:

clasp deploy --deploymentId {published_deployment_id} --version {selected_version_here}

from clasp.

kpoman avatar kpoman commented on May 6, 2024
  1. test your version at
    https://script.google.com/macros/s/{test_deployment_id}/exec

after doing that step, the browser autoredirects to https://script.google.com/a/macros/mydomain.com/s/{test_deployment_id}/exec
and the page shows this error:

Sorry, unable to open the file at this time.
Please check the address and try again.

Would really like to get this working.

from clasp.

Yancy-Godoy avatar Yancy-Godoy commented on May 6, 2024
  • https://script.google.com/macros/s/{test_deployment_id}/exec

When I deploy my test_deployment_id and tries to open it on the browser, it redirects to https://script.google.com/a/macros/safewebmed.com.br/s/{test_deployment_id}/exec and shows an error page: Sorry, unable to open the file at this time.

Please check the address and try again.

Get stuff done with Google Drive

Apps in Google Drive make it easy to create, store and share online documents, spreadsheets, presentations and more.

Learn more at drive.google.com/start/apps.

I started using Clasp today and can confirm this issue still persists (following same steps) to this day. Any workaround available for this?

from clasp.

anbuchelva avatar anbuchelva commented on May 6, 2024

somehow i found the solution for this.
The expected behavior:

  • Let's say, the existing deployment id is "AKfycbwGoFhpo5qekznUEn9z4Crt9BtFz0ubDsjK9sNlcJz0xTroscdU"
  • last deployed version is 25

I want to deploy the app with the same deployment ID but a new version.
when we do clasp deploy it generates a new deployment ID and a new version, which is not the expected behavior, as we don't want a new deployment ID.

The right way:
clasp version && clasp deploy -i AKfycbwGoFhpo5qekznUEn9z4Crt9BtFz0ubDsjK9sNlcJz0xTroscdU -V 26

  • clasp version will create the next version (25 -> 26) but doesn't deploy the app.
  • clasp deploy -i <deployment ID> -V <version number> command is to redeploy app with same deployment ID and with the existing version, which we created using clasp version

from clasp.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    πŸ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. πŸ“ŠπŸ“ˆπŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❀️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.