bullet_train-incoming_webhooks 1.0.1 → 1.0.2

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 4cca44c64cd5bbdf7bd18f914d3e24a7b4d2429ceb1c6afc1f10cc2378dfd267
4
- data.tar.gz: 0a446ad675c1e044c6b7d886a40f240cf2b04b11659ea168e18add4200e1bc30
3
+ metadata.gz: 841631804b153e610af2c14dcf42bb8d1eeab70553fb2bffbbb53ada8e220036
4
+ data.tar.gz: 2c4359e0e6a1b9b63d20a93e5861cf8b79089a04210fb1660890da8d758365b7
5
5
  SHA512:
6
- metadata.gz: 922ee62630cda4224cd8cb4a3794a4e801d0fd4802898f72595add7c5b935297ddcb04d07c1887c777c0184a45d8b655792fd6b7712dce3a5ce0447ef5083bb7
7
- data.tar.gz: 27cc13bcf8efb5f531aab7fc71c775af3a8278b83bea15f69049e4a24900a79c8d6d99be586305e5c42f06599fc3de77c8015c294b1d0606bbba9fc1f23613c2
6
+ metadata.gz: d8a194b7c27b8dbfe972143863fddb83c8be7bf5a1dd1fec25a49f5275e89ddc0918582d193cc237346abbf062c0fbdf34658837a4d789e96b8f5179a38d67c8
7
+ data.tar.gz: ae8331ebaf6460a674a06c03f0fc3c9c0f14e65219a351037ae48ea8c44b5f20cc966bceb0f400889b31c753e55775708424dc057ada9be3c9a5277c8fa041af
@@ -5,6 +5,7 @@ class Webhooks::Incoming::BulletTrainWebhook < ApplicationRecord
5
5
  # there are many ways a service might ask you to verify the validity of a webhook.
6
6
  # whatever that method is, you would implement it here.
7
7
  def verify_authenticity
8
+ # 🚅 skip this section when scaffolding.
8
9
  # trying to fix integration tests. if this fixes it, i don't know why puma won't accept another connection here.
9
10
  return true if Rails.env.test?
10
11
 
@@ -19,6 +20,7 @@ class Webhooks::Incoming::BulletTrainWebhook < ApplicationRecord
19
20
 
20
21
  # ensure that the payload on the server is the same as the payload we received.
21
22
  JSON.parse(response.body) == data
23
+ # 🚅 stop any skipping we're doing now.
22
24
  end
23
25
 
24
26
  def process
@@ -1,6 +1,15 @@
1
+ require "bullet_train/incoming_webhooks/scaffolders/incoming_webhooks_scaffolder"
2
+
1
3
  module BulletTrain
2
4
  module IncomingWebhooks
3
5
  class Engine < ::Rails::Engine
6
+ initializer "bullet_train.super_scaffolding.incoming_webhooks.templates.register_template_path" do |app|
7
+ # Register the base of this package with the Super Scaffolding engine.
8
+ BulletTrain::SuperScaffolding.template_paths << File.expand_path("../../../..", __FILE__)
9
+ BulletTrain::SuperScaffolding.scaffolders.merge!({
10
+ "incoming-webhooks" => "BulletTrain::IncomingWebhooks::Scaffolders::IncomingWebhooksScaffolder"
11
+ })
12
+ end
4
13
  end
5
14
  end
6
15
  end
@@ -0,0 +1,40 @@
1
+ require "scaffolding/incoming_webhooks_transformer"
2
+
3
+ module BulletTrain
4
+ module IncomingWebhooks
5
+ module Scaffolders
6
+ class IncomingWebhooksScaffolder < SuperScaffolding::Scaffolder
7
+ def run
8
+ unless argv.count >= 1
9
+ puts ""
10
+ puts "🚅 usage: bin/super-scaffold incoming-webhooks SomeProvider"
11
+ puts ""
12
+ puts "E.g. prepare to receive system-level webhooks from ClickFunnels"
13
+ puts " bin/super-scaffold incoming-webhooks ClickFunnels"
14
+ puts ""
15
+ standard_protip
16
+ puts ""
17
+ return
18
+ end
19
+
20
+ provider_name = argv.shift
21
+ transformer = Scaffolding::IncomingWebhooksTransformer.new(provider_name)
22
+
23
+ `yes n | bin/rails g model webhooks_incoming_#{provider_name.tableize.singularize}_webhook data:jsonb processed_at:datetime verified_at:datetime`
24
+
25
+ transformer.scaffold_incoming_webhook
26
+
27
+ puts ""
28
+ puts "1. To receive webhooks in your development environment, you'll need to configure a tunnel.".yellow
29
+ puts " See http://bullettrain.co/docs/tunneling for more information.".yellow
30
+ puts ""
31
+ puts "2. Once you have a tunnel running, you can configure the provider to deliver webhooks to:".yellow
32
+ puts " https://your-tunnel.ngrok.io/webhooks/incoming/#{provider_name.tableize}_webhooks".yellow
33
+ puts ""
34
+
35
+ transformer.restart_server
36
+ end
37
+ end
38
+ end
39
+ end
40
+ end
@@ -1,5 +1,5 @@
1
1
  module BulletTrain
2
2
  module IncomingWebhooks
3
- VERSION = "1.0.1"
3
+ VERSION = "1.0.2"
4
4
  end
5
5
  end
@@ -0,0 +1,98 @@
1
+ class Scaffolding::IncomingWebhooksTransformer < Scaffolding::Transformer
2
+ attr_accessor :provider_name
3
+
4
+ def initialize(provider_name, cli_options = {})
5
+ super("", "", cli_options)
6
+ self.provider_name = provider_name
7
+ end
8
+
9
+ def scaffold_incoming_webhook
10
+ files = [
11
+ "./app/models/webhooks/incoming/bullet_train_webhook.rb",
12
+ "./app/controllers/webhooks/incoming/bullet_train_webhooks_controller.rb"
13
+ ]
14
+
15
+ files.each do |name|
16
+ if File.directory?(resolve_template_path(name))
17
+ scaffold_directory(name)
18
+ else
19
+ scaffold_file(name)
20
+ end
21
+ end
22
+
23
+ # Rename files according to their provider name.
24
+ file_name_hook = "bullet_train_webhook"
25
+ new_model_file_name, new_controller_file_name = files.map { |file| file.gsub(file_name_hook, replacement_for(file_name_hook)) }
26
+ File.rename("./app/models/webhooks/incoming/bullet_train_webhook.rb", new_model_file_name)
27
+ File.rename("./app/controllers/webhooks/incoming/bullet_train_webhooks_controller.rb", new_controller_file_name)
28
+
29
+ # Since we eject the model from this repository, we don't need the
30
+ # extra model generated by `rails g model` (just the migration).
31
+ File.delete("./app/models/webhooks_incoming_#{replacement_for(file_name_hook)}.rb")
32
+
33
+ # Set up the model's `verify_authenticity` method to return `true`.
34
+ model_file_lines = File.readlines(new_model_file_name)
35
+ comment_lines = [
36
+ "# You can implement your authenticity verification logic in either\n",
37
+ "# the newly scaffolded model or controller for your incoming webhooks.\n"
38
+ ]
39
+ lines_to_ignore = [
40
+ " # there are many ways a service might ask you to verify the validity of a webhook.\n",
41
+ " # whatever that method is, you would implement it here.\n"
42
+ ]
43
+
44
+ model_file_lines = File.readlines(new_model_file_name)
45
+ new_model_file_lines = File.open(new_model_file_name).map.with_index do |line, idx|
46
+ if line.match?("def verify_authenticity")
47
+ indentation = Scaffolding::BlockManipulator.indentation_of(idx, model_file_lines)
48
+ new_comment_lines = comment_lines.map { |comment_line| "#{indentation}#{comment_line}" }.join
49
+
50
+ new_comment_lines +
51
+ "#{line}" \
52
+ "#{indentation} true\n"
53
+ elsif lines_to_ignore.include?(line)
54
+ next
55
+ else
56
+ line
57
+ end
58
+ end
59
+
60
+ Scaffolding::FileManipulator.write(new_model_file_name, new_model_file_lines)
61
+
62
+ # Apply new routes
63
+ begin
64
+ [
65
+ "config/routes.rb",
66
+ # "config/routes/api/v1.rb"
67
+ ].each do |routes_file|
68
+ # Since the webhooks routes don't live under a parent resource, we can't use the `apply` method to apply routes.
69
+ routes_manipulator = Scaffolding::RoutesFileManipulator.new(routes_file, "", "")
70
+ resources_line = " resources :#{replacement_for("bullet_train_webhooks")}"
71
+ new_routes_lines = Scaffolding::BlockManipulator.insert(resources_line, lines: routes_manipulator.lines, after: "namespace :incoming")
72
+ Scaffolding::FileManipulator.write(routes_file, new_routes_lines)
73
+ end
74
+ rescue BulletTrain::SuperScaffolding::CannotFindParentResourceException => exception
75
+ add_additional_step :red, "We were not able to generate the routes for your Incoming Webhook automatically because: \"#{exception.message}\" You'll need to add them manually, which admittedly can be complicated. See https://blog.bullettrain.co/nested-namespaced-rails-routing-examples/ for guidance. 🙇🏻‍♂️"
76
+ end
77
+ end
78
+
79
+ def transform_string(string)
80
+ [
81
+ "Webhooks::Incoming::BulletTrainWebhook"
82
+ ].each do |needle|
83
+ string = string.gsub(needle, replacement_for(needle))
84
+ end
85
+ string
86
+ end
87
+
88
+ def replacement_for(string)
89
+ case string
90
+ when "bullet_train_webhook"
91
+ "#{provider_name.tableize.singularize}_webhook"
92
+ when "bullet_train_webhooks"
93
+ "#{provider_name.tableize.singularize}_webhooks"
94
+ when "Webhooks::Incoming::BulletTrainWebhook"
95
+ "Webhooks::Incoming::#{provider_name}Webhook"
96
+ end
97
+ end
98
+ end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: bullet_train-incoming_webhooks
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.0.1
4
+ version: 1.0.2
5
5
  platform: ruby
6
6
  authors:
7
7
  - Andrew Culver
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2022-03-11 00:00:00.000000000 Z
11
+ date: 2022-11-24 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: rails
@@ -43,7 +43,9 @@ files:
43
43
  - config/routes.rb
44
44
  - lib/bullet_train/incoming_webhooks.rb
45
45
  - lib/bullet_train/incoming_webhooks/engine.rb
46
+ - lib/bullet_train/incoming_webhooks/scaffolders/incoming_webhooks_scaffolder.rb
46
47
  - lib/bullet_train/incoming_webhooks/version.rb
48
+ - lib/scaffolding/incoming_webhooks_transformer.rb
47
49
  - lib/tasks/bullet_train/incoming_webhooks_tasks.rake
48
50
  homepage: https://github.com/bullet-train-co/bullet_train-incoming_webhooks
49
51
  licenses:
@@ -66,7 +68,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
66
68
  - !ruby/object:Gem::Version
67
69
  version: '0'
68
70
  requirements: []
69
- rubygems_version: 3.2.22
71
+ rubygems_version: 3.3.7
70
72
  signing_key:
71
73
  specification_version: 4
72
74
  summary: Bullet Train Incoming Webhooks