name: heroku-deploy-stop-start on: workflow_dispatch: inputs: actions: description: "action: deploy/stop/start/destroy" default: "deploy" heroku-region: description: "us or eu. 如果你的app已经创建,切换到不同的region,需要先删除app" default: "us" heroku-app-name: description: "可选,如果输入,则会覆盖 Secrets 里面配置的 APP_NAME" default: "" required: false env: description: "environment: Input the name of Environment. If left blank, the main secrets setting will be used by default." default: "" jobs: jobenv: runs-on: ubuntu-latest environment: ${{ github.event.inputs.env}} outputs: actions: ${{ github.event.inputs.actions || 'deploy'}} heroku-app-name: ${{ github.event.inputs.heroku-app-name || secrets.APP_NAME }} test111: ${{ github.event.inputs.env }} # todo steps: - id: isDeployHeroku # TODO check atcion doc for usage # if: ${{ github.event.inputs.actions == 'start'}} run: echo "::set-output name=action::false" output-jobenv: runs-on: ubuntu-latest needs: jobenv steps: - id: test-env if: ${{ env.test-env }} run: echo needs.jobenv.outputs.deploy is ${{needs.jobenv.outputs.deploy}} - run: echo needs.jobenv.outputs.stop is ${{needs.jobenv.outputs.stop}} - run: echo needs.jobenv.outputs.start is ${{needs.jobenv.outputs.start}} - run: echo herokuEnv is ${{env.herokuEnv}} heroku-deploy: needs: jobenv if: ${{ needs.jobenv.outputs.actions == 'deploy' || needs.jobenv.outputs.actions == ''}} runs-on: ubuntu-latest environment: ${{ github.event.inputs.env }} steps: - run: echo APP_NAME is ${{env.heroku-app-name}} - uses: actions/checkout@v2 - uses: akhileshns/heroku-deploy@v3.12.12 # This is the action with: heroku_api_key: ${{secrets.HEROKU_API_KEY}} heroku_app_name: ${{needs.jobenv.outputs.heroku-app-name}} #Must be unique in Heroku heroku_email: ${{secrets.EMAIL}} usedocker: true region: ${{github.event.inputs.heroku-region || 'us'}} # docker_build_args: | # HD_UUID env: # 这是为了heroku,注意前缀有个HD,这是为了告诉heroku-deploy,这些变量需要传入到 container 中。 HD_UUID: ${{ secrets.HEROKU_V2RAY_UUID }} # UUID for v2ray user, 为了安全,一定要放入 github action token 中 HD_TUNNEL_TOKEN: ${{ secrets.HEROKU_TUNNEL_TOKEN }} # token for cloudflared tunnel NODE_ENV: production SECRET_KEY: ${{ secrets.MY_SECRET_KEY }} stop-start-destroy: needs: jobenv if: ${{ needs.jobenv.outputs.actions == 'start' || needs.jobenv.outputs.actions == 'stop' || needs.jobenv.outputs.actions == 'destroy' }} runs-on: ubuntu-latest environment: ${{ github.event.inputs.env }} steps: - uses: actions/checkout@v2 - uses: akhileshns/heroku-deploy@v3.7.8 # This is the action with: heroku_api_key: ${{secrets.HEROKU_API_KEY}} heroku_email: ${{secrets.EMAIL}} justlogin: true - run: | echo action is ${{ needs.jobenv.outputs.actions }} if [[ ${{ needs.jobenv.outputs.actions }} == 'stop' ]]; then heroku ps:scale web=0 -a ${{needs.jobenv.outputs.heroku-app-name}} && echo "stop"; fi if [[ ${{ needs.jobenv.outputs.actions }} == 'start' ]]; then heroku ps:scale web=1 -a ${{needs.jobenv.outputs.heroku-app-name}} && echo "start"; fi heroku ps -a ${{env.heroku-app-name}} if [[ ${{ needs.jobenv.outputs.actions }} == 'destroy' ]]; then heroku apps:destroy -a ${{needs.jobenv.outputs.heroku-app-name}} --confirm ${{env.heroku-app-name}} && echo "destroy app"; fi