LoginSignup
2
1

More than 1 year has passed since last update.

TypeScriptを用いてContentfulへ新規投稿する

Last updated at Posted at 2021-10-17

他のサイトで書いた記事を取得し、contetfulへ保存する処理についてまとめています。
contentfulの基礎的な概念や扱いを把握していることを前提としてい記事を書いております。
間違いなどあれば、指摘していただけると幸いです。

利用するサードパーティーのインストール(https://www.npmjs.com/package/contentful-management)

yarn add contentful-management

記事を取得するだけならば、こちら(contentful) のサードパーティーだけで事足りますが、記事の保存などを行う場合は上の contentful-management を利用することをお勧めします。

まずapi key や spaceの情報を用いてclientを作成する

APIKEY, SPACEID はそれぞれのアカウントのものに読み替えてください。

spaceのenvironmentはデフォルトの masterを利用しています


import * as contentful from "contentful-management";
import { Environment } from "contentful-management/dist/typings/entities/environment";

export const connect = async (): Promise<Environment> => {
  const client = contentful.createClient({
    accessToken: APIKEY,
  });
  const mySpace = await client.getSpace(SPACEID);

  return await mySpace.getEnvironment("master");
};

上の connect メソッドによって返されるspace の Environment オブジェクトがspace のエントリーやメディアを操作するためのapiを提供してくれています。

新規記事の追加方法

まず、インターネット上にある画像のURLをもとにmediaの画像を作成 => それを利用して、新規の投稿を作ります。

Mediaへ新規画像の登録

createAssetWithIdメソッドは第一引数にidとなるstring, 第二引数にmedia objectを渡します。

const myEnvironment = await connect();

const assetRes = await myEnvironment
    .createAssetWithId("id-absdef", {
      fields: {
        title: {
          "en-US": "タイトル",
        },
        file: {
          "en-US": {
            contentType: "image/webp",
            fileName: "filename.webp",
            upload: "https://-------",
          },
        },
      },
    })
    .then((asset) => asset.processForAllLocales());

  await assetRes.publish();

// asset mediaのidさえあれば紐づけられる!
  const assetObj = {
    sys: {
      id: assetRes.sys.id,
      type: assetRes.sys.type,
      linkType: "Asset",
    },
  };

assetObj は次の新規投稿に用いるオブジェクトです。mediaのidさえあれば、contentful内で自動で既存メディアと紐づけてくれるようです。

await assetRes.publish()を忘れると投稿がdraft状態のままとなるので注意してください

新規記事の登録

contetTypeは利用するcontent typeに読み替えてください

createEntryWithIdメソッドは第一引数にcontent type, 第二引数にid, 第三引数に登録するobjectを渡します。

const res = await myEnvironment.createEntryWithId(
    "contentType",
    "id-ghijk",
    {
      fields: {
        title: { "en-US": "title" },
        slug: { "en-US": "slug" },
                // assetObjはmediaを新規登録した際に作成したオブジェクト
        image: { "en-US": assetObj },
        contents: { "en-US": "test test test test test test" },
        time: { "en-US": new Date() },
        tags: { "en-US": ["aaa", "bbb", "ccc"] },
      },
    }
  );
  await res.publish();

既存の投稿を更新する場合

let item = await myEnvironment.getEntry("id-gihjk");

item.fields.title["en-US"] = "new title";
item.fields.image["en-US"] = assetObj;
item.fields.contents["en-US"] = "new test test test test";
item.fields.tags["en-US"] = ["aaa", "bbb", "ccc", "zzz", "xxx"];
// 変更の適用
await item.update();
// 変更の更新
item = await myEnvironment.getEntry("id-gihjk");
await item.publish();

updateメソッドを呼ぶだけでは状態がchangeになるだけで、変更が公開されないので、publishメソッドまで呼ぶことを忘れずに、、

参考

2
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
1