import * as pulumi from "@pulumi/pulumi";
/**
 * Manages a single assignment for a role. Conflicts with the "grafana.enterprise.RoleAssignment" resource which manages the entire set of assignments for a role.
 *
 * ## Example Usage
 *
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as grafana from "@pulumiverse/grafana";
 *
 * const testRole = new grafana.enterprise.Role("test_role", {
 *     name: "Test Role",
 *     uid: "testrole",
 *     version: 1,
 *     global: true,
 *     permissions: [{
 *         action: "org.users:add",
 *         scope: "users:*",
 *     }],
 * });
 * const testTeam = new grafana.oss.Team("test_team", {name: "terraform_test_team"});
 * const testUser = new grafana.oss.User("test_user", {
 *     email: "terraform_user@test.com",
 *     login: "terraform_user@test.com",
 *     password: "password",
 * });
 * const testSa = new grafana.oss.ServiceAccount("test_sa", {
 *     name: "terraform_test_sa",
 *     role: "Viewer",
 * });
 * const user = new grafana.enterprise.RoleAssignmentItem("user", {
 *     roleUid: testRole.uid,
 *     userId: testUser.id,
 * });
 * const team = new grafana.enterprise.RoleAssignmentItem("team", {
 *     roleUid: testRole.uid,
 *     teamId: testTeam.id,
 * });
 * const serviceAccount = new grafana.enterprise.RoleAssignmentItem("service_account", {
 *     roleUid: testRole.uid,
 *     serviceAccountId: testSa.id,
 * });
 * ```
 *
 * ## Import
 *
 * ```sh
 * $ pulumi import grafana:index/roleAssignmentItem:RoleAssignmentItem name "{{ roleUID }}:{{ type (user, team or service_account) }}:{{ identifier }}"
 * ```
 *
 * ```sh
 * $ pulumi import grafana:index/roleAssignmentItem:RoleAssignmentItem name "{{ orgID }}:{{ roleUID }}:{{ type (user, team or service_account) }}:{{ identifier }}"
 * ```
 *
 * @deprecated grafana.index/roleassignmentitem.RoleAssignmentItem has been deprecated in favor of grafana.enterprise/roleassignmentitem.RoleAssignmentItem
 */
export declare class RoleAssignmentItem extends pulumi.CustomResource {
    /**
     * Get an existing RoleAssignmentItem resource's state with the given name, ID, and optional extra
     * properties used to qualify the lookup.
     *
     * @param name The _unique_ name of the resulting resource.
     * @param id The _unique_ provider ID of the resource to lookup.
     * @param state Any extra arguments used during the lookup.
     * @param opts Optional settings to control the behavior of the CustomResource.
     */
    static get(name: string, id: pulumi.Input<pulumi.ID>, state?: RoleAssignmentItemState, opts?: pulumi.CustomResourceOptions): RoleAssignmentItem;
    /**
     * Returns true if the given object is an instance of RoleAssignmentItem.  This is designed to work even
     * when multiple copies of the Pulumi SDK have been loaded into the same process.
     */
    static isInstance(obj: any): obj is RoleAssignmentItem;
    /**
     * The Organization ID. If not set, the default organization is used for basic authentication, or the one that owns your service account for token authentication.
     */
    readonly orgId: pulumi.Output<string>;
    /**
     * the role UID onto which to assign an actor
     */
    readonly roleUid: pulumi.Output<string>;
    /**
     * the service account onto which the role is to be assigned
     */
    readonly serviceAccountId: pulumi.Output<string | undefined>;
    /**
     * the team onto which the role is to be assigned
     */
    readonly teamId: pulumi.Output<string | undefined>;
    /**
     * the user onto which the role is to be assigned
     */
    readonly userId: pulumi.Output<string | undefined>;
    /**
     * Create a RoleAssignmentItem resource with the given unique name, arguments, and options.
     *
     * @param name The _unique_ name of the resource.
     * @param args The arguments to use to populate this resource's properties.
     * @param opts A bag of options that control this resource's behavior.
     */
    /** @deprecated grafana.index/roleassignmentitem.RoleAssignmentItem has been deprecated in favor of grafana.enterprise/roleassignmentitem.RoleAssignmentItem */
    constructor(name: string, args: RoleAssignmentItemArgs, opts?: pulumi.CustomResourceOptions);
}
/**
 * Input properties used for looking up and filtering RoleAssignmentItem resources.
 */
export interface RoleAssignmentItemState {
    /**
     * The Organization ID. If not set, the default organization is used for basic authentication, or the one that owns your service account for token authentication.
     */
    orgId?: pulumi.Input<string>;
    /**
     * the role UID onto which to assign an actor
     */
    roleUid?: pulumi.Input<string>;
    /**
     * the service account onto which the role is to be assigned
     */
    serviceAccountId?: pulumi.Input<string>;
    /**
     * the team onto which the role is to be assigned
     */
    teamId?: pulumi.Input<string>;
    /**
     * the user onto which the role is to be assigned
     */
    userId?: pulumi.Input<string>;
}
/**
 * The set of arguments for constructing a RoleAssignmentItem resource.
 */
export interface RoleAssignmentItemArgs {
    /**
     * The Organization ID. If not set, the default organization is used for basic authentication, or the one that owns your service account for token authentication.
     */
    orgId?: pulumi.Input<string>;
    /**
     * the role UID onto which to assign an actor
     */
    roleUid: pulumi.Input<string>;
    /**
     * the service account onto which the role is to be assigned
     */
    serviceAccountId?: pulumi.Input<string>;
    /**
     * the team onto which the role is to be assigned
     */
    teamId?: pulumi.Input<string>;
    /**
     * the user onto which the role is to be assigned
     */
    userId?: pulumi.Input<string>;
}
