Sample values.yaml file for LWM2M deployment

The following is a sample override values.yaml file for LWM2M.

pullPolicy: ${docker.pullPolicy}
# replicas is the replication count
rbac_enabled: true
pcap_scc_enabled: false
# description:
#   To enable packetcapture functionality with security context constraint, set pcap_scc_enabled to true.
replicas: 1

#nodeSelector is the optional node selector (key value pairs)
nodeSelector:

# lwm2mTag is the LWM2M image tag. Defaults to chart.AppVersion
# lwm2mTag:

# lwm2mResources contains resource limits for LWM2M image
lwm2mResources:
  limits:
    memory: "4Gi"
    cpu: 2
  requests:
    memory: "1024Mi"
    cpu: 500m
javaOpts: ""


lwm2mSchemaResources:
  limits:
    memory: "512Mi"
    cpu: 1
  requests:
    memory: "128Mi"
    cpu: 200m
persistence:
    fwimage:
        ## this enables PVC templates that will create one per pod
        enabled: false

        ## Persistent Volume Claim name which will be used during creation
        pvcname: lwm2m-firmware

        ## fwimage directory Persistent Volume Storage Class
        ## it should be a storage class which provides ReadWriteMany accessMode (eg. glusterfs storage class )
        ## the bounded persistent volume will be shared between all containers in order to have a shared firmware immages storage.
        ## If defined, storageClassName: <storageClass>
        ## If set to "-", storageClassName: "", which disables dynamic provisioning
        ## If undefined (the default) or set to null, no storageClassName spec is
        ##   set, choosing the default provisioner.
        ##
        # storageClass: "-"
        # storageClass: "glusterfs-storageclass"
        storageClass: "-"
        accessMode: ReadWriteMany
        # the requested size of the mounted volume
        size: 5Gi
    objregistry:
        enabled: false
        # description:
        #   If enabled, lwm2m objects are maintained in persistent volume; otherwise configmap is used for lwm2m object models. Following parameters under objregistry are applicable only when enabled = true
        pvcname: lwm2m-object-registry
        # description:
        #   Name of the pvc
        # storageClass: "glusterfs-storageclass"
        storageClass: "-"
        # description:
        #   This is the storage class name for the pvc. The storage class should represent a common shared storage like glusterfs-storageclass. Leave it "-" if objregistry.enabled is false
        accessMode: ReadWriteMany
        # description:
        #   The access mode of the pvc should be ReadWriteMany so that all replicas of lwm2m-controller can access and modify the storage volume
        size: 1Gi
        # description:
        #   The size of the persistent volume used to store lwm2m object models
    packetcapture:
        enabled: false
        pvcname: lwm2m-packet-capture
        # storageClass: "glusterfs-storageclass"
        storageClass: "-"
        # description:
        #   This is the storage class name for the pvc. The storage class should represent a common shared storage like glusterfs-storageclass. Leave it "-" if packetcapture.enabled is false
        accessMode: ReadWriteMany
        # description:
        #   The access mode of the pvc should be ReadWriteMany so that all replicas of lwm2m-controller can access and modify the storage volume
        size: 5Gi
        # description:
        #   The size of the persistent volume used to store lwm2m pcap files
        #   Reserve atleast 500Mi x replicas

#serviceAccount: lwm2m
# description:
#   To enable packetcapture functionality, use the serviceAccount.
#   It requires PSP,role,roleBinding and serviceAccount to be created as prerequisites, Refer README.

config:
    cert:
      keyFile: ""
     # scef truststore path location 
     # scefTrustStorePath: ""
    lwm2m:
      LWM2M_NO_SEC_REG_URL: "127.0.0.1:5683"
      LWM2M_PSK_REG_URL: "127.0.0.1:5684"
      #LWM2M_SERVER_CERT_PATH: /appl/config/certs/server.p12
      UQ_CMD_EXPIRY_IN_MINS: 1440
      LWM2M_OBJECT_DEFINITIONS_DIR: /appl/config/models
      PCAP_DATA_DIR: /appl/data
      PCAP_FILE_SIZE_IN_MB: 100
      # description: If the file capturing the packets reach this size a new file is created.
      PCAP_FILE_COUNT: 5
      # description: Limit the number of files created, and begin overwriting files from the beginning
      PCAP_CLIENT_ADDRESS_TTL_IN_SEC: 604800
      # description: The time-to-live for the client addresses maintained in the DB. The records would be cleared after the TTL is reached.
      OMA_REGISTRY_API_BASE_URL: "http://www.openmobilealliance.org/api"
      AGENTSERVER_EXCHANGE: "agentserver"
      LIFECYCLE_KEY: "lifecycle"
      OBSERVATION_KEY: "observation"
      RESPONSES_KEY: "response"
      FAULT_KEY: "fault"
      FIRMWARE_EXPIRY_IN_HRS: 24
      FIRMWARE_POLLING_INTERVAL_IN_SEC: 1
      FIRMWARE_POLLING_COUNT: 3
      LWM2M_BOOTSTRAP_DISABLE_TIMEOUT: 86400
      THREAD_POOL_SIZE: 100
      DTLS_THREAD_POOL_SIZE: 100
      SCRIPT_THREAD_POOL_SIZE_MIN: 200
      SCRIPT_THREAD_POOL_SIZE_MAX: 200
      FW_IMAGE_CACHE_CONCURRENCY_LEVEL: 10
      FW_IMAGE_CACHE_EXPIRATION_AFTER_ACCESS: 10
      FW_IMAGE_CACHE_EXPIRATION_AFTER_WRITE: 10
      FW_IMAGE_CACHE_MAXIMUM_SIZE: 10
      LWM2M_MASTER_HOST: lwm2m-controller-0.lwm2m-service.default.svc.cluster.local
      LWM2M_REGISTRATION_URI: "127.0.0.1:5684"
      LWM2M_BOOTSTRAP_SESSION_EXPIRATION_IN_MINS: 1440
      LWM2M_KICK_INSTANCE: 1
      LWM2M_CLIENT_ACTIVE_DURATION: 60
      LWM2M_SMS_SESSION_ACTIVE_DURATION: 60
      # description: This is the time gap   (in seconds) between two wake-up SMS invocation for a particular device.
      # default: 60
      LWM2M_LEGACY_BOOTSTRAP_INTERFACE_DTLS_PORT: 0
      LWM2M_LEGACY_BOOTSTRAP_INTERFACE_SETUP_IDENTITY: "identity"
      MAX_RESPONSE_TIME_IN_SECS: 180
      SCEF_SERVER_URL: "http://localhost:8080"
      SCEF_SCS_ID: "lwm2mScs"
      SCEF_CALLBACK_PUBLIC_URL: "http://lwm2m-scef-callback:6666/callback"
      LWM2M_PSK_LENGTH: 64
      #CBOR_RESOURCES: /?(54321|54399)/([0-9])/[8,9](?:.*)?
      # user name used for T8 basic auth
      # SCEF_USER_NAME: "nidduser"
      # scef trust store path if T8 backend uses https
      SCEF_TRUST_STORE_PATH: "/appl/config/certs/sceftrust.jks"
      LWM2M_API_URL: "http://lwm2m-api:7777/"
      TRM_CONFIGURATION_DIR: /appl/config/trm
      NON_IP_TRANSPORT: "SGI"
      USE_CACHE_WITH_ASYNC_QUERIES: false
      # This property specifies the database storage in LwM2M, default is false
      USE_CASSANDRA_DB: false

      #SUBSCRIBER_REPO_URL: "http://impactsubscrepo:9095"
      #SUBSCRIBER_REPO_USER: "admin"

      CDP_URL: "http://cdp:8080"
      CDP_USER: "superadmin"

      # This property to be enabled for NOSEC Authentication for host ports 31234 and 30999,this is not required for SCEF/SGI flows
      ENABLE_SUBSCRIBER_REPO: false
      # Specify integer value. Values mappings:  0 - Pull, 1 - Push
      FW_DELIVERY_METHOD: 1
      # Specify integer value. Values mappings: 0 - CoAP, 1 - CoAPS, 2 - HTTP, 3 - HTTPS
      FW_UPDATE_PROTOCOL: 3
      # Reject commands if registration is expired by server
      REJECT_EXPIRED_ENDPOINTS: false
      # To enable control queue, configure Redis properties
      ENABLE_CONTROL_QUEUE: false
      # Batch size for command queue expiry timer, when redis is enabled for command queue
      REDIS_CMD_EXP_BATCH_SIZE: "1000"
      # Expiry timer scheduler interval for command queue, when redis is enabled for command queue
      REDIS_CMD_EXP_SCHED_IN_SECS: 60
    monte:
      #the values for monitor_expire_time are to be provided with notations like "2d" for 2 days
      #the value needs to be a number followed by "d/D"(days), "m/M"(minutes),"h/H"(hour),"s/S"(seconds),"ms/MS"(milliseconds)
      #P indicates the period (required)
      #nY indicates the number of years
      #nM indicates the number of months
      #nD indicates the number of days
      #T indicates the start of a time section (required if you are going to specify hours, minutes, or seconds)
      #nH indicates the number of hours
      #nM indicates the number of minutes
      #nS indicates the number of seconds
      MONITOR_EXPIRY_TIME: P2D
      UE_REACHABILITY_ENABLED: false
# californium properties
    californium:
      coap:
        ACK_TIMEOUT: 2000
        ACK_INIT_RANDOM: 1.5
        ACK_TIMEOUT_SCALE: 2.0
        MAX_RETRANSMIT: 4
        NSTART: 1
        PROBING_RATE: 1.0
        EXCHANGE_LIFETIME: 247000
        NON_LIFETIME: 145000
        MAX_TRANSMIT_WAIT: 93000
        PREFERRED_BLOCK_SIZE: 512
        MAX_MESSAGE_SIZE: 1024
        BLOCKWISE_STATUS_LIFETIME: 300000
        MAX_RESOURCE_BODY_SIZE: "1048576"
        PROTOCOL_STAGE_THREAD_COUNT: 100
      tcp:
        CONNECTION_IDLE_TIMEOUT: 600000
        CONNECT_TIMEOUT: 10000
        HANDSHAKE_TIMEOUT: 10000
        WORKER_THREADS: 10
      dtls:
        # Deprecated Ciphers Suites are not supported by default. To override, set the value to false
        RECOMMENDED_CIPHER_SUITES_ONLY: true
        # EXTENDED_MASTER_SECRET_MODE is ENABLED by default, considering the vulnerability mentioned https://datatracker.ietf.org/doc/html/rfc7627#section-6.1
        # To override set the value to OPTIONAL
        EXTENDED_MASTER_SECRET_MODE: ENABLED
    redis:
      #REDIS_DB_HOST: "crdb-crdb-redisio:6379"
      #REDIS_MASTER_NAME:
      #REDIS_MAX_TOTAL: 15
      #REDIS_MAX_IDLE: 15
      #this property should be enabled for redis cluster, the values can be host:port of all the clusters with ',' seperated ex: HOST1:PORT1,HOST2:PORT2,HOST3:PORT3
      #REDIS_CLUSTER_HOSTS:

    usage:
      USAGE_CONTROL_ENABLE: false
      enterpriseBilling: false
    trm:
      enabled: false

nodePort:
    nosec: 30683
    dtls: 30684
    tcp: 30683
    tls: 30684
    legacyBootstrap: 30784
    lwm2mscefcb: 30666

hostPort:
    noSecBS: 31234
    nosecRd: 30999


cassandra:
    # cassandraUser is the username of Cassandra.
    username: "impact"
    # cassandraGatewayKeyspace is the Cassandra keyspace to use.
    keyspace: "lwm2m"
    # cassandra.dropKeyspace When true, keyspace will be dropped before creation/upgrade. Do not use in production
    dropKeyspace: "false"
    CAS_KEYSPACE_REPLICATION: "{ 'class' : 'SimpleStrategy', 'replication_factor': 1 }"   
global:
  secretname: "lwm2m-secrets"
  registry: ${docker.registry}
  # broker properties
  broker:
    # brokerHosts is the RMQ hosts and ports.
    hosts: "rabbitmq:5672"
    # brokerUsername is the username of RMQ
    username: "impact"
    # brokerVirtualHost is the vhost of RMQ
    virtualHost: "/"
  #ingress_proxy: http://proxy_host:proxy_port/
  #description: >
  #  This is applicable for OMA registry to download LwM2M Object contents from OMA site.
  #  The ingress_proxy is required, if the k8s host does not have direct access to Internet.
  #  Uncomment ingress_proxy and provide the http proxy URL.
# cassandra properties
  cassandra:
    # cassandraHosts is the cassandra host and port.
    hosts: "cassandra:9042"
    # adminUsername is the name of the cassandra admin user, used to create dedicated keyspace/user. If not specified, dedicated user/keyspace is supposed to be created upfront
    adminUsername: null
    # No of core local connections to cassandra
    coreLocal: 20
    # No of max local connections to cassandra
    maxLocal: 500
    # No of core remote connections to cassandra
    coreRemote: 10
    # No of max remote connections to cassandra
    maxRemote: 50
    # Local cassandra DC name
    localdc: "dc_east"
ingress:
  ## Host to which Monte Notification from SECF are sent.
  host: lwm2mdev-cluster-edge-01
  ssl_redirect: false
  secretname: lwm2m-api
Note: Reclaiming the PV when re-installing IMPACT Mobile and LWM2M

While re-installing IMPACT Mobile, NFS Persistent Volume has to be reclaimed manually.

  1. Execute the command:
    kubectl edit <pv_name>
  2. Remove the section claimRef.
  3. Save the changes and check if the CLAIM status in kubectl get pv is AVAILABLE.
    Note: Delete all the PVCs before reclaim.
Note: The values given in the above sample file are only for illustration purpose. Nokia recommends to modify these values based on your deployment.