Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: Large overhaul adding a more complete view of all the different entities in Pulumi Cloud #185

Open
wants to merge 44 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
44 commits
Select commit Hold shift + click to select a range
6aa29db
Split streams into orgs/stacks
sicarul Aug 12, 2024
9b0dba4
Merge pull request #1 from pulumi/branch-pablo
sicarul Aug 12, 2024
3a0f156
Add stack details and resources
sicarul Aug 12, 2024
4688cae
Merge pull request #2 from pulumi/update-stacks
sicarul Aug 12, 2024
62350d8
Add stack policy groups and policy packs
sicarul Aug 12, 2024
8e7b490
Merge pull request #3 from pulumi/add-stack-policies
sicarul Aug 12, 2024
d402558
add policy group streams
lucascrespo88 Aug 12, 2024
c798a46
rename policy group streams to remove organization prefix
lucascrespo88 Aug 12, 2024
d36ced2
Merge pull request #4 from pulumi/add_policy_pack_streams
lucascrespo88 Aug 12, 2024
3903044
Add stack previews and change updates to service format
sicarul Aug 13, 2024
9033232
add policy pack and enviroment streams
lucascrespo88 Aug 13, 2024
5db6bfe
Merge pull request #5 from pulumi/add-stack-updates-previews
sicarul Aug 13, 2024
2116f7b
fix environments description
lucascrespo88 Aug 13, 2024
08a1387
Merge pull request #6 from pulumi/add_policy_pack_streams
lucascrespo88 Aug 13, 2024
6fc7770
Add deployments and set default items per page to 100
sicarul Aug 13, 2024
82c19a8
Merge pull request #7 from pulumi/add-deployments
sicarul Aug 13, 2024
1a729f7
Add team details
sicarul Aug 13, 2024
a542b2b
Add team access tokens
sicarul Aug 13, 2024
e3d53dd
Merge pull request #8 from pulumi/add-team-details
sicarul Aug 13, 2024
815e406
Add webhooks
sicarul Aug 13, 2024
16feaff
added org name to envs and OIDC Issuers and RUM usage streams added
lucascrespo88 Aug 13, 2024
8147b48
fix commenting
lucascrespo88 Aug 13, 2024
91f5a68
fix space
lucascrespo88 Aug 13, 2024
c078a14
Merge pull request #9 from pulumi/add-webhooks
sicarul Aug 13, 2024
71409e1
Merge branch 'main' into add_issuers_streams
lucascrespo88 Aug 13, 2024
1252510
Merge pull request #10 from pulumi/add_issuers_streams
lucascrespo88 Aug 13, 2024
2407fd1
Add audit logs
sicarul Aug 13, 2024
e7a213e
Agent Pool Stream Added
lucascrespo88 Aug 13, 2024
6cd0126
Merge pull request #11 from pulumi/add-audit-logs
sicarul Aug 13, 2024
60a95e0
Merge pull request #12 from pulumi/add_agent_pool_stream
lucascrespo88 Aug 13, 2024
924c78b
Integrity fixes needed to target-duckdb to work
sicarul Aug 13, 2024
a5dad6a
Merge pull request #13 from pulumi/fixes-for-integrity
sicarul Aug 13, 2024
e02ca2d
Handle 504 gateway timeout error for stack previews endpoint
sicarul Aug 13, 2024
9b5c86e
Merge pull request #14 from pulumi/handle-504-on-stack-previews
sicarul Aug 13, 2024
7b61b21
add Stack Schedules and Stack Schedules deployment history Streams
lucascrespo88 Aug 14, 2024
e3e6627
Merge pull request #15 from pulumi/add_schedule_streams
lucascrespo88 Aug 14, 2024
b3d7845
Merge branch 'main' into main
sicarul Aug 14, 2024
4a003e8
Fix linting
sicarul Aug 14, 2024
e12f1c0
Merge pull request #16 from pulumi/fix-linting
sicarul Aug 14, 2024
4c3bbc4
Start date is now required
sicarul Aug 14, 2024
afa2a83
Let tests run
edgarrmondragon Aug 14, 2024
f5d43f7
Merge pull request #17 from MeltanoLabs/pr-185-suggestions
sicarul Aug 15, 2024
857d88a
fix resource hours field name
lucascrespo88 Aug 15, 2024
3109ef0
Merge pull request #19 from pulumi/fix_resource_hours_field
sicarul Aug 15, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Add webhooks
  • Loading branch information
sicarul committed Aug 13, 2024
commit 815e4061b9c64fe3b0b37b46892511b30fbddde2
6 changes: 5 additions & 1 deletion tap_pulumi_cloud/tap.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
from singer_sdk import Stream, Tap
from singer_sdk import typing as th

from tap_pulumi_cloud import organizations, stacks, policies, environments
from tap_pulumi_cloud import organizations, stacks, policies, environments, webhooks


class TapPulumiCloud(Tap):
Expand Down Expand Up @@ -98,5 +98,9 @@ def discover_streams(self) -> list[Stream]:
policies.PolicyPacks(tap=self),
policies.LatestPolicyPacks(tap=self),
environments.Environments(tap=self),
webhooks.OrganizationWebhooks(tap=self),
webhooks.OrganizationWebhookDeliveries(tap=self),
webhooks.StackWebhooks(tap=self),
webhooks.StackWebhookDeliveries(tap=self),

]
312 changes: 312 additions & 0 deletions tap_pulumi_cloud/webhooks.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,312 @@
"""Stream type classes for tap-pulumi-cloud."""

from __future__ import annotations

import typing as t

from singer_sdk import typing as th

from tap_pulumi_cloud.client import PulumiCloudStream, _OrgPartitionedStream
from tap_pulumi_cloud import stacks

class OrganizationWebhooks(_OrgPartitionedStream):
"""Stream Organization Webhooks."""

name = "organization_webhooks"
path = "/api/orgs/{org_name}/hooks"
primary_keys = ["org_name", "name"]
records_jsonpath = "$[*]"

schema = th.PropertiesList(
th.Property(
"org_name",
th.StringType,
description="The name of the organization."
),
th.Property(
"name",
th.StringType,
description="The name of the webhook."
),
th.Property(
"display_name",
th.StringType,
description="The display name of the webhook."
),
th.Property(
"payload_url",
th.StringType,
description="The URL to which the webhook will send payloads."
),
th.Property(
"format",
th.StringType,
description="The format of the webhook payload, e.g. raw, slack, ms_teams."
),
th.Property(
"active",
th.BooleanType,
description="Whether the webhook is active."
)
).to_dict()


def get_child_context(
self,
record: dict,
context: dict | None, # noqa: ARG002
) -> dict | None:
"""Return a context object for child streams.

Args:
record: A record from this stream.
context: The stream sync context.

Returns:
A context object for child streams.
"""
return {
"webhook_name": record["name"],
"org_name": record["org_name"],

}

class OrganizationWebhookDeliveries(PulumiCloudStream):
"""Organization Webhook deliveries stream."""

name = "organization_webhook_deliveries"
path = "/api/orgs/{org_name}/hooks/{webhook_name}/deliveries"
primary_keys = ["org_name", "webhook_name", "id"]
records_jsonpath = "$[*]"

parent_stream_type = OrganizationWebhooks

schema = th.PropertiesList(
th.Property(
"org_name",
th.StringType,
description="The name of the organization."
),
th.Property(
"webhook_name",
th.StringType,
description="The name of the webhook."
),
th.Property(
"id",
th.StringType,
description="The ID of the delivery."
),
th.Property(
"kind",
th.StringType,
description="The kind of the delivery."
),
th.Property(
"payload",
th.StringType,
description="The payload of the delivery."
),
th.Property(
"timestamp",
th.IntegerType,
description="The timestamp of the delivery."
),
th.Property(
"duration",
th.IntegerType,
description="The duration of the delivery."
),
th.Property(
"request_url",
th.StringType,
description="The URL of the request."
),
th.Property(
"request_headers",
th.StringType,
description="The headers of the request."
),
th.Property(
"response_code",
th.IntegerType,
description="The response code of the delivery."
),
th.Property(
"response_headers",
th.StringType,
description="The headers of the response."
),
th.Property(
"response_body",
th.StringType,
description="The body of the response."
)
).to_dict()



class StackWebhooks(PulumiCloudStream):
"""Stream Organization Webhooks."""

name = "stack_webhooks"
path = "/api/stacks/{org_name}/{project_name}/{stack_name}/hooks"
primary_keys = ["org_name", "project_name", "stack_name", "name"]
records_jsonpath = "$[*]"

parent_stream_type = stacks.Stacks

schema = th.PropertiesList(
th.Property(
"org_name",
th.StringType,
description="The name of the organization."
),
th.Property(
"project_name",
th.StringType,
description="The name of the project.",
),
th.Property(
"stack_name",
th.StringType,
description="The name of the stack.",
),
th.Property(
"name",
th.StringType,
description="The name of the webhook."
),
th.Property(
"display_name",
th.StringType,
description="The display name of the webhook."
),
th.Property(
"payload_url",
th.StringType,
description="The URL to which the webhook will send payloads."
),
th.Property(
"format",
th.StringType,
description="The format of the webhook payload, e.g. raw, slack, ms_teams."
),
th.Property(
"filters",
th.ArrayType(th.StringType),
description="The filters for the webhook."
),
th.Property(
"active",
th.BooleanType,
description="Whether the webhook is active."
)
).to_dict()

def get_child_context(
self,
record: dict,
context: dict | None, # noqa: ARG002
) -> dict | None:
"""Return a context object for child streams.

Args:
record: A record from this stream.
context: The stream sync context.

Returns:
A context object for child streams.
"""
return {
"org_name": record["org_name"],
"project_name": record["project_name"],
"stack_name": record["stack_name"],
"webhook_name": record["name"],

}



class StackWebhookDeliveries(PulumiCloudStream):
"""Stack Webhook deliveries stream."""

name = "stack_webhook_deliveries"
path = "/api/stacks/{org_name}/{project_name}/{stack_name}/hooks/{webhook_name}/deliveries"
primary_keys = ["org_name", "project_name", "stack_name", "webhook_name", "id"]
records_jsonpath = "$[*]"

parent_stream_type = StackWebhooks

schema = th.PropertiesList(
th.Property(
"org_name",
th.StringType,
description="The name of the organization."
),
th.Property(
"project_name",
th.StringType,
description="The name of the project.",
),
th.Property(
"stack_name",
th.StringType,
description="The name of the stack.",
),
th.Property(
"webhook_name",
th.StringType,
description="The name of the webhook."
),
th.Property(
"id",
th.StringType,
description="The ID of the delivery."
),
th.Property(
"kind",
th.StringType,
description="The kind of the delivery."
),
th.Property(
"payload",
th.StringType,
description="The payload of the delivery."
),
th.Property(
"timestamp",
th.IntegerType,
description="The timestamp of the delivery."
),
th.Property(
"duration",
th.IntegerType,
description="The duration of the delivery."
),
th.Property(
"request_url",
th.StringType,
description="The URL of the request."
),
th.Property(
"request_headers",
th.StringType,
description="The headers of the request."
),
th.Property(
"response_code",
th.IntegerType,
description="The response code of the delivery."
),
th.Property(
"response_headers",
th.StringType,
description="The headers of the response."
),
th.Property(
"response_body",
th.StringType,
description="The body of the response."
)
).to_dict()