Membuat kemunculan dan catatan khusus

Anda dapat memilih untuk memberikan metadata Anda sendiri ke Analisis Artefak untuk memenuhi kebutuhan bisnis tertentu. Misalnya, organisasi yang menyediakan pengelolaan keamanan untuk container Docker pelanggannya dapat menggunakan Artifact Analysis untuk menyimpan dan mengambil metadata terkait keamanan untuk image tersebut.

Langkah-langkah berikut menunjukkan cara memberikan metadata pengesahan untuk gambar Anda menggunakan Artifact Analysis API. Anda dapat menggunakan petunjuk yang sama untuk menyimpan dan mengambil jenis metadata apa pun yang didukung oleh Analisis Artefak.

Sebelum memulai

  1. Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
  2. In the Google Cloud console, on the project selector page, select or create a Google Cloud project.

    Roles required to select or create a project

    • Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
    • Create a project: To create a project, you need the Project Creator role (roles/resourcemanager.projectCreator), which contains the resourcemanager.projects.create permission. Learn how to grant roles.

    Go to project selector

  3. Enable the Container Analysis API.

    Roles required to enable APIs

    To enable APIs, you need the Service Usage Admin IAM role (roles/serviceusage.serviceUsageAdmin), which contains the serviceusage.services.enable permission. Learn how to grant roles.

    Enable the API

  4. Install the Google Cloud CLI.

  5. Jika Anda menggunakan penyedia identitas (IdP) eksternal, Anda harus login ke gcloud CLI dengan identitas gabungan Anda terlebih dahulu.

  6. Untuk melakukan inisialisasi gcloud CLI, jalankan perintah berikut:

    gcloud init
  7. In the Google Cloud console, on the project selector page, select or create a Google Cloud project.

    Roles required to select or create a project

    • Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
    • Create a project: To create a project, you need the Project Creator role (roles/resourcemanager.projectCreator), which contains the resourcemanager.projects.create permission. Learn how to grant roles.

    Go to project selector

  8. Enable the Container Analysis API.

    Roles required to enable APIs

    To enable APIs, you need the Service Usage Admin IAM role (roles/serviceusage.serviceUsageAdmin), which contains the serviceusage.services.enable permission. Learn how to grant roles.

    Enable the API

  9. Install the Google Cloud CLI.

  10. Jika Anda menggunakan penyedia identitas (IdP) eksternal, Anda harus login ke gcloud CLI dengan identitas gabungan Anda terlebih dahulu.

  11. Untuk melakukan inisialisasi gcloud CLI, jalankan perintah berikut:

    gcloud init
  12. Pelajari cara menyiapkan kontrol akses untuk metadata di project Anda. Lewati langkah ini jika Anda hanya menggunakan metadata dari kejadian yang dibuat oleh pemindaian container Artifact Analysis.
  13. Membuat catatan dan kemunculan untuk project

    Bagian ini menjelaskan cara membuat catatan dan kejadian. Untuk contoh ini, Anda akan menggunakan jenis ATTESTATION.

    Sebagai penyedia, Anda akan membuat catatan di project Anda untuk setiap pengesahan, dan Anda akan membuat kejadian di project pelanggan untuk kejadian pengesahan tersebut.

    Buat catatan

    Gunakan langkah-langkah berikut untuk membuat catatan dan memberikan ID catatan.

    API

    1. Buat file bernama note.json dengan deskripsi dan detail pengesahan. Kode berikut menunjukkan contoh file note.json:

      {
        "shortDescription": "A brief Description of the note",
        "longDescription": "A longer description of the note",
        "kind": "ATTESTATION",
        "attestation": {
          "hint": {
            "humanReadableName": "my-attestation-authority"
          }
        }
      }
      

      Lihat dokumentasi notes API untuk mengetahui informasi selengkapnya tentang representasi JSON catatan.

    2. Jalankan perintah curl berikut untuk membuat catatan:

      curl -v -H "Content-Type: application/json" -H \
        "Authorization: Bearer $(gcloud auth print-access-token)" \
        https://containeranalysis.googleapis.com/v1/projects/PROVIDER_PROJECT_ID/notes?note_id=NOTE_ID -d @note.json
      

      Dengan:

      • PROVIDER_PROJECT_ID adalah project ID Anda.
      • NOTE_ID menentukan ID untuk catatan Anda. Gunakan string dengan panjang maksimum 100 karakter.

    Java

    Untuk mempelajari cara menginstal dan menggunakan library klien untuk Artifact Analysis, lihat Library klien Artifact Analysis. Untuk mengetahui informasi selengkapnya, lihat dokumentasi referensi Artifact Analysis Java API.

    Untuk melakukan autentikasi ke Artifact Analysis, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.

    import com.google.cloud.devtools.containeranalysis.v1.ContainerAnalysisClient;
    import io.grafeas.v1.GrafeasClient;
    import io.grafeas.v1.Note;
    import io.grafeas.v1.ProjectName;
    import io.grafeas.v1.Version;
    import io.grafeas.v1.AttestationNote;
    import java.io.IOException;
    import java.lang.InterruptedException;
    
    public class CreateNote {
    
      // Creates and returns a new Note
      public static Note createNote(String noteId, String projectId)
          throws IOException, InterruptedException {
        // String noteId = "my-note";
        // String projectId = "my-project-id";
        final String projectName = ProjectName.format(projectId);
    
        Note newNote =
            Note.newBuilder()
                // Associate the Note with the metadata type
                // https://cloud.google.com/container-registry/docs/container-analysis#supported_metadata_types
                // Here, we use the type "attestation"
                .setAttestation(
                    AttestationNote.newBuilder()
                        .setHint(
                            AttestationNote.Hint.newBuilder()
                                .setHumanReadableName("my-attestation-authority")))
                .build();
    
        // Initialize client that will be used to send requests. After completing all of your requests,
        // call the "close" method on the client to safely clean up any remaining background resources.
        GrafeasClient client = ContainerAnalysisClient.create().getGrafeasClient();
        Note result = client.createNote(projectName, noteId, newNote);
        return result;
      }
    }
    

    Go

    Untuk mempelajari cara menginstal dan menggunakan library klien untuk Artifact Analysis, lihat Library klien Artifact Analysis. Untuk mengetahui informasi selengkapnya, lihat dokumentasi referensi Artifact Analysis Go API.

    Untuk melakukan autentikasi ke Artifact Analysis, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.

    
    import (
      "context"
      "fmt"
    
      containeranalysis "cloud.google.com/go/containeranalysis/apiv1"
      grafeaspb "google.golang.org/genproto/googleapis/grafeas/v1"
    )
    
    // createNote creates and returns a new attestation Note.
    func createNote(noteID, projectID string) (*grafeaspb.Note, error) {
      ctx := context.Background()
      client, err := containeranalysis.NewClient(ctx)
      if err != nil {
        return nil, fmt.Errorf("NewClient: %w", err)
      }
      defer client.Close()
    
      projectName := fmt.Sprintf("projects/%s", projectID)
    
      req := &grafeaspb.CreateNoteRequest{
        Parent: projectName,
        NoteId: noteID,
        Note: &grafeaspb.Note{
          Type: &grafeaspb.Note_Attestation{
            Attestation: &grafeaspb.AttestationNote{
              Hint: &grafeaspb.AttestationNote_Hint{
                HumanReadableName: "my-attestation-authority",
              },
            },
          },
        },
      }
    
      return client.GetGrafeasClient().CreateNote(ctx, req)
    }
    

    Node.js

    Untuk mempelajari cara menginstal dan menggunakan library klien untuk Artifact Analysis, lihat Library klien Artifact Analysis. Untuk mengetahui informasi selengkapnya, lihat dokumentasi referensi API Node.js Artifact Analysis.

    Untuk melakukan autentikasi ke Artifact Analysis, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.

    /**
    * TODO(developer): Uncomment these variables before running the sample
    */
    // const projectId = 'your-project-id', // Your Google Cloud Project ID
    // const noteId = 'my-note-id' // Id of the note
    
    // Import the library and create a client
    const {ContainerAnalysisClient} = require('@google-cloud/containeranalysis');
    const client = new ContainerAnalysisClient();
    
    // Construct request
    // Associate the Note with a metadata type
    // https://cloud.google.com/container-registry/docs/container-analysis#supported_metadata_types
    // Here, we use the type "attestation"
    const formattedParent = client.getGrafeasClient().projectPath(projectId);
    
    // Creates and returns a new Note
    const [note] = await client.getGrafeasClient().createNote({
      parent: formattedParent,
      noteId: noteId,
      note: {
        attestation: {
          hint: {
            humanReadableName: 'my-attestation-authority',
          },
        },
      },
    });
    
    console.log(`Note ${note.name} created.`);
    

    Ruby

    Untuk mempelajari cara menginstal dan menggunakan library klien untuk Artifact Analysis, lihat Library klien Artifact Analysis. Untuk mengetahui informasi selengkapnya, lihat dokumentasi referensi Artifact Analysis Ruby API.

    Untuk melakukan autentikasi ke Artifact Analysis, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.

    # note_id = "A user-specified identifier for the note"
    # project_id = "Your Google Cloud project ID"
    
    require "google/cloud/container_analysis"
    
    # Initialize the client
    client = Google::Cloud::ContainerAnalysis.container_analysis.grafeas_client
    
    parent = client.project_path project: project_id
    note = {
      attestation: {
        hint: {
          human_readable_name: "attestation-authority"
        }
      }
    }
    response = client.create_note parent: parent, note_id: note_id, note: note
    puts response.name
    

    Python

    Untuk mempelajari cara menginstal dan menggunakan library klien untuk Artifact Analysis, lihat Library klien Artifact Analysis. Untuk mengetahui informasi selengkapnya, lihat Dokumentasi referensi Python API Analisis Artefak.

    Untuk melakukan autentikasi ke Artifact Analysis, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.

    from google.cloud.devtools import containeranalysis_v1
    from grafeas.grafeas_v1 import types, Version
    
    def create_note(note_id: str, project_id: str) -> types.grafeas.Note:
        """Creates and returns a new attestation note."""
        # note_id = 'my-note'
        # project_id = 'my-gcp-project'
    
        client = containeranalysis_v1.ContainerAnalysisClient()
        grafeas_client = client.get_grafeas_client()
        project_name = f"projects/{project_id}"
        note = {
          "attestation": {
            "hint": {
              "human_readable_name": "attestation-authority",
            }
          }
        }
        response = grafeas_client.create_note(
            parent=project_name, note_id=note_id, note=note
        )
        return response
    

    Membuat kemunculan untuk catatan

    Untuk membuat kemunculan catatan:

    API

    1. Buat file bernama occurrence.json dengan deskripsi dan detail pengesahan. Kode berikut menunjukkan contoh file occurrence.json:

      {
        "resourceUri": "your-resource-uri-here",
        "noteName": "projects/your-note-project/notes/your-note-id",
        "kind": "ATTESTATION",
        "attestation": {
          "serializedPayload": "eW91ci1wYXlsb2FkLWhlcmU=",
          "signatures": [
            {
              "publicKeyId": "your-key-id-here",
              "signature": "eW91ci1zaWduYXR1cmUtaGVyZQ=="
            }
          ]
        }
      }
      

      Lihat dokumentasi notes API untuk mengetahui informasi selengkapnya tentang representasi JSON catatan.

    2. Jalankan perintah curl berikut untuk membuat kemunculan:

      curl -v -H "Content-Type: application/json" -H \
        "Authorization: Bearer $(gcloud auth print-access-token)" \
        https://containeranalysis.googleapis.com/v1/projects/PROVIDER_PROJECT_ID/occurrences/ -d @occurrence.json
      

      Dengan:

      • PROVIDER_PROJECT_ID adalah project ID Anda.
      • NOTE_ID menentukan ID untuk catatan Anda. Gunakan string dengan panjang maksimum 100 karakter.

    Java

    Untuk mempelajari cara menginstal dan menggunakan library klien untuk Artifact Analysis, lihat Library klien Artifact Analysis. Untuk mengetahui informasi selengkapnya, lihat dokumentasi referensi Artifact Analysis Java API.

    Untuk melakukan autentikasi ke Artifact Analysis, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.

    import com.google.cloud.devtools.containeranalysis.v1.ContainerAnalysisClient;
    import com.google.protobuf.ByteString;
    import io.grafeas.v1.AttestationOccurrence;
    import io.grafeas.v1.GrafeasClient;
    import io.grafeas.v1.NoteName;
    import io.grafeas.v1.Occurrence;
    import io.grafeas.v1.ProjectName;
    import io.grafeas.v1.Signature;
    import java.io.IOException;
    
    public class CreateOccurrence {
      // Creates and returns a new attestation Occurrence associated with an existing Note
      public static Occurrence createOccurrence(
          String resourceUrl, String noteId, String occProjectId, String noteProjectId)
          throws IOException {
        // String resourceUrl = "https://gcr.io/project/image@sha256:123";
        // String noteId = "my-note";
        // String occProjectId = "my-project-id";
        // String noteProjectId = "my-project-id";
        final NoteName noteName = NoteName.of(noteProjectId, noteId);
        final String occProjectName = ProjectName.format(occProjectId);
    
        Occurrence newOcc =
            Occurrence.newBuilder()
                .setNoteName(noteName.toString())
                .setResourceUri(resourceUrl)
                .setAttestation(
                    AttestationOccurrence.newBuilder()
                        .setSerializedPayload(ByteString.copyFrom("your-payload-here", "UTF-8"))
                        .addSignatures(
                            Signature.newBuilder()
                                .setPublicKeyId("your-key-id-here")
                                .setSignature(ByteString.copyFrom("your-signature-here", "UTF-8"))))
                .build();
    
        // Initialize client that will be used to send requests. After completing all of your requests,
        // call the "close" method on the client to safely clean up any remaining background
        // resources.
        GrafeasClient client = ContainerAnalysisClient.create().getGrafeasClient();
        Occurrence result = client.createOccurrence(occProjectName, newOcc);
        return result;
      }
    }
    

    Go

    Untuk mempelajari cara menginstal dan menggunakan library klien untuk Artifact Analysis, lihat Library klien Artifact Analysis. Untuk mengetahui informasi selengkapnya, lihat dokumentasi referensi Artifact Analysis Go API.

    Untuk melakukan autentikasi ke Artifact Analysis, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.

    import (
      "context"
      "fmt"
    
      containeranalysis "cloud.google.com/go/containeranalysis/apiv1"
      grafeaspb "google.golang.org/genproto/googleapis/grafeas/v1"
    )
    
    // createsOccurrence creates and returns a new Occurrence of a previously created attestation note.
      // Use this style of URL when you use Google Artifact Registry.
      // resourceURL := "https://LOCATION-docker.pkg.dev/my-project/my-repo/my-image"
      // noteID := "my-note"
      ctx := context.Background()
      client, err := containeranalysis.NewClient(ctx)
      if err != nil {
        return nil, fmt.Errorf("NewClient: %w", err)
      }
      defer client.Close()
    
      req := &grafeaspb.CreateOccurrenceRequest{
        Parent: fmt.Sprintf("projects/%s", occProjectID),
        Occurrence: &grafeaspb.Occurrence{
          NoteName: fmt.Sprintf("projects/%s/notes/%s", noteProjectID, noteID),
          // Attach the occurrence to the associated resource uri.
          ResourceUri: resourceURL,
          // Details about the attestation can be added here.
          Details: &grafeaspb.Occurrence_Attestation{
            Attestation: &grafeaspb.AttestationOccurrence{
              SerializedPayload: []byte("..."),
              Signatures: []*grafeaspb.Signature{
                {
                  PublicKeyId: "...",
                  Signature:   []byte("..."),
                },
              },
            },
          },
        },
      }
      return client.GetGrafeasClient().CreateOccurrence(ctx, req)
    }
    

    Node.js

    Untuk mempelajari cara menginstal dan menggunakan library klien untuk Artifact Analysis, lihat Library klien Artifact Analysis. Untuk mengetahui informasi selengkapnya, lihat dokumentasi referensi API Node.js Artifact Analysis.

    Untuk melakukan autentikasi ke Artifact Analysis, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.

    /**
     * TODO(developer): Uncomment these variables before running the sample
     */
    // const noteProjectId = 'your-project-id', // Your Google Cloud Project ID
    // const noteId = 'my-note-id', // Id of the note
    // const occurrenceProjectId = 'your-project-id', // The Google Cloud Project ID of the occurrence
    // If you are using Google Artifact Registry
    // const imageUrl = 'https://LOCATION-docker.pkg.dev/my-project/my-repo/my-image:123' // Image to attach metadata to
    
    // Import the library and create a client
    const {ContainerAnalysisClient} = require('@google-cloud/containeranalysis');
    const client = new ContainerAnalysisClient();
    
    // Construct request
    const formattedParent = client
    .getGrafeasClient()
    .projectPath(occurrenceProjectId);
    const formattedNote = client
    .getGrafeasClient()
    .notePath(noteProjectId, noteId);
    
    // Creates and returns a new Occurrence associated with an existing Note
    const [occurrence] = await client.getGrafeasClient().createOccurrence({
    parent: formattedParent,
    occurrence: {
      noteName: formattedNote,
      resourceUri: imageUrl,
      attestation: {
        serializedPayload: Buffer.from('your-payload-here').toString('base64'),
        signatures: [
          {
            publicKeyId: 'your-key-id-here',
            signature: Buffer.from('your-signature-here').toString('base64'),
          },
        ],
      },
    },
    });
    console.log(`Occurrence created ${occurrence.name}.`);
    return occurrence;
    

    Ruby

    Untuk mempelajari cara menginstal dan menggunakan library klien untuk Artifact Analysis, lihat Library klien Artifact Analysis. Untuk mengetahui informasi selengkapnya, lihat dokumentasi referensi Artifact Analysis Ruby API.

    Untuk melakukan autentikasi ke Artifact Analysis, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.

    # note_id    = "A user-specified identifier for the note"
    # project_id = "Your Google Cloud project ID"
    # note_project = "The project that contains the note"
    # occurrence_project = "The project that contains the occurrence"
    
    require "google/cloud/container_analysis"
    require "base64"
    
    # Initialize the client
    client = Google::Cloud::ContainerAnalysis.container_analysis.grafeas_client
    note_path = client.note_path project: note_project, note: note_id
    project_path = client.project_path project: occurrence_project
    
    occurrence = {
      note_name:    note_path,
      resource_uri: resource_url,
      attestation:  {
        serialized_payload: Base64.encode64("your-payload-here"),
        signatures:         [
          {
            public_key_id: "your-key-id-here",
            signature:     Base64.encode64("your-signature-here")
          }
        ]
      }
    }
    
    response = client.create_occurrence parent: project_path, occurrence: occurrence
    puts response.name
    

    Python

    Untuk mempelajari cara menginstal dan menggunakan library klien untuk Artifact Analysis, lihat Library klien Artifact Analysis. Untuk mengetahui informasi selengkapnya, lihat Dokumentasi referensi Python API Analisis Artefak.

    Untuk melakukan autentikasi ke Artifact Analysis, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.

    import base64
    from google.cloud.devtools import containeranalysis_v1
    from grafeas.grafeas_v1 import types
    
    def create_occurrence(
        resource_url: str, note_id: str, occurrence_project: str, note_project: str
    ) -> types.grafeas.Occurrence:
        """Creates and returns a new occurrence of a previously
        created attestation note."""
        # note_id = 'my-note'
        # project_id = 'my-gcp-project'
    
        client = containeranalysis_v1.ContainerAnalysisClient()
        grafeas_client = client.get_grafeas_client()
        formatted_note = f"projects/{note_project}/notes/{note_id}"
        formatted_project = f"projects/{occurrence_project}"
    
        occurrence = {
            "note_name": formatted_note,
            "resource_uri": resource_url,
            "attestation": {
                "serialized_payload": base64.b64encode(b"your-payload-here").decode("utf-8"),
                "signatures": [
                    {
                        "public_key_id": "your-key-id-here",
                        "signature": base64.b64encode(b"your-signature-here").decode("utf-8"),
                    }
                ],
            },
        }
    
        return grafeas_client.create_occurrence(
            parent=formatted_project, occurrence=occurrence
        )
    

    Mendapatkan semua kejadian untuk catatan tertentu

    Anda dapat melihat semua kemunculan pengesahan tertentu di seluruh project pelanggan Anda menggunakan notes.occurrences.list().

    API

    Untuk mencantumkan semua kemunculan catatan, kirim permintaan GET sebagai berikut:

    GET https://containeranalysis.googleapis.com/v1/projects/PROJECT_ID/notes/NOTE_ID/occurrences
    

    Lihat endpoint projects.notes.occurrences.list API untuk detail selengkapnya.

    Java

    Untuk mempelajari cara menginstal dan menggunakan library klien untuk Artifact Analysis, lihat Library klien Artifact Analysis. Untuk mengetahui informasi selengkapnya, lihat dokumentasi referensi API Java Artifact Analysis.

    Untuk melakukan autentikasi ke Artifact Analysis, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.

    import static java.lang.Thread.sleep;
    
    import com.google.cloud.devtools.containeranalysis.v1.ContainerAnalysisClient;
    import io.grafeas.v1.GrafeasClient;
    import io.grafeas.v1.ListNoteOccurrencesRequest;
    import io.grafeas.v1.NoteName;
    import io.grafeas.v1.Occurrence;
    import java.io.IOException;
    import java.lang.InterruptedException;
    
    public class OccurrencesForNote {  
      // Retrieves all the Occurrences associated with a specified Note
      // Here, all Occurrences are printed and counted
      public static int getOccurrencesForNote(String noteId, String projectId) 
          throws IOException, InterruptedException {
        // String noteId = "my-note";
        // String projectId = "my-project-id";
        final NoteName noteName = NoteName.of(projectId, noteId);
    
        ListNoteOccurrencesRequest request = ListNoteOccurrencesRequest.newBuilder()
                                                                       .setName(noteName.toString())
                                                                       .build();
    
        // Initialize client that will be used to send requests. After completing all of your requests, 
        // call the "close" method on the client to safely clean up any remaining background resources.
        GrafeasClient client = ContainerAnalysisClient.create().getGrafeasClient();
        int i = 0;
        for (Occurrence o : client.listNoteOccurrences(request).iterateAll()) {
          // Write custom code to process each Occurrence here
          System.out.println(o.getName());
          i = i + 1;
        }
        return i;
      }
    }

    Go

    Untuk mempelajari cara menginstal dan menggunakan library klien untuk Artifact Analysis, lihat Library klien Artifact Analysis. Untuk mengetahui informasi selengkapnya, lihat dokumentasi referensi API Go Artifact Analysis.

    Untuk melakukan autentikasi ke Artifact Analysis, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.

    
    import (
    	"context"
    	"fmt"
    	"io"
    
    	containeranalysis "cloud.google.com/go/containeranalysis/apiv1"
    	"google.golang.org/api/iterator"
    	grafeaspb "google.golang.org/genproto/googleapis/grafeas/v1"
    )
    
    // getOccurrencesForNote retrieves all the Occurrences associated with a specified Note.
    // Here, all Occurrences are printed and counted.
    func getOccurrencesForNote(w io.Writer, noteID, projectID string) (int, error) {
    	// noteID := fmt.Sprintf("my-note")
    	ctx := context.Background()
    	client, err := containeranalysis.NewClient(ctx)
    	if err != nil {
    		return -1, fmt.Errorf("NewClient: %w", err)
    	}
    	defer client.Close()
    
    	req := &grafeaspb.ListNoteOccurrencesRequest{
    		Name: fmt.Sprintf("projects/%s/notes/%s", projectID, noteID),
    	}
    	it := client.GetGrafeasClient().ListNoteOccurrences(ctx, req)
    	count := 0
    	for {
    		occ, err := it.Next()
    		if err == iterator.Done {
    			break
    		}
    		if err != nil {
    			return -1, fmt.Errorf("occurrence iteration error: %w", err)
    		}
    		// Write custom code to process each Occurrence here.
    		fmt.Fprintln(w, occ)
    		count = count + 1
    	}
    	return count, nil
    }
    

    Node.js

    Untuk mempelajari cara menginstal dan menggunakan library klien untuk Artifact Analysis, lihat Library klien Artifact Analysis. Untuk mengetahui informasi selengkapnya, lihat dokumentasi referensi API Node.js Artifact Analysis.

    Untuk melakukan autentikasi ke Artifact Analysis, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.

    /**
     * TODO(developer): Uncomment these variables before running the sample
     */
    // const projectId = 'your-project-id', // Your GCP Project ID
    // const noteId = 'my-note-id' // Id of the note
    
    // Import the library and create a client
    const {ContainerAnalysisClient} = require('@google-cloud/containeranalysis');
    const client = new ContainerAnalysisClient();
    
    // Get path to Note
    const formattedNote = client.notePath(projectId, noteId);
    
    // Retrieves all the Occurrences associated with a specified Note
    const [occurrences] = await client.getGrafeasClient().listNoteOccurrences({
      name: formattedNote,
    });
    
    if (occurrences.length) {
      console.log('Occurrences:');
      occurrences.forEach(occurrence => {
        console.log(`${occurrence.name}:`);
      });
    } else {
      console.log('No occurrences found.');
    }

    Ruby

    Untuk mempelajari cara menginstal dan menggunakan library klien untuk Artifact Analysis, lihat Library klien Artifact Analysis. Untuk mengetahui informasi selengkapnya, lihat dokumentasi referensi API Ruby Artifact Analysis.

    Untuk melakukan autentikasi ke Artifact Analysis, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.

      # note_id    = "The identifier for the note to query"
      # project_id = "The Google Cloud project ID of the occurrences to retrieve"
    
      require "google/cloud/container_analysis"
    
      # Initialize the client
      client = Google::Cloud::ContainerAnalysis.container_analysis.grafeas_client
    
      name = client.note_path project: project_id, note: note_id
      count = 0
      client.list_note_occurrences(name: name).each do |occurrence|
        # Process occurrence here
        puts occurrence
        count += 1
      end
      puts "Found #{count} occurrences"
      count
    end
    
    def get_discovery_info resource_url:, project_id:
      # resource_url = "The URL of the resource associated with the occurrence."
      #                # e.g. https://gcr.io/project/image@sha256:123
      # project_id   = "The Google Cloud project ID of the occurrences to retrieve"
    
      require "google/cloud/container_analysis"
    
      # Initialize the client
      client = Google::Cloud::ContainerAnalysis.container_analysis.grafeas_client
    
      parent = client.project_path project: project_id
      filter = "kind = \"DISCOVERY\" AND resourceUrl = \"#{resource_url}\""
      client.list_occurrences(parent: parent, filter: filter).each do |occurrence|
        # Process discovery occurrence here
        puts occurrence
      end
    end
    
    def occurrence_pubsub subscription_id:, timeout_seconds:, project_id:
      # subscription_id = "A user-specified identifier for the new subscription"
      # timeout_seconds = "The number of seconds to listen for new Pub/Sub messages"
      # project_id      = "Your Google Cloud project ID"
    
      require "google/cloud/pubsub"
    
      pubsub = Google::Cloud::PubSub.new project_id: project_id
      subscription_admin = pubsub.subscription_admin
      subscription = subscription_admin.create_subscription \
        name: pubsub.subscription_path(subscription_id),
        topic: pubsub.topic_path("container-analysis-occurrences-v1")
    
      subscriber = pubsub.subscriber subscription.name
      count = 0
      listener = subscriber.listen do |received_message|
        count += 1
        # Process incoming occurrence here
        puts "Message #{count}: #{received_message.data}"
        received_message.acknowledge!
      end
    
      listener.start
      # Wait for incoming occurrences
      sleep timeout_seconds
      listener.stop.wait!
    
      subscription_admin.delete_subscription subscription: subscription.name
    
      # Print and return the total number of Pub/Sub messages received
      puts "Total Messages Received: #{count}"
      count
    end
    
    # rubocop:disable Metrics/MethodLength
    
    def poll_discovery_finished resource_url:, timeout_seconds:, project_id:
      # resource_url    = "The URL of the resource associated with the occurrence."
      #                   # e.g. https://gcr.io/project/image@sha256:123
      # timeout_seconds = "The number of seconds to wait for the discovery occurrence"
      # project_id      = "Your Google Cloud project ID"
    
      require "google/cloud/container_analysis"
    
      deadline = Time.now + timeout_seconds
    
      # Initialize the client
      client = Google::Cloud::ContainerAnalysis.container_analysis.grafeas_client
      parent = client.project_path project: project_id
    
      # Find the discovery occurrence using a filter string
      discovery_occurrence = nil
      while discovery_occurrence.nil?
        begin
          filter = "resourceUrl=\"#{resource_url}\" " \
                   'AND noteProjectId="goog-analysis" ' \
                   'AND noteId="PACKAGE_VULNERABILITY"'
          # The above filter isn't testable, since it looks for occurrences in a
          # locked down project. Fall back to a more permissive filter for testing
          filter = "kind = \"DISCOVERY\" AND resourceUrl = \"#{resource_url}\""
          # Only the discovery occurrence should be returned for the given filter
          discovery_occurrence = client.list_occurrences(parent: parent, filter: filter).first
        rescue StandardError # If there is an error, keep trying until the deadline
          puts "discovery occurrence not yet found"
        ensure
          # check for timeout
          sleep 1
          raise "Timeout while retrieving discovery occurrence." if Time.now > deadline
        end
      end
    
      # Wait for the discovery occurrence to enter a terminal state
      status = Grafeas::V1::DiscoveryOccurrence::AnalysisStatus::PENDING
      until [:FINISHED_SUCCESS, :FINISHED_FAILED, :FINISHED_UNSUPPORTED].include? status
        # Update occurrence
        begin
          updated = client.get_occurrence name: discovery_occurrence.name
          status = updated.discovery.analysis_status
        rescue StandardError # If there is an error, keep trying until the deadline
          puts "discovery occurrence not yet in terminal state"
        ensure
          # check for timeout
          sleep 1
          raise "Timeout while retrieving discovery occurrence." if Time.now > deadline
        end
      end
      puts "Found discovery occurrence #{updated.name}."
      puts "Status: #{updated.discovery.analysis_status}"
      updated
    end
    
    # rubocop:enable Metrics/MethodLength
    
    def find_vulnerabilities_for_image resource_url:, project_id:
      # resource_url = "The URL of the resource associated with the occurrence
      #                e.g. https://gcr.io/project/image@sha256:123"
      # project_id   = "The Google Cloud project ID of the vulnerabilities to find"
    
      require "google/cloud/container_analysis"
    
      # Initialize the client
      client = Google::Cloud::ContainerAnalysis.container_analysis.grafeas_client
    
      parent = client.project_path project: project_id
      filter = "resourceUrl = \"#{resource_url}\" AND kind = \"VULNERABILITY\""
      client.list_occurrences parent: parent, filter: filter
    end
    
    def find_high_severity_vulnerabilities_for_image resource_url:, project_id:
      # resource_url       = "The URL of the resource associated with the occurrence."
      #                      # If you are using Google Container Registry
      #                      # e.g. https://gcr.io/project/repo/image@sha256:123
      #                      # If you are using Google Artifact Registry
      #                      # e.g. https://LOCATION-docker.pkg.dev/project/repo/image@sha256:123
      # project_id   = "The Google Cloud project ID of the vulnerabilities to find"
    
      require "google/cloud/container_analysis"
    
      # Initialize the client
      client = Google::Cloud::ContainerAnalysis.container_analysis.grafeas_client
    
      parent = client.project_path project: project_id
      filter = "resourceUrl = \"#{resource_url}\" AND kind = \"VULNERABILITY\""
      vulnerability_list = client.list_occurrences parent: parent, filter: filter
      # Filter the list to include only "high" and "critical" vulnerabilities
      vulnerability_list.select do |item|
        [:HIGH, :CRITICAL].include? item.vulnerability.effective_severity
      end
    end
    

    Python

    Untuk mempelajari cara menginstal dan menggunakan library klien untuk Artifact Analysis, lihat Library klien Artifact Analysis. Untuk mengetahui informasi selengkapnya, lihat dokumentasi referensi API Python Artifact Analysis.

    Untuk melakukan autentikasi ke Artifact Analysis, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.

    from google.cloud.devtools import containeranalysis_v1
    
    
    def get_occurrences_for_note(note_id: str, project_id: str) -> int:
        """Retrieves all the occurrences associated with a specified Note.
        Here, all occurrences are printed and counted."""
        # note_id = 'my-note'
        # project_id = 'my-gcp-project'
    
        client = containeranalysis_v1.ContainerAnalysisClient()
        grafeas_client = client.get_grafeas_client()
        note_name = f"projects/{project_id}/notes/{note_id}"
    
        response = grafeas_client.list_note_occurrences(name=note_name)
        count = 0
        for o in response:
            # do something with the retrieved occurrence
            # in this sample, we will simply count each one
            count += 1
        return count
    
    

    Langkah berikutnya