2024-03-14 15:28:32 +00:00
|
|
|
// Copyright 2016-2023, Pulumi Corporation.
|
2018-05-22 19:43:36 +00:00
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
2017-03-03 01:10:10 +00:00
|
|
|
|
|
|
|
package resource
|
|
|
|
|
2024-03-14 15:28:32 +00:00
|
|
|
// The contents of this file have been moved. The logic behind URN now lives in
|
|
|
|
// "github.com/pulumi/pulumi/sdk/v3/go/common/resource/urn". This file exists to fulfill
|
|
|
|
// backwards-compatibility requirements. No new declarations should be added here.
|
2017-03-03 01:10:10 +00:00
|
|
|
|
2024-03-14 15:28:32 +00:00
|
|
|
import (
|
|
|
|
"github.com/pulumi/pulumi/sdk/v3/go/common/resource/urn"
|
2021-03-17 13:20:05 +00:00
|
|
|
"github.com/pulumi/pulumi/sdk/v3/go/common/tokens"
|
2017-03-03 01:10:10 +00:00
|
|
|
)
|
|
|
|
|
2018-03-04 21:34:20 +00:00
|
|
|
// URN is a friendly, but unique, URN for a resource, most often auto-assigned by Pulumi. These are
|
2017-12-04 22:50:55 +00:00
|
|
|
// used as unique IDs for objects, and help us to perform graph diffing and resolution of resource
|
|
|
|
// objects.
|
2017-03-03 01:10:10 +00:00
|
|
|
//
|
2017-12-04 22:50:55 +00:00
|
|
|
// In theory, we could support manually assigned URIs in the future. For the time being, however,
|
|
|
|
// we have opted to simplify developers' lives by mostly automating the generation of them
|
|
|
|
// algorithmically. The one caveat where it isn't truly automatic is that a developer -- or
|
|
|
|
// resource provider -- must provide a semi-unique name part.
|
2017-03-03 01:10:10 +00:00
|
|
|
//
|
|
|
|
// Each resource URN is of the form:
|
|
|
|
//
|
2022-09-14 02:12:02 +00:00
|
|
|
// urn:pulumi:<Stack>::<Project>::<Qualified$Type$Name>::<Name>
|
2017-03-03 01:10:10 +00:00
|
|
|
//
|
|
|
|
// wherein each element is the following:
|
|
|
|
//
|
2022-09-14 02:12:02 +00:00
|
|
|
// <Stack> The stack being deployed into
|
|
|
|
// <Project> The project being evaluated
|
|
|
|
// <Qualified$Type$Name> The object type's qualified type token (including the parent type)
|
|
|
|
// <Name> The human-friendly name identifier assigned by the developer or provider
|
2017-03-03 01:10:10 +00:00
|
|
|
//
|
2017-12-04 22:50:55 +00:00
|
|
|
// In the future, we may add elements to the URN; it is more important that it is unique than it is
|
|
|
|
// human-typable.
|
2024-03-14 15:28:32 +00:00
|
|
|
type URN = urn.URN
|
2017-03-03 01:10:10 +00:00
|
|
|
|
|
|
|
const (
|
2024-03-14 15:28:32 +00:00
|
|
|
URNPrefix = urn.Prefix // the standard URN prefix
|
|
|
|
URNNamespaceID = urn.NamespaceID // the URN namespace
|
|
|
|
URNNameDelimiter = urn.NameDelimiter // the delimiter between URN name elements
|
|
|
|
URNTypeDelimiter = urn.TypeDelimiter // the delimiter between URN type elements
|
2017-03-03 01:10:10 +00:00
|
|
|
)
|
|
|
|
|
2023-07-18 15:10:23 +00:00
|
|
|
// ParseURN attempts to parse a string into a URN returning an error if it's not valid.
|
2024-03-14 15:28:32 +00:00
|
|
|
func ParseURN(s string) (URN, error) { return urn.Parse(s) }
|
2023-07-18 15:10:23 +00:00
|
|
|
|
|
|
|
// ParseOptionalURN is the same as ParseURN except it will allow the empty string.
|
2024-03-14 15:28:32 +00:00
|
|
|
func ParseOptionalURN(s string) (URN, error) { return urn.ParseOptional(s) }
|
2023-07-18 15:10:23 +00:00
|
|
|
|
2017-03-03 01:10:10 +00:00
|
|
|
// NewURN creates a unique resource URN for the given resource object.
|
2023-11-20 08:59:00 +00:00
|
|
|
func NewURN(stack tokens.QName, proj tokens.PackageName, parentType, baseType tokens.Type, name string) URN {
|
2024-03-14 15:28:32 +00:00
|
|
|
return urn.New(stack, proj, parentType, baseType, name)
|
2022-03-03 09:53:28 +00:00
|
|
|
}
|